关闭

C 常见错误

361人阅读 评论(0) 收藏 举报
 1.用malloc或farmalloc动态分配内存时,如

  char *buffer;

  buffer=(char *)malloc(300);

  因为并不是在所有的情况下,都会分配成功

  所以应加 if(buffer==NULL) {......}

2.char far *buffer;

  buffer=(char far *)farmalloc(size);

  当size的值大于64K时,很可能不会分配成功,

  但是不会返回NULL,很容易出错。

  因此最好size的值最好不要大于64K

3.char 的取值范围为 0-127

  unsigned char 的取值范围为0-255

  新手常常在使用char时,出错,比如说,

  在256色的屏幕模式下,颜色索引值为0-255,

  而很多新手用 char color,这样会出错。

4.编程时常会对键盘进行处理

  key=bioskey(1);

  用bioskey(1)时,程序从缓冲区取一个键,但是不

  会把这个键从缓冲区移走,因此key的值将永远保持不变

5.用if(bioskey(1)!=0) key=bioskey(0);

  这样按键时,会从缓冲区移走一个键。

  但是当不按键时,key的值将保持不变,直到按下一键为止

  因此应加 else key=0;

6.使用textcolor(int newcolor);

      和textbackground(int newcolor);

  这两个函数来改变字符颜色和背景色时,

  用stdio.h中的printf,puts等向屏幕输出的函数是,并不能

  按textcolor(int),textbackground(int)这两个函数所要求的颜色来显示。

  用该用conio.h中的cprintf,cputs等函数

7.printf("/n");光标会在屏幕上换行并移动到第一列。

  但cprintf("/n");不会,printf是标准输出函数,与DOS相关

  DOS会自动把'/n'处理成'/n'和'/r',而cprintf是控制台级函数,不会这样

  因此应该用cprintf("/n/r");

8.float a=1.9;

  if(a==1.9) printf("OK");

  运行时却不会显示OK;

  不要用float型数字进行关系运算中的等于运算

  改为double双精度型即可解决问题.

9.在TC2.0中

  main()

  {

   ......

   .....

  }

  这样编译时不会出错

  但是在有些C语言版本中,系统会自动当作

  int main()

  {

   }

  而显示"..should return a value "

10.float a;

   a=1/2;

    printf("%f",a);

   运行的结果是0.000000,而不是0.500000.

   因为/号两边的数字是1和2,系统会当作整型处理,因此出

   现这种情况,解决办法是改为 a=1.0/2 或 a=1/2.0 或 1.0/2.0

11.一个函数

   char *buf()

   {

      char *data;

      char str[]="HELLO";

      data=str;

      return data;

   }

   因为系统在调用完函数时,会自动释放为str 开辟的空间,

   因此 return data无意义

12.对于findfirst(char *name,struct ffblk,int attrib);

       findnext(struct ffblk);

       当寻找目录时,用findfirst("*.*",&ffblk,FA_DIREC);

       虽然所找文件的属性为目录,但是会将当前目录下的所有文件找出来

      用findfirst("*.",&ffbli,FA_DIREC)时,找出来的是目录以及没有扩

      展名的文件。

13.看下面一个函数

   /*640x480x256*/

   void plot(int x,int y,unsigned char color)

   {

      char far *video=(char far *)(0xa0000000L);

      long int offest;

      

      offest=(y-1)*640+x-1;

      *(video+offest)=color;

   }

   看似没有错误,但是对于offest=(y-1)*640+x-1这句,

   虽然offest是长整型,但是y是短整型,在计算(y-1)*640时,系统

   会按短整型处理,当y的值取110以上时,(y-1)*640的值显然会超出

   短整型数字的取值范围,从而产生错误,因此应改为

   offest=(long int)(y-1)*640+x-1;

14.对于一个数组 int data[5][4];

   data表示data[0][0]的地址

   data[2]表示data[2][0]的地址

   因此有人认为data[4][2]的地址可表示为

   (1).data+4*4+2;

   (2).data[4]+2;

   其中(2)是正确的,而(1)却是错误的.

   因为data的基类型是8个字节的,

   data+4表示的就是data[4][0]的地址

   data+1表示的就是data[1][0]的地址

15.许多人认为转义字符'/64'中的64是十进制数,

   但实际上这个64是八进制数,这个八进制数前面可以加0也可不

   加0,当然转义字符/后面也可以用十六进制数,但要

   用'/x..'或'/X..'的形式,如'/x14'。

16.看下面这个程序

   #include <stdio.h>

   void display(int data[],int num)

   {

     int i;

     for(i=0;i<num;i++)

       printf("%d/n",data[i]);

   }

   void main()

   {

      int da[10]={0,1,2,3,4,5,6,7,8,9};

      display(da,10);  

  }

   一般认为当程序里调用这个函数时,系统会为形参data[]开辟一个

   10个整型数字的存储空间,实际上,这个函数只为data[]开辟一个整型指针类型的空间,

   使用指针指向data[]的首地址,因此在display(int data[],int num)这个函数中,

   若使用赋值语句对数组data[]的某项赋值,如data[0]=2,会使主程序中的数组da[]的值改变.

17.

   void main()

   {

       unsigned char index;

       for(index=0;index<256;index++)

      {

         printf("%d/n",index);

      }

   }

    在编译时,会出现警告。

    在TC2.0中,若改为index<=255,编译会通过,但是运行程序时

    却会陷入死循环,大家不禁会产生疑问,unsigned char类型数据的

    取值范围为0-255,为什么上述程序会出现错误呢。

    让我们先看下面一个程序:

    void main()

    {

       int i;

       for(i=0;i<10;i++)

       {;}

       printf("%d",i);

    }

    运行结果为10,当i=9的循环完成后,i自加1,使得i=10,这时不符合

    i<10,才跳出循环,因此运行结果为10;

    同理,若改为i<=10;则运行结果为11。

    通过这个程序,应该能明白为什么前一个程序会出错了。
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:74509次
    • 积分:1114
    • 等级:
    • 排名:千里之外
    • 原创:23篇
    • 转载:26篇
    • 译文:0篇
    • 评论:21条
    文章分类
    最新评论
    我的好友:一个软件Niu人