当前位置:早雪网网络学院编程文档C/C++ → C 语言编程

C 语言编程

减小字体 增大字体 作者:不详  来源:supcode.com收集整理  发布时间:2005-7-22 19:39:35
次循环的结果都是正确的. 当 i=10 时, 表达式 
 string2[size - i] 的值等于 `e`,  size - i 的值等于 1, 最后一个字符已经 
拷到新串里了. 
    如果你再把循环执行下去, 你会看到已经没有值分配给 string2[0] 了,  而 
它是新串的第一个字符, 因为 malloc 函数在分配内存时把它们初始化为空 
(null)字符. 所以 string2 的第一个字符是空字符. 这解释了为什么在打印 
string2 时没有任何输出了. 
  
    现在找出了问题出在哪里, 修正这个错误是很容易的. 你得把代码里写入 
string2 的第一个字符的的偏移量改为 size - 1 而不是 size. 这是因为 
string2 的大小为 12, 但起始偏移量是 0, 串内的字符从偏移量 0 到 偏移量 
10, 偏移量 11 为空字符保留. 
  
    为了使代码正常工作有很多种修改办法. 一种是另设一个比串的实际大小小 1 
 的变量. 这是这种解决办法的代码: 
  
#include  <stdio.h> 
  
  
  
main () 
  
  

  
  char my_string[] = "hello there"; 
  
  
  
  my_print (my_string); 
  
  my_print2 (my_string); 
  

  
  
  
my_print (char *string) 
  

  
  printf ("The string is %s\n", string); 
  

  
  
  
my_print2 (char *string) 
  

  
  char *string2; 
  
  int size, size2, i; 
  
  
  
  size = strlen (string); 
  
  size2 = size -1; 
  
  string2 = (char *) malloc (size + 1); 
  
  for (i = 0; i < size; i++) 
  
    string2[size2 - i] = string[i]; 
  
  string2[size] = `\0' 
  
  printf ("The string printed backward is %s\n", string2); 
  



另外的 C 编程工具 
    Slackware Linux 的发行版中还包括一些我们尚未提到的 C 开发工具. 本节 
将介绍这些工具和它们的典型用法. 
xxgdb 
    xxgdb 是 gdb 的一个基于 X Window 系统的图形界面.  xxgdb 包括了命令行 
版的 gdb 上的所有特性.  xxgdb 使你能通过按按钮来执行常用的命令. 设置了断 
点的地方也用图形来显示. 
  
    你能在一个 Xterm 窗口里键入下面的命令来运行它: 
xxgdb 
    你能用 gdb 里任何有效的命令行选项来初始化 xxgdb . 此外 xxgdb 也有一 
些特有的命令行选项, 表 27.2 列出了这些选项. 
  
表 27.2.  xxgdb 命令行选项. 
  
  
选  项 描  述 
db_name 指定所用调试器的名字, 缺省是 gdb. 
db_prompt 指定调试器提示符, 缺省为 gdb. 
gdbinit 指定初始化 gdb 的命令文件的文件名, 缺省为 .gdbinit. 
nx 告诉 xxgdb 不执行 .gdbinit 文件. 
bigicon 使用大图标. 
  
  
  
  
calls 
     你可以在 sunsite.unc.edu FTP 站点用下面的路径: 
/pub/Linux/devel/lang/c/calls.tar.Z 
  
    来取得 calls , 一些旧版本的 Linux CD-ROM 发行版里也附带有. 因为它是 
一个有用的工具, 我们在这里也介绍一下. 如果你觉得有用的话, 从 BBS, FTP, 
或另一张CD-ROM 上弄一个拷贝.  calls 调用 GCC 的预处理器来处理给出的源程 
序文件, 然后输出这些文件的里的函数调用树图. 
  
  
  
------------------------------------------------------------------------ 
-------- 
注意: 在你的系统上安装 calls , 以超级用户身份登录后执行下面的步骤: 1. 解 
压和 untar 文件. 2. cd 进入 calls untar 后建立的子目录. 3. 把名叫 
calls 的文件移动到 /usr/bin 目录. 4. 把名叫 calls.1 的文件移动到目录 
/usr/man/man1 . 5. 删除 /tmp/calls 目录. 这些步骤将把 calls 程序和它的指 
南页安装载你的系统上. 
------------------------------------------------------------------------ 
-------- 
  
    当 calls 打印出调用跟踪结果时, 它在函数后面用中括号给出了函数所在文 
件的文件名: 
main [test.c] 
    如果函数并不是向 calls 给出的文件里的,  calls 不知道所调用的函数来自 
哪里, 则只显示函数的名字: 
printf 
    calls 不对递归和静态函数输出. 递归函数显示成下面的样子: 
fact <<< recursive in factorial.c >>> 
    静态函数象这样显示: 
total [static in calculate.c] 
    作为一个例子, 假设用 calls 处理下面的程序: 
  
#include <stdio.h> 
  
  
  
main () 
  

  
char my_string[] = "hello there"; 
  
my_print (my_string); 
  
my_print2(my_string); 
  

  
  
  
my_print (char *string) 
  

  
printf ("The string is %s\n", string); 
  

  
  
  
my_print2 (char *string) 
  

  
  char *string2; 
  
  int size, size2, i; 
  
  
  
  size = strlen (string); 
  
  size2 = size -1; 
  
  string2 = (char *) malloc (size + 1); 
  
  for (i = 0; i < size; i++) 
  
    string2[size2 - i] = string[i]; 
  
  string2[size] = `\0' 
  
  printf ("The string printed backward is %s\n", string2); 
  

    将产生如下的输出: 
    1 main [test.c] 
  
    2       my_print [test.c] 
  
    3             printf 
  
    4       my_print2 [test.c] 
  
    5             strlen 
  
    6             malloc 
  
    7             printf 
calls 有很多命令行选项来设置不同的输出格式, 有关这些选项的更多信息请参考 
 calls 的指南页. 方法是在命令行上键入 calls -h .  
 
 
 
cproto 
    cproto 读入 C 源程序文件并自动为每个函数产生原型申明. 用 cproto 可以 
在写程序时为你节省大量用来定义函数原型的时间. 
    如果你让 cproto 处理下面的代码: 
#include  <stdio.h> 
  
  
  
main () 
  

  
  char my_string[] = "hello there"; 
  
  my_print (my_string); 
  
  my_print2(my_string); 
  

  
  
  
my_print (char *string) 
  

  
  printf ("The string is %s\n", *string); 
  

  
  
  
my_print2 (char *string) 
  

  
  char *string2; 
  
  int size, size2, i; 
  
  
  
  size = strlen (string); 
  
  size2 = size -1; 
  
  string2 = (char *) malloc (size + 1); 
  
  for (i = 0; i < size; i++) 
  
    string2[size2 - i] = string[i]; 
  
  string2[size] = `\0' 
  
  printf ("The string printed backward is %s\n", string2); 
  

    你将得到下面的输出: 
/* test.c */ 
  
int main(void); 
  

int my_print(char *string); 
  
int my_print2(char *string); 
    这个输出可以重定向到一个定义函数原型的包含文件里.        




indent 
    indent 实用程序是 Linux 里包含的另一个编程实用工具. 这个工具简单的说 
就为你的代码产生美观的缩进的格式. indent 也有很多选项来指定如何格式化你 
的源代码.这些选项的更多信息请看indent 的指南页, 在命令行上键入 indent -h 
 . 
  
    下面的例子是 indent 的缺省输出: 
  
    运行 indent 以前的 C 代码: 
  
#include  <stdio.h> 
  
  
  
main () { 
  
      char my_string[] = "hello there"; 
  
  my_print (my_string); 
  
     my_print2(my_string); } 
  
  
  
my_print (char *string) 
  

  
  printf    ("The string is %s\n", *string); 
  

  
  
  
my_print2           (char *string) { 
  
    char *string2; 
  
      int size, size2, i; 
  
  
  
      size = strlen (string); 
  
      size2 = size -1; 
  
      string2 = (char *) malloc (size + 1); 
  
  for (i = 0; i < size; i++) 
  
            string2[size2 - i] = string[i]; 
  
      string2[size] = `\0' 
  
  
      printf ("The string printed backward is %s\n", string2); 
  

    运行 indent 后的 C 代码: 
#include  <stdio.h> 
  
  
  
main () 
  

  
  char my_string[] = "hello there"; 
  
  my_prin

上一页  [1] [2] [3] [4]  下一页

[数据载入中...] [返回上一页] [打 印]