诊断错误及其处理_第1页
诊断错误及其处理_第2页
诊断错误及其处理_第3页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、断错误及其处理防止程序出错的第一关是编译器。如果遇到约束违规的情况或语法错误,编译器至少 会生成一个诊断错误信息。大多数编译器将其诊断信息分为两类:错误和警告。语法错误 很常见,也较易修改。调试程序时首先要改正的是语法错误,调试本身是一种艺术,是程 序中断时试着去修复的一种艺术。糟糕的语法会使编译器混乱,甚至可能到达生成很多错误的程度,程序设计者对这种 情况不要大惊小怪,应冷静对待,其实很可能仅仅是由于某一个语句引起的,比方说漏掉 了 while 循环中的一个大括号或语句末尾键入了冒号而非分号等。为此我们应该养成一种 习惯,自顶向下的修改方法,每次从错误表的开头开始,一次修改一、二个错误再编译

2、, 或许错误就能减少许多甚至全部语法错误。模块化程序设计也有助于程序的排错。 调试一个充满连接和转折、 全局变量等的程序要比 调试一个精心设计的模块化程序困难得多。如果程序分成几个模块,各个模块负责程序的一 个专项功能,一旦识别出问题可能所处的模块, 就很容易地通过检查源代码方式来发现错误, 这种策略也称为分治法, 因为如果知道了没有问题之处, 几乎等同于知道了问题发生的地方。有时我们也可以忽略警告,但这并非是一种良好的编程习惯,追踪每个警告的原因并 认真考虑是否有更稳健的方法编写代码能够帮助编程者编写更好的代码。如果我们只是忽 略它,当这些“无害的警告不断累积到一定程度时,可能面临出现混乱的

3、危险。、差 1 错误及其处理在C语言中,一个拥有n个元素的数组,不存在下标为n的元素,其元素下标的允许 取值范围为0到n-1。请考察以下一段代码:int a10, i; for(i=1; i<=10; i+)ai=0;这段代码本意是要设置数组 a 中的 10 个元素均为 0,却产生了一个出人意料的“副作 用。循环把并不存在的 a10 元素设置为 0。如果用来编译这段程序的编译器按照内存地 址递减的方式来给变量分配内存,那么内存中数组 a 之后的 2 个字节实际上分配给了整型变 量 i 。此时,本来循环计数器 i 的值为 10,循环体内将并不存在的 a10 设置为 0,实际 上却是将计数器

4、 i 的值设置为 0,这就陷入了死循环。 这是程序设计中较常见也较难觉察的一类错误,被称为“差一错误 (off-by-one error )。 “差一错误也称“栏杆错误 ,问题说的是: 100 英尺长的围栏每隔 10 英尺需要一根支 撑用的栏杆,一共需要多少根呢?如果不假思索,将 100除以 10得到 10,当然这个答案 是错误的,正确的答案应该是 11。是否存在一些编程技巧,能够降低这类错误发生的可能 性呢?“不对称边界法给程序设计带来的便利非常明显。在“不对称边界法中,可以 规定数组元素的第一个“入界点(对C语言而言,0就是数组下标的第一个“入界点) 和第一个“出界点 (对上述定义的数组而

5、言,第一个出界点就是10,它不在数组下标范围之内)。在这种方法下,“出界点的值即是数组的长度。三、“悬挂 else 错误及其处理这个问题并非C语言所独有,也已经为人熟知,但即使是有经验的 C程序员,也常常 在此失误。如果想实现当x分别是大于0、等于0和小于0时y值分别取得1、0和1。 考虑下面的程序片段:y=0;if(x>=0)if(x>0) y=1;else y=-1;然而,这段代码实际上所做的与编程者的愿望相去甚远。原因在于 C 语言中有这样的 规那么, else 总是与同一对括号内最近的未匹配的 if 结合。如果我们按照上面这段程序实 际上被执行的逻辑来调整代码缩进,大致是这

6、样:y=0;if(x>=0)if(x>0) y=1;else y=-1;也就是说,并非是当 x<0 时 y=-1 ,而是当 x=0 时也使 y=-1 。解决这一问题我们可以用“封装的方法,将上述程序改为:y=0;if(x>=0)if(x>0) y=1;else y=-1;现在, else 与第一个 if 结合,即使它离第二个 if 更近也是如此,因为此时第二个 if 已 经被括号“封闭起来了。四、整数溢出及其处理C语言为编程者提供了三种不同长度的整数:short int 、int和long int ,但不管是哪种类型表示的整数总有一定的范围,越出该范围时称为整数的

7、溢出。例如现有算法要求 如下:求满足条件1+2+3+n< 32767的最大整数n,请考察如下程序段:int n=1,sum=0;while(sum<=32767) sum+=n; n+;printf( “n=%dn,n-1);乍看该程序时无错误,但事实上,上列程序中的 while 循环是一个无限循环,原因在 于int型数的表示范围为-32768到+32767,当累加和sum超过32767时,便向高位进位, 而对int型数而言,最高位表示符号,故sum超过32767后便得到一个负数,while条件当然满足,从而形成无限循环。此时,最好的解决方法是将sum定义为long int型。五、

8、词法陷井及其处理(1)=不同于=这是初学者最易犯的一个错误,符号二作为赋值运算符,符号=作为比拟。一般而言, 赋值运算相对于比拟运算出现得更频繁,因此,字符数少的符号二就被赋予了更常用的含 义一一赋值运算。此外,在 C语言中赋值符号被作为一种操作符对待,因而重复进行赋值 运算(如a=b=c=5)可很容易地书写,并且赋值操作还可以嵌入到更大的表达式中。这种 使用上的便利性可能导致一个潜在的问题:本意是作比拟运算时,却可能无意中误写成了 赋值运算。 该错误大多数情况下可以通过简单的要素项重排而防止。 从编译器的角度出发, 对于相等测试,变元在等号的哪一边无关紧要,如果两边都是变量,那么需要留意符号

9、“二 的个数。但是,如果一边是常量,那么存在可以防止错误的适当措施。我们何不养成把常量 放在比拟运算符左边的习惯呢?因为这样一来,即便漏掉了一个符号,保证会出现 一个编译错误,因为不能给常数赋值。2字符与字符串C 语言中的单引号和双引号含义迥异,用单引号引起的一个字符实际上代表一个整数,整 数值对应于该字符在编译器采用的字符集中的序列值,因此,采用ASCII字符集的编译器而言, a'的含义与0141或97严格一致。而用双引号引起的字符串,代表的却是一个指向无名数组 起始字符的指针,该数组被双引号之间的字符以及一个额外的二进制值为零的字符 0'初始 化。整型数一般为 16位或 3

10、2位的存储空间中可以容纳多个字符 一般为 8 位,因此, 有的C编译器允许在一个字符常量以及字符串常量中包含多个字符。也就是说,用yes' 代替“yes不会被编译器检测到,后者的含义是“依次包含 y'、 e'、 s'以及字符0 ' 的4个连续内存单元的首地址,而前者的含义并没有正确地定义,有些 C编译器会处理 成出错,但大多数 C编译器的理解为“一个整数值,由 y ' e'、 s'所代表的整数值 按照特定编译器实现中定义的方式组合得到 。因此,这两者如果在数值上有什么相似之 处,也完全是一种巧合而已。 3整数溢出C语言为编程者提供

11、了三种不同长度的整数:short int 、int和long int ,但不管是哪种类型表示的整数总有一定的范围,越出该范围时称为整数的溢出。例如现有算法要求 如下:求满足条件1+2+3+n< 32767的最大整数n,请考察如下程序段:int n=1,sum=0;whilesum<=32767 sum+=n; n+;printf “n=%dn,n-1;乍看该程序时无错误,但事实上,上列程序中的 while 循环是一个无限循环,原因在 于int型数的表示范围为-32768到+32767,当累加和sum超过32767时,便向高位进位, 而对int型数而言,最高位表示符号,故 sum超过

12、32767后便得到一个负数,while条件 当然满足,从而形成无限循环。此时,最好的解决方法是将sum定义为long int型。4词法分析中的“贪心法C语言中的某些符号,例如/、*、=、+等,只有一个字符长,称为单词符符号。而/*、 =、+等包含了多个字符,称为多字符符号。当 C编译器读入一个字符/'后又跟了一个 字符 *' , 那么编译器就必须做出判断:是将其作为两个分别的符号对待,还是合起来作 为一个符号对待。C语言的处理策略是“贪心法,即从左到右一个字符一个字符地读入, 如果该字符可能组成一个符号,那么再读入下一个字符,判断已经读入的两个字符组成的 字符串是否可能是一个符

13、号的组成局部;如可能,再读入下一个字符,重复上述判断,直 到读入的字符组成的字符串已不再可能组成一个有意义的符号为止。所以a-b :应理解为a-b ;而将描述命题x除以p所指向的值时,应书写为:y=x/*p;而不要写为: y=x/*p,因为编译器将/*理解为一段注释的开始。六、C 语言常见错误小结C语言的最大特点是:功能强、使用方便灵活。 C编译的程序对语法检查并不象其它高级 语言那么严格,这就给编程人员留下“灵活的余地 ,但还是由于这个灵活给程序的调试 带来了许多不便,尤其对初学 C语言的人来说,经常会出一些连自己都不知道错在哪里的 错误。看着有错的程序,不知该如何改起,本人通过对 C的学习

14、,积累了一些C编程时常 犯的错误,写给各位学员以供参考。1. 书写标识符时,忽略了大小写字母的区别。main()int a=5;printf("%d",A);编译程序把a和A认为是两个不同的变量名,而显示出错信息。C认为大写字母和小写字 母是两个不同的字符。习惯上,符号常量名用大写,变量名用小写表示,以增加可读性。2. 忽略了变量的类型,进行了不合法的运算。main()float a,b;printf("%d",a%b);%是求余运算,得到a/b的整余数。整型变量a和b可以进行求余运算,而实型变量那么不 允许进行“求余运算。3. 将字符常量与字符串常量混

15、淆。char c;c="a" 在这里就混淆了字符常量与字符串常量,字符常量是由一对单引号括起来的单个字符, 字符串常量是一对双引号括起来的字符序列。 C 规定以“作字符串结束标志,它是由系 统自动加上的,所以字符串“ a实际上包含两个字符:a '和,而把它赋给一个字符 变量是不行的。4. 忽略了“ =与“ =的区别。在许多高级语言中,用“=符号作为关系运算符“等于。如在BASIC程序中可以写if (a=3) then 但C语言中,“=是赋值运算符,“=是关系运算符。如:if (a=3) a=b;前者是进行比拟,a是否和3相等,后者表示如果a和3相等,把b值赋给a。由

16、于习惯 问题,初学者往往会犯这样的错误。5. 忘记加分号。分号是C语句中不可缺少的一局部,语句末尾必须有分号。a=1b=2编译时,编译程序在“ a=1 后面没发现分号,就把下一行“ b=2也作为上一行语句的 一局部,这就会出现语法错误。改错时,有时在被指出有错的一行中未发现错误,就需要 看一下上一行是否漏掉了分号。 z=x+y;t=z/100;printf("%f",t);对于复合语句来说,最后一个语句中最后的分号不能忽略不写(这是和PASCA不同的)。6. 多加分号。对于一个复合语句,如: z=x+y;t=z/100;prin tf("%f",t);;

17、复合语句的花括号后不应再加分号,否那么将会画蛇添足。又如:if (a%3=0);I+;本是如果3整除a,那么I加1。但由于if (a%3=0)后多加了分号,那么if语句到此结束, 程序将执行I+语句,不管3是否整除a,I都将自动加1。再如:for (I=0;I<5;I+);sea nf("%d", &x);prin tf("%d",x);本意是先后输入5个数,每输入一个数后再将它输出。由于for()后多加了一个分号,使 循环体变为空语句,此时只能输入一个数并输出它。7. 输入变量时忘记加地址运算符“ &。int a,b;scan f

18、("%d%d",a,b);这是不合法的。Seanf函数的作用是:按照a、b在内存的地址将a、b的值存进去。“&a 指a在内存中的地址。8. 输入数据的方式与要求不符。 scan f("%d%d",&a,&b);输入时,不能用逗号作两个数据间的分隔符,如下面输入不合法:3,4输入数据时,在两个数据之间以一个或多个空格间隔,也可用回车键,跳格键 tab。 scan f("%d,%d",&a,&b);C规定:如果在“格式控制字符串中除了格式说明以外还有其它字符,那么在输入数据时 应输入与这些字符相同的

19、字符。下面输入是合法的:3,4此时不用逗号而用空格或其它字符是不对的。3 43 : 4又如:scan f("a=%d,b=%d",&a,&b);输入应如以下形式:a=3,b=49. 输入字符的格式与要求不一致。在用“ %c格式输入字符时,“空格字符和“转义字符都作为有效字符输入。scan f("%c%c%c",&c1,&c2,&c3);如输入a b c字符“a送给cl,字符“ 送给c2,字符“b送给c3,因为0只要求读入一个字符, 后面不需要用空格作为两个字符的间隔。10. 输入输出的数据类型与所用格式说明符不一致

20、。例如,a已定义为整型,b定义为实型a=3;b=4.5;prin tf("%f%d n",a,b);编译时不给出出错信息,但运行结果将与原意不符。这种错误尤其需要注意。11. 输入数据时,企图规定精度。scanf("%7.2f",&a);这样做是不合法的,输入数据时不能规定精度。12. switch 语句中漏写 break 语句。例如:根据考试成绩的等级打印出百分制数段。switch(grade) case A :printf("85100n");(不知道为什么这里的反斜线打不出来! )case B :printf("

21、;7084n");(不知道为什么这里的反斜线打不出来! )case C :printf("6069n");(不知道为什么这里的反斜线打不出来! )case D :printf("<60n");(不知道为什么这里的反斜线打不出来! )default:printf("errorn"); (不知道为什么这里的反斜线打不出来! ) 由于漏写了 break 语句, case 只起标号的作用,而不起判断作用。因此,当 grade 值为A 时, printf 函数在执行完第一个语句后接着执行第二、三、四、五个 printf 函数语句

22、。 正确写法应在每个分支后再加上“ break; 。例如case A :printf("85100n");break;(不知道为什么这里的反斜线打不出来! )13. 无视了 while 和 do-while 语句在细节上的区别。(1)main()int a=0,I;scanf("%d",&I);while(I<=10)a=a+I;I+;printf("%d",a);(2)main()int a=0,I;scanf("%d",&I);doa=a+I;I+;while(I<=10);prin

23、tf("%d",a);可以看到,当输入 I 的值小于或等于 10 时,二者得到的结果相同。而当 I>10 时,二者 结果就不同了。因为 while 循环是先判断后执行,而 do-while 循环是先执行后判断。对 于大于 10 的数 while 循环一次也不执行循环体,而 do-while 语句那么要执行一次循环体。14. 定义数组时误用变量。int n;scanf("%d",&n);int an;数组名后用方括号括起来的是常量表达式,可以包括常量和符号常量。即 C 不允许对数 组的大小作动态定义。15. 在定义数组时,将定义的“元素个数误

24、认为是可使的最大下标值。main()static int a10=1,2,3,4,5,6,7,8,9,10;printf("%d",a10);C 语言规定:定义时用 a10 ,表示 a 数组有 10 个元素。其下标值由 0 开始,所以数组 元素 a10 是不存在的。16. 初始化数组时,未使用静态存储。int a3=0,1,2;这样初始化数组是不对的。 C 语言规定只有静态存储 (static) 数组和外部存储 (exterm) 数组才能初始化。应改为: static int a3=0,1,2;17. 在不应加地址运算符 &的位置加了地址运算符。scanf(&quo

25、t;%s",&str);C语言编译系统对数组名的处理是:数组名代表该数组的起始地址,且seanf函数中的输入项是字符数组名,不必要再加地址符 &。应改为: seanf("%s",str);18. 同时定义了形参和函数中的局部变量。int max(x,y)int x,y,z;z=x>y?x:y;return(z); 形参应该在函数体外定义,而局部变量应该在函数体内定义。应改为: int max(x,y)int x,y;int z;z=x>y?x:y;return(z);附: Turbo C(V2.0) 编译错误信息说明: Turbo C

26、的来源程序错误分为三种类型:致命错误、一般错误和警告。其中, 致命错误通常是内部编译发生错误;一般错误指程序的语法错误、磁盘或内存存取错误或 指令行错误等;警告那么只是指出一些得疑心的情况,它并不防止编译的进行。下面按字母顺序AZ分别列出致命错误及一般错误讯息,英汉对照及处理方法:(一) 、致命错误英汉对照及处理方法:A-B致命错误Bad eall of in-line funetion (内部函数非法调用 )分析与处理:在使用一个宏定义的内部函数时,没能正确调用。一个内部函数以两个加底 线(_) 开始和结束。Irreducable expression tree 不可约表达式树 分析与处理:

27、这种错误指的是档案行中的表达式太复杂,使得编码产生程序无法为它产生 编码。这种表达式必须防止使用。Register allocation failure 内存分配失败 分析与处理: 这种错误指的是档案行中的表达式太复杂, 编码产生程序无法为它产生编码 此时应简化这种繁杂的表达式或干脆防止使用它。二 、一般错误讯息英汉照及处理方法#operator not followed by maco argument name#运算符后没跟宏变元名 分析与处理:在宏定义中, #用于标示一宏变串。 "#" 号后必须跟一个宏变元名。 'xxxxxx' not anargum

28、ent 'xxxxxx'不是函数参数 分析与处理: 在源程序中将该标示符定义为一个函数参数, 但此标示符没有在函数中出现 Ambiguous symbol 'xxxxxx' 二义性符号 'xxxxxx' 分析与处理:两个或多个结构的某一域名相同,但具有的偏移、类型不同。在变量或表达 式中引用该域而未带结构名时,会产生二义性,此时需修改某个域名或在引用时加上结构 名。Argument # missing name 参数#名遗失 分析与处理:参数名已脱离用于定义函数的函数原型。如果函数以原型定义,该函数必须 包含所有的参数名。Argument lis

29、t syntax error 参数表出现语法错误 分析与处理:函数调用的参数间必须以逗号隔开,并以一个右括号结束。假设原始档中含有 一个其后不是逗号也不是右括号的参数,那么发生错误。Array bounds missing 数组的界限符 "" 遗失 分析与处理:在原始档中定义了一个数组,但此数组没有以下右方括号结束。Array size too large 数组太大 分析与处理:定义的数组太大,超过了可用内存空间。分析与处理:内部汇编语句最长不能超过 480 位分析与处理:TURBOC.CFG定文件中包含的不是适宜指令行选择项的非批注文字。设定文件指令选择项必须以一个短横线

30、开始。Bad file name format in include directive包含指令中文件名称格式不正确 分析与处理:包含文件名称必须用引号 "filename.h" 或尖括号 filename 括起来,否 那么将产生本类错误。 如果使用了宏, 那么产生的延伸文字也不正确, 因为无引号没方法识别。Bad ifdef directive syntax ifdef指令语法错误 分析与处理: #ifdef 必须以单个标示符 只此一个 作为该指令的体。Bad ifndef directive syntax ifndef指令语法错误 分析与处理: #ifndef 必须以单

31、个标示符 只此一个 作为该指令的体。Bad undef directive syntax undef 指令语法错误 分析与处理: #undef 指令必须以单个标示符 只此一个 作为该指令的体。Bad file size syntax 位字段长语法错误 分析与处理:一个位字段长必须是 1-16 位的常量表达式。Call of non-functin 调用未定义函数 分析与处理: 正被调用的函数无定义, 通常是由于不正确的函数声明或函数名拼错而造成。Cannot modify a const object 不能修改一个长量对像 分析与处理:对定义为常量的对象进行不合法操作 如常量配置 引起本错误。

32、Case outside of switch Case 出现在 switch 外分析与处理:编译程序发现 Case语句出现在switch语句之外,这类故障通常是由于括号 不符合造成的。Case statement missing Case 语句漏掉 分析与处理:Case语必须包含一个以冒号结束的常量表达式,如果漏了冒号或在冒号前多了其它符号,那么会出现此类错误。分析与处理:字符常量的长度通常只能是一个或两个字符长,超过此长度那么会出现这种错 误。Compound statement missing 漏掉复合语句 分析与处理:编译程序扫瞄到原始文件未时,未发现结束符号 大括号 ,此类故障通常 是

33、由于大括号不符合所致。Conflicting type modifiers 类型修饰符冲突 分析与处理:对同一指针,只能指定一种变址修饰符 如 near 或 far ;而对于同一函数, 也只能给出一种语言修饰符 如 Cdecl 、pascal 或 interrupt 。Constant expression required 需要常量表达式 分析与处理:数组的大小必须是常量,本错误通常是由于 #define 常量的拼写错误引起。 Could not find file 'xxxxxx.xxx' 找不到 'xxxxxx.xx' 档案 分析与处理:编译程序找不到指令

34、行上给出的档案。Declaration missing 漏掉了说明 分析与处理:当原始档中包含了一个 struct 或 union 域声明,而后面漏掉了分号,那么会 出现此类错误。Declaration needs type or storage class说明必须给出类型或储存类 分析与处理:正确的变量说明必须指出变量类型,否那么会出现此类错误。Declaration syntax error 说明出现语法错误 分析与处理:在原始档中,假设某个说明遗失了某些符号或输入多余的符号,那么会出现此类 错误。Default outside of switch Default 语句在 switch 语

35、句外出现 分析与处理:这类错误通常是由于括号不符合引起的。Define directive needs an identifier Define指令必须有一个标示符 分析与处理: #define 后面的第一个非空格符必须是一个标示符, 假设该位置出现其它字符, 那么会引起此类错误。Division by zero 除数为零 分析与处理:当原始档的常量表达式出现除数为零的情况,那么会造成此类错误Do statement must have while do 语句中必须有 While 关键词 分析与处理:假设原始文件中包含了一个无 While 关键词的 do 语句,那么出现本错误。DO while

36、 statement missing Do while 语句中漏掉了符号 "" 分析与处理:在 do 语句中,假设 while 关键词后无左括号,那么出现本错误。Do while statement missing;Do while 语句中掉了分号 分析与处理:在DO语句的条件表达式中,假设右括号后面无分号那么出现此类错误。Duplicate Case Case 情况不唯一 分析与处理: Switch 语句的每个 case 必须有一个唯一的常量表达式值。否那么导致此类错 误发生。Enum syntax error Enum 语法错误 分析与处理:假设enum说明的标示符表格

37、式不对,将会引起此类错误发生。Enumeration constant syntax error 枚举常量语法错误 分析与处理:假设赋给enum类型变量的表达式值不为常量,那么会导致此类错误发生。Error Directive : xxxx Error指令: xxxx分析与处理:原始文件处理 #error 指令时,显示该指令指出的讯息。Error Writing output file 写输出档案错误 分析与处理:这类错误通常是由于磁盘空间已满,无法进行写入操作而造成。Expression syntax error 表达式语法错误 分析与处理:本错误通常是由于出现两个连续的操作符,括号不符合或

38、缺少括号、前一语 句漏掉了分号引起的。Extra parameter in call 调用时出现多余参数 分析与处理: 本错误是由于调用函数时, 其实际参数个数多于函数定义中的参数个数所致。Extra parameter in call to xxxxxx调用 xxxxxxxx 函数时出现了多余参数 分析与处理: #include 指令给出的文件名称太长,致使编译程序无法处理,那么会出现此类 错误。通常DOS下的文件名称长度不能超过64个字符。For statement missing ) (For 语名缺少 ")")分析与处理:在 for 语句中,如果控制表达式后缺少右括

39、号,那么会出现此类错误For statement missing( (For语句缺少 "(")For statement missing; (For语句缺少 " ;")分析与处理:在 for 语句中,当某个表达式后缺少分号,那么会出现此类错误。Function call missing) (函数调用缺少 ")")分析与处理:如果函数调用的参数表漏掉了右手括号或括号不符合,那么会出现此类错误。Function definition out ofplace (函数定义位置错误 )Function doesn't take a va

40、riable number of argument(函数不接受可变的参数个数 )Goto statement missing label (Goto 语句缺少标号 )If statement missing( (If语句缺少 "(")If statement missing) (If语句缺少 ")")lllegal initalization (非法初始化 )lllegal octal digit ( 非法八进制数 )分析与处理:此类错误通常是由于八进制常数中包含了非八进制数字所致lllegal pointer subtraction (非法指针相减 )

41、lllegal structure operation (非法结构操作 )lllegal use of floating point (浮点运算非法 )lllegal use of pointer ( 指针使用非法 )Improper use of a typedef symbol (typedef符号使用不当 )Incompatible storage class (不兼容的储存类型 )Incompatible type conversion ( 不兼容的类型转换 )Incorrect commadn line argument:xxxxxx 不正确的指令行参数: xxxxxxxIncorr

42、ect commadn file argument:xxxxxx 不正确的设定档参数: xxxxxxxIncorrect number format 不正确的资料格式 Incorrect use of default deflult不正确使用 Initializer syntax error 初始化语法错误 Invaild indrection 无效的间接运算 Invalid macro argument separator 无效的宏参数分隔符 Invalid pointer addition 无效的指针相加 Invalid use of dot 点使用错 Macro argument syn

43、tax error 宏参数语法错误 Macro expansion too long 宏延伸太长 Mismatch number of parameters in definition定义中参数个数不符合 Misplaced break break 位置错误 Misplaced continue 位置错 Misplaced decimal point 十进制小数点位置错 Misplaced else else位置错 Misplaced else driective clse指令位置错 Misplaced endif directive endif指令位置错 Must be addressabl

44、e 必须是可编址的 Must take address of memory location 必须是内存一地址 No file name ending 无档案终止符 No file names given 未给出文件名称 Non-protable pointer assignment 对不可移植的指针配置 Non-protable pointer comparison 不可移植的指针比拟 Non-protable return type conversion Not an allowed type 不允许的类型 Out of memory 内存不够 Pointer required on le

45、ft side of Redeclaration of 'xxxxxx' 'xxxxxx'Size of structure or array not known 不可移植的返回类型转换 )操作符左边须是一指针 )重定义) 结构或数组大小不定 )Structure or union syntax error Structure size too large 结构或联合语法错误 )结构太大 )Statement missing ; 语句缺少 " ;"Subscription missing 下标缺少 ''Switch state

46、ment missing switch 语句缺少 ""Switch statement missing switch 语句缺少 ""Too few parameters in call 函数调用参数太少 Too few parameter in call to'xxxxxx'调用 'xxxxxx' 时参数太少 Too many cases Cases 太多 Too many decimal points 十进制小数点太多 Too many default cases defaut太多 Too many exponents 阶码太多 Too many initializers 初始化太多 Too many storage classes in declaration 说明中储存类太多 Too

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论