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

下载本文档

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

文档简介

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,实际上却是将计数器i

4、 的值设置为 0,这就陷入了死循环。这是程序设计中较常见也较难觉察的一类错误,被称为“差一错误”(off-by-oneerror )。“差一错误” 也称“栏杆错误”,问题说的是: 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 条件当然满足,从而形成

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

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

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

11、、 int和 long int,但不管是哪种类型表示的整数总有一定的范围,越出该范围时称为整数的溢出。例如现有算法要求如下:求满足条件 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

12、 后便得到一个负数, 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 语言的人来说,经常会出一些连自己都不知道错在哪里的错误。看着有错的程序,不知该如何改起,本人

14、通过对 C 的学习,积累了一些 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 可以进行求余运算,而实型变量则不允许进行“

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

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

17、=x+y; t=z/100; printf("%f",t);复合语句的花括号后不应再加分号,否则将会画蛇添足。又如: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+);scanf("%d",&x);printf("%d",x);本意是先后输入 5 个数,每输入一个数后再将它输出。由于 for() 后多加了一个分号,使循环体变为空语句

18、,此时只能输入一个数并输出它。7. 输入变量时忘记加地址运算符“ &”。 int a,b;scanf("%d%d",a,b);这是不合法的。 Scanf 函数的作用是: 按照 a、b 在内存的地址将 a、b 的值存进去。“&a”指 a 在内存中的地址。8. 输入数据的方式与要求不符。 scanf("%d%d",&a,&b);输入时,不能用逗号作两个数据间的分隔符,如下面输入不合法:3 ,4输入数据时,在两个数据之间以一个或多个空格间隔,也可用回车键,跳格键tab 。 scanf("%d,%d",&

19、;a,&b);C 规定:如果在“格式控制”字符串中除了格式说明以外还有其它字符,则在输入数据时应输入与这些字符相同的字符。下面输入是合法的:3 ,4此时不用逗号而用空格或其它字符是不对的。343:4又如:scanf("a=%d,b=%d",&a,&b);输入应如以下形式:a=3,b=49. 输入字符的格式与要求不一致。在用“ %c”格式输入字符时, “空格字符”和“转义字符”都作为有效字符输入。scanf("%c%c%c",&c1,&c2,&c3);如输入 a b c字符“ a”送给 c1,字符“ ”送给

20、c2,字符“ b”送给 c3,因为 %c只要求读入一个字符,后面不需要用空格作为两个字符的间隔。10. 输入输出的数据类型与所用格式说明符不一致。例如, a 已定义为整型, b 定义为实型a=3;b=4.5;printf("%f%dn",a,b);编译时不给出出错信息,但运行结果将与原意不符。这种错误尤其需要注意。11. 输入数据时,企图规定精度。scanf("%7.2f",&a);这样做是不合法的,输入数据时不能规定精度。12.switch语句中漏写 break 语句。例如:根据考试成绩的等级打印出百分制数段。switch(grade) cas

21、e A :printf("85100n");(不知道为什么这里的反斜线打不出来! )case B:printf("7084n");(不知道为什么这里的反斜线打不出来! )case C:printf("6069n");(不知道为什么这里的反斜线打不出来! )case D:printf("<60n");(不知道为什么这里的反斜线打不出来! )default:printf("errorn");(不知道为什么这里的反斜线打不出来! )由于漏写了 break 语句, case 只起标号的作用,而不起

22、判断作用。 因此,当 grade 值为A 时,printf 函数在执行完第一个语句后接着执行第二、 三、四、五个 printf 函数语句。正确写法应在每个分支后再加上“ 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

23、a=0,I;scanf("%d",&I);doa=a+I;I+;while(I<=10);printf("%d",a);可以看到,当输入 I 的值小于或等于 10 时,二者得到的结果相同。而当 I>10 时,二者结果就不同了。因为 while 循环是先判断后执行,而 do-while 循环是先执行后判断。对于大于 10 的数 while 循环一次也不执行循环体, 而 do-while 语句则要执行一次循环体。14. 定义数组时误用变量。int n;scanf("%d",&n);int an;数组名后用方括号

24、括起来的是常量表达式,可以包括常量和符号常量。即 C不允许对数组的大小作动态定义。15. 在定义数组时,将定义的“元素个数”误认为是可使的最大下标值。 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)数组才能初始化。应改为:

25、static int a3=0,1,2;17. 在不应加地址运算符 &的位置加了地址运算符。scanf("%s",&str);C 语言编译系统对数组名的处理是:数组名代表该数组的起始地址,且scanf 函数中的输入项是字符数组名,不必要再加地址符&。应改为:scanf("%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;

26、z=x>y?x:y;return(z);附: Turbo C(V2.0)编译错误信息说明: Turbo C 的来源程序错误分为三种类型:致命错误、一般错误和警告。其中,致命错误通常是内部编译发生错误;一般错误指程序的语法错误、磁盘或内存存取错误或指令行错误等;警告则只是指出一些得怀疑的情况,它并不防止编译的进行。下面按字母顺序AZ 分别列出致命错误及一般错误讯息,英汉对照及处理方法:( 一) 、致命错误英汉对照及处理方法:致命错误Bad call of in-line function (内部函数非法调用 )分析与处理:在使用一个宏定义的内部函数时,没能正确调用。一个内部函数以两个加底线

27、 (_) 开始和结束。Irreducable expression tree (不可约表达式树 )分析与处理:这种错误指的是档案行中的表达式太复杂,使得编码产生程序无法为它产生编码。这种表达式必须避免使用。Register allocation failure (内存分配失败 )分析与处理:这种错误指的是档案行中的表达式太复杂,编码产生程序无法为它产生编码。此时应简化这种繁杂的表达式或干脆避免使用它。( 二) 、一般错误讯息英汉照及处理方法#operator not followed by maco argument name(#运算符后没跟宏变元名)分析与处理:在宏定义中,#用于标示一宏变串

28、。 "#" 号后必须跟一个宏变元名。'xxxxxx' not anargument ('xxxxxx'不是函数参数 )分析与处理:在源程序中将该标示符定义为一个函数参数,但此标示符没有在函数中出现。Ambiguous symbol 'xxxxxx' (二义性符号 'xxxxxx')分析与处理:两个或多个结构的某一域名相同,但具有的偏移、类型不同。在变量或表达式中引用该域而未带结构名时,会产生二义性,此时需修改某个域名或在引用时加上结构名。Argument # missing name (参数 #名遗失 )分析与

29、处理:参数名已脱离用于定义函数的函数原型。如果函数以原型定义,该函数必须包含所有的参数名。Argument list syntax error (参数表出现语法错误 )分析与处理:函数调用的参数间必须以逗号隔开,并以一个右括号结束。若原始档中含有一个其后不是逗号也不是右括号的参数,则发生错误。Array bounds missing (数组的界限符 "" 遗失 )分析与处理:在原始档中定义了一个数组,但此数组没有以下右方括号结束。Array size too large (数组太大 )分析与处理:定义的数组太大,超过了可用内存空间。Assembler statement t

30、oo long (汇编语句太长 )分析与处理:内部汇编语句最长不能超过480 位。Bad configuration file (设定档不正确 )分析与处理: TURBOC.CFG设定文件中包含的不是合适指令行选择项的非批注文字。设定文件指令选择项必须以一个短横线开始。Bad file name format in include directive(包含指令中文件名称格式不正确)分析与处理:包含文件名称必须用引号 ("filename.h") 或尖括号 (<filename>) 括起来,否则将产生本类错误。如果使用了宏,则产生的延伸文字也不正确,因为无引号没办

31、法识别。Bad ifdef directive syntax (ifdef指令语法错误)分析与处理: #ifdef必须以单个标示符 ( 只此一个 ) 作为该指令的体。Bad ifndef directive syntax (ifndef指令语法错误 )分析与处理: #ifndef必须以单个标示符 ( 只此一个 ) 作为该指令的体。Bad undef directive syntax (undef指令语法错误 )分析与处理: #undef 指令必须以单个标示符( 只此一个 ) 作为该指令的体。Bad file size syntax (位字段长语法错误 )分析与处理:一个位字段长必须是1-16

32、位的常量表达式。Call of non-functin (调用未定义函数 )分析与处理:正被调用的函数无定义,通常是由于不正确的函数声明或函数名拼错而造成。Cannot modify a const object (不能修改一个长量对像 )分析与处理:对定义为常量的对象进行不合法操作( 如常量配置 ) 引起本错误。Case outside of switch (Case出现在 switch 外)分析与处理:编译程序发现 Case语句出现在 switch 语句之外,这类故障通常是由于括号不符合造成的。Case statement missing (Case语句漏掉 )分析与处理: Case 语必

33、须包含一个以冒号结束的常量表达式,如果漏了冒号或在冒号前多了其它符号,则会出现此类错误。Character constant too long (字符常量太长 )分析与处理:字符常量的长度通常只能是一个或两个字符长,超过此长度则会出现这种错误。Compound statement missing (漏掉复合语句 )分析与处理:编译程序扫瞄到原始文件未时,未发现结束符号 ( 大括号 ) ,此类故障通常是由于大括号不符合所致。Conflicting type modifiers (类型修饰符冲突 )分析与处理:对同一指针,只能指定一种变址修饰符 ( 如 near 或 far) ;而对于同一函数,也

34、只能给出一种语言修饰符 ( 如 Cdecl 、pascal 或 interrupt) 。Constant expression required (需要常量表达式 )分析与处理:数组的大小必须是常量,本错误通常是由于#define常量的拼写错误引起。Could not find file 'xxxxxx.xxx' (找不到 'xxxxxx.xx'档案 )分析与处理:编译程序找不到指令行上给出的档案。Declaration missing (漏掉了说明 )分析与处理: 当原始档中包含了一个 struct 或 union 域声明,而后面漏掉了分号, 则会出现此类错误

35、。Declaration needs type or storage class(说明必须给出类型或储存类)分析与处理:正确的变量说明必须指出变量类型,否则会出现此类错误。Declaration syntax error (说明出现语法错误 )分析与处理:在原始档中,若某个说明遗失了某些符号或输入多余的符号,则会出现此类错误。Default outside of switch (Default语句在 switch 语句外出现 )分析与处理:这类错误通常是由于括号不符合引起的。Define directive needs an identifier (Define指令必须有一个标示符)分析与处理

36、: #define 后面的第一个非空格符必须是一个标示符,若该位置出现其它字符,则会引起此类错误。Division by zero (除数为零 )分析与处理:当原始档的常量表达式出现除数为零的情况,则会造成此类错误。Do statement must have while (do语句中必须有 While 关键词 )分析与处理:若原始文件中包含了一个无While 关键词的 do 语句,则出现本错误。DO while statement missing ( (Do while语句中漏掉了符号"(")分析与处理:在do 语句中,若 while关键词后无左括号,则出现本错误。Do

37、while statement missing; (Do while语句中掉了分号 )分析与处理:在DO语句的条件表达式中,若右括号后面无分号则出现此类错误。Duplicate Case (Case情况不唯一 )分析与处理: Switch 语句的每个 case 必须有一个唯一的常量表达式值。 否则导致此类错误发生。Enum syntax error (Enum语法错误 )分析与处理:若enum说明的标示符表格式不对,将会引起此类错误发生。Enumeration constant syntax error (枚举常量语法错误 )分析与处理:若赋给enum类型变量的表达式值不为常量,则会导致此类错

38、误发生。Error Directive : xxxx (Error指令: xxxx)分析与处理:原始文件处理#error指令时,显示该指令指出的讯息。Error Writing output file (写输出档案错误 )分析与处理:这类错误通常是由于磁盘空间已满,无法进行写入操作而造成。Expression syntax error (表达式语法错误 )分析与处理:本错误通常是由于出现两个连续的操作符,括号不符合或缺少括号、前一语句漏掉了分号引起的。Extra parameter in call (调用时出现多余参数 )分析与处理:本错误是由于调用函数时,其实际参数个数多于函数定义中的参数个

39、数所致。Extra parameter in call to xxxxxx(调用 xxxxxxxx 函数时出现了多余参数 )File name too long (文件名称太长 )分析与处理: #include 指令给出的文件名称太长,致使编译程序无法处理,则会出现此类错误。通常 DOS下的文件名称长度不能超过 64 个字符。For statement missing ) (For语名缺少 ")")分析与处理:在for语句中,如果控制表达式后缺少右括号,则会出现此类错误。For statement missing( (For语句缺少 "(")For st

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

41、l (Goto语句缺少标号 )If statement missing( (If语句缺少 "(")If statement missing) (If语句缺少 ")")lllegal initalization (非法初始化 )lllegal octal digit (非法八进制数 )分析与处理:此类错误通常是由于八进制常数中包含了非八进制数字所致。lllegal pointer subtraction (非法指针相减 )lllegal structure operation (非法结构操作 )lllegal use of floating point (

42、浮点运算非法 )lllegal use of pointer (指针使用非法 )Improper use of a typedef symbol (typedef符号使用不当 )Incompatible storage class (不兼容的储存类型 )Incompatible type conversion (不兼容的类型转换 )Incorrect commadn line argument:xxxxxx (不正确的指令行参数: xxxxxxx)Incorrect commadn file argument:xxxxxx (不正确的设定档参数: xxxxxxx)Incorrect numbe

43、r format (不正确的资料格式 )Incorrect use of default (deflult不正确使用 )Initializer syntax error (初始化语法错误 )Invaild indrection (无效的间接运算 )Invalid macro argument separator (无效的宏参数分隔符 )Invalid pointer addition (无效的指针相加 )Invalid use of dot (点使用错 )Macro argument syntax error (宏参数语法错误 )Macro expansion too long (宏延伸太长

44、)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 addressable (必须是可编址的 )Must take address of me

45、mory 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 left s

46、ide of (操作符左边须是一指针 )Redeclaration of 'xxxxxx' ('xxxxxx'重定义 )Size of structure or array not known (结构或数组大小不定 )Statement missing ; ( 语句缺少 " ;")Structure or union syntax error (结构或联合语法错误 )Structure size too large (结构太大 )Subscription missing (下标缺少 '')Switch statement mi

47、ssing ( (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 many types in decleration (说明中类型太多 )Too much auto memory in function (函数中自动储存太多 )Too m

温馨提示

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

评论

0/150

提交评论