当前位置:文档之家› 常见编译错误及常用标准库函数

常见编译错误及常用标准库函数

常见编译错误及常用标准库函数
常见编译错误及常用标准库函数

附录 A 常见编译错误和警告

1. fatal error C1010: unexpected end of file while looking for precompiled header directive 寻找预编

译头文件路径时遇到了不该遇到的文件尾。

(一般是因为误删了包含命令#include "stdafx.h")

2. fatal error C1083: Cannot open include file: '***.h': No such file or directory 不能打开包含文件

'***.h': 没有这样的文件或目录

3. error C2018: unknown character '0xa3'

不认识的字符’0xa3'(—般是代码中出现了汉字或中文标点符号)

4. error C2039: '****' : is not a member of '####'

'****' 不是'####' 结构体的一个成员(一般是因为错误引用结构体成员)

5. error C2057: expected constant expression 期望是常量表达式(一般出现在switch 语句的case

分支中)

6. error C2061: syntax error : identifier '***'

语法错误: 标识符 '*** '(一般是因为未定义形式参数的数据类型)

7. error C2065: '****' : undeclared identifier

'****': 未声明过的标识符

8. error C2082: redefinition of formal parameter '****' 重复定义形式参数'****'

9. error C2133: '****' : unknown size

'****' : 不知道其大小(一般是因为数组未定义长度)

10. error C2143: syntax error: missing ';' before '{' 句法错误:'{' 前缺少';'

11. error C2146: syntax error : missing ';' before identifier '****' 句法错误:在'****' 前缺少';'

12. error C2181: illegal else without matching if

非法的else,没有与之匹配的if(一般是因为if与else不配对)

13. error C2196: case value '****' already used

case值'****'已经使用过(一般出现在switch语句的case分支中)

14. error C2296: '%' : illegal, left operand has type 'float'

'%':非法,左操作数应为’float'类型

15. error C2297: '%' : illegal, right operand has type 'float'

'%':非法,右操作数应为'float'类型

16. error C2562: '****' : 'void' function returning a value

'****': 无返回值的函数返回了一个值

17. error C2660: '****' : function does not take 2 parameters

'****' 函数不能传递2 个参数

18. error C2466: cannot allocate an array of constant size 0

不能分配一个大小为0 的数组(一般是因为数组未定义长度)

19. error C4716: '****' : must return a value

'****' 函数必须返回一个值(一般是定义返回值的函数体内未写return 语句)

20. warning C4035: '****': no return value

'****' 函数没有返回值

21. warning C4244:'return':conversion from 'float' to 'int',possible loss of data

'return':从'float'转换为’int',可能丢失数据

22. warning C4553: '= =' : operator has no effect; did you intend '='? 没有效果的运算符“= =”是;

否改为“=”?

23. warning C4700: local variable '****' used without having been initialized 局部变量'****' 没有初始

化就使用

24. error C4716: '****' : must return a value

'****' 函数必须返回一个值

25. LINK : fatal error LNK1168: cannot open Debug/P1.exe for writing

连接错误:不能打开P1.exe文件,以改写内容

(一般是因为P1.Exe 还在运行,未关闭)

附录 B 常用标准库函数

一. stdio.h 中包括的常用函数

1. fclose 关闭文件

原型:int fclose(FILE *stream);

功能:关闭由stream指向的流。清洗保留在流缓冲区内的任何未写的输出。如果是自动分配,那么就释放缓冲区。

返回:如果成功,就返回零。如果检测到错误,就返回EOF。

2. feof 检测文件末尾

原型:int feof(FILE *stream);

返回:如果为stream指向的流设置了文件尾指示器,则返回非零值;否则返回零。

3. ferror 检测文件错误

原型:int ferror(FILE *stream);

返回:如果为stream指向的流设置了文件错误指示器,则返回非零值;否则返回零。

4. fflush 清洗文件缓冲区

原型:int fflush(FILE *stream);

功能:把任何未写入的数据写到和stream相关的缓冲区中,其中stream指向用于输出或更新

的已打开的流。如果stream是空指针,那么flush函数清洗存储在缓冲区中的所有未写入的流。返回:如果成功就返回零。如果检测到错误,就返回EOF。

5. fgetc 从文件中读取字符

原型:int fgetc(FILE *stream);

功能:从stream指向的流中读取字符。

返回:读到的字符。如果fgetc函数遇到流的末尾,则设置流的文件尾指示器并且返回EOF。如果读取发生错误,fgetc函数设置流的错误指示器并且返回EOF。

6. fgetpos 获得文件位置

原型:int fgetpos(FILE *stream, fpos_t *pos);

功能:把stream指向的流的当前位置存储到pos指向的对象中。

返回:如果成功就返回零。如果调用失败,则返回非零值,并且把由实现定义的错误码存储

到errno 中。

7. fgets 从文件中读取字符串

原型:char *fgets(char *s, int n, FILE *stream);

功能:从stream指向的流中读取字符,并且把读入的字符存储到s指向的数组中。遇到第一

个换行符已经读取了n-1个字符,或到了文件末尾时,读取操作都会停止。fgets函数会在字

符串后添加一个空字符。

返回:s (指向数组的指针),如果读取操作错误或fgets函数在存储任何字符之前遇到了流

的末尾,都会返回空指针。

8. fopen 打开文件

原型:FILE *fopen(const char *filename, const char *mode);

功能:打开文件以及和它相关的流,文件名是由file name指向的。mode说明文件打开的方式。返回:文件指针。在执行下一次关于文件的操作时会用到此指针。如果无法打开文件则返回空指针。

9. fprintf 格式化写文件

原型:int fprintf(FILE *stream, const char *format, ...);

功能:向stream指旨向的流写输出。format指向的字符串说明了后续参数显示的格式。返回:写入的字符数量。如果发生错误就返回负值。

10. fputc 向文件写字符

原型:int fputc(int c, FILE *stream);

功能:把字符c写到stream指向的流中。

返回:c (写入的字符),如果写发生错误,fputc函数会为stream设置错误指示器,并且返

回EOF 。

11. fputs 向文件写字符串

原型:int fputs(const char *s, FILE *stream);

功能:把s扌旨向的字符串写到stream指向的流中。返回:如果成功,返回非负值。如果写发生错误,则返回EOF。

12. fread 从文件读块

原型:size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);

功能:试着从stream 指向的流中读取nmemb 个元素,每个元素大小为size 个字节,并且把读入的元素存储到ptr 指向的数组中。

返回:实际读入的元素(不是字符)数量。如果fread 遇到文件末尾或检测到读取错误,那么此数将会小于nmemb。如果nmemb或size为零,则返回值为零。

13. freopen 重新打开文件

原型:FILE *freopen(const char *filename, const char *mode, FILE *stream);

功能:在freopen 函数关闭和stream 相关的文件后,打开名为filename 且与stream 相关的文件。Mode 参数具有和fopen 函数调用中相同的含义。

返回:如果操作成功,返回stream 的值。如果无法打开文件则返回空指针。

14. fscanf 格式化读文件

原型:int fscanf(FILE *stream, const char *format, ...);

功能:向stream指向的流读入任意数量的数据项。format指向的字符串说明了读入项的格式。

跟在format后边的参数指向数据项存储的位置。

返回:成功读入并且存储的数据项数量。如果发生错误或在可以读数据项前到达了文件末尾,那么就返回EOF。

15. fseek 文件查找

原型:int fseek(FILE *stream, long int offset, int whence);

功能:为stream指旨向的流改变文件位置指示器。如果whenee是SEEK_SET,那么新位置是在

文件开始处加上offset个字节。如果whenee是SEEK_CUR,那么新位置是在当前位置加上offset个字节。如果whenee是SEEK_END,那么新位置是在文件末尾加上offset个字节。对于

文本流而言,offset必须是零,或者whenee必须是SEEK_SET并且offset的值是由前一次的ftell 函数调用获得的。而对于二进制流来说,fseek函数不可以支持whenee是SEEK_END的调用。返回:如果操作成功就返回零。否则返回非零值。

16. fsetpos 设置文件位置

原型:int fsetpos(FILE *stream, eonst fpos_t *pos);

功能:根据pos (前一次fgetpos函数调用获得的) 指向的值来为stream指向的流设置文件位置返回:如果成功就返回零。如果调用失败,返回非零值,并且把由实现定义的错误码存储在errno 中。

17. ftell 确定文件位置

原型:long int ftell(FILE *stream);

返回:返回stream旨向的流的当前文件位置指示器。如果调用失败,返回-1L,并且把由实

现定义的错误码存储在errno中。

18. fwrite 向文件写块

原型:size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);

功能:从ptr指向的数组中写nmemb个元素到stream指向的流中,且每个元素大小为size个字节。

返回:实际写入的元素(不是字符)的数量。如果fwrite函数检测到写错误,则这个数将会

小于nmemb。

19. getchar 读入字符

原型:int getchar(void);

功能:从stdin流中读入一个字符。注意:getchar函数通常是作为宏来实现的。

返回:读入的字符。如果读取发生错误,则返回EOF。

20. gets 读入字符串

原型:char *gets(char *s);

功能:从stdin流中读入多个字符,并把这些读入的字符存储到s指向的数组中。

返回:s (即存储输入的数组的指针) 。如果读取发生错误或gets函数在存储任何字符之前遇

到流的末尾,那么返回空指针。

21. printf 格式化写

原型:int printf(const char *format, ...);

功能:向stdout流写输出。format指向的字符串说明了后续参数显示的格式。返回:写入数据的数量。如果发生错误就返回负值。

22. putchar 写字符

原型:int putchar(int c);

功能:把字符c写到stdout流中。注意:putchar函数通常作为宏来实现的。

返回:c(写入的字符)。如果写发生错误,putchar函数设置流的错误指示器,并且返回EOF。

23. puts 写字符串

原型:int puts(const char *s);

功能:把s扌旨向的字符串写到strout流中,然后写一个换行符。返回:如果成功返回非负值。如果写发生错误则返回EOF。

24. remove 移除文件

原型:int remove(const char *filename);

功能:删除文件,此文件名由file name指向。

返回:如果成功就返回零;否则返回非零值。

25. rename 重命名文件

原型:int rename(const char *old, const char *new);

功能:改变文件的名字。old和new指向的字符串分别包含旧文件名和新文件名。

返回:如果改名成功就返回零。如果操作失败,就返回非零值 (可能因为旧文件目前是打开的)。

26. rewind 返回到文件头

原型:void rewind(FILE *stream);

功能:为stream指向的流设置文件位置指示器到文件的开始处。为流清除错误指示器和文件

尾指示器。

27. scanf 格式化读

原型:int scanf(const char *format, ...);

功能:从stdin流读取任意数量数据项。format指向的字符串说明了读入项的格式。跟随在format后边的参数指向数据项要存储的地方。

返回:成功读入并且存储的数据项数量。如果发生错误或在可以读入任意数据项之前到达了文件末尾,就返回EOF。

28. sprintf 格式串写

原型:int sprintf(char *s, const char *format, ...);

功能:与fprintf函数和printf函数很类似,但是sprintf函数不是把字符写入流,而是把字符存储到s 指向的数组中。format指向的字符串说明了后续参数显示的格式,在输出的末尾存储一个空字符到数组中。

返回:存储到数组中的字符数量,不计空字符。

29. sscanf 格式串读

原型:int sscanf(const char *s, const char *format, ...);

功能:与fscanf函数和scanf函数很类似,但是sprintf函数不是从流读取字符,而是从s指向的字符串中读取字符。format指向的字符串说明了读入项的格式。跟随在format后的参数指向

数据项要存储的地方。

返回:成功读入并且存储的数据项数量。如果在可以读入任意数据项之前到达了字符串末尾,就返回EOF。

30. tmpfile 创建临时文件

原型:FILE *tmpfile(void);

功能:创建临时文件,此文件在被关闭或者程序结束时会被自动删除。按照"wb+" 模式打开文件。

返回:文件指针。当执行对此文件的后续操作时候用到此指针。如果无法创建文件,则返回空

31. tmpnam 产生临时文件名

原型:char *tmpnam(char *s);

功能:产生临时文件名。如果s是空指针,那么tmpnam把文件名存储在静态变量中。否则,

它会把文件名复制到s旨向的字符数组中。(数组必须足够长可以存储L_tmp nam个字符,这

里的L_tmpnam是在<stdio.h>头文件中定义的宏。)

返回:指向文件名的指针。

32. ungetc 未读取的字符

原型:int ungetc(int c, FILE *stream);

功能:把字符c回退到stream指向的流中,并且清除流的文件尾指示器。由连续的ungetc函数调用回退的字符数量有变化。只能保证第一次调用成功。调用文件定位函数( fseek函数、fsetpos函数或者rewind函数)会导致回退的字符丢失。

返回:c (回退的字符)。如果没有读取操作或者文件定位操作就试图回退过多的字符,那么函数将会返回EOF。

二. math.h 中包括的常用函数

1. abs 整数的绝对值

原型:int abs(int j);

返回:整数j 的绝对值。 2. acos 反余弦

原型: double acos(double x);

返回:X 的反余弦值。返回值的范围在 生定义域错误。 3. asin 反正弦

原型: double asin(double x);

返回:x 的反正弦值。返回值的范围在 发生定义域错误。

4. atan 反正切

原型: double atan(double x);

返回:x 的反正切值。返回值的范围在 -n /2到 n /之间。 5. atan2 商的反正切

原型: double atan2(double y, double x); 返回:y/x 的反正切值。返回值的范围在 -冗到n 之间。如果x 和y 的值都为零,那么就会发生定 义域错误。 6. ceil 上整数

原型: double ceil(double x); 返回:大于或等于 x 的最小整数。 7. cos 余弦

原型: double cos(double x); 返回:x 的余弦值(按照弧度衡量的)。 8. cosh 双曲余弦

原型: double cosh(double x);

返回:x 的双曲余弦值。如果 x 的数过大,那么可能会发生取值范围错误。 9. exp 指数

原型: double exp(double x);

返回:e 的x 次幕的值(即e x )。如果x 的数过大,那么可能会发生取值范围错误。 10. fabs 浮点数的绝对值 原型: double fabs(double x); 返回:x 的绝对值。 11. floor 向下取整

原型: double floor(double x); 返回:小于或等于 x 的最大整数。 12. fmod 浮点模数

原型: double fmod(double x, double y);

返回:x 除以y 的余数。如果y 为零,是发生定义域错误还是 fmod 函数返回零是由实现定

义的。

13. frexp 分解成小数和指数

原型: double frexp(double value, int *exp);

功能:按照下列形式把 value 分解成小数部分f 和指数部分n : value = f 药 其中f 是规范化的,因此 0.5

0到n 之间。如果x 的值不在-1到+1之间,那么就会发 -n /到 n /之间。如果x 的值不在-1到+1之间,那么就会

KEIL常见编译错误大全

KEIL常见编译错误大全 【致命错误】 立即终止编译这些错误通常是命令行指定的无效选项的结果当编译器不 能访问一个特定的源包含文件时也产生致命错误 致命错误信息采用下面的格式 C51FATAL-ERROR– ACTION: LINE: ERROR: C51TERMIANTED. C51FATAL-ERROR– ACTION: FILE: ERROR: C51TERMIANTED. 下面说明Action和Error中可能的内容 Actions ALLOCATING MEMORY 编译器不能分配足够的存储区来编译指定的源文件. CREATING LIST-FILE/OBJECT-FILE/WORKFILE 编译器不能建立列表文件,OBJ文件,或工作文件这个错误的出现可能是磁盘满或写保护,或文件已存在和只读. GENERATING INTERMEDIATE CODE 源文件包含的一个函数太大,不能被编译器编译成虚拟代码.尝试把函数分小或重新编译. OPENING INPUT-FILE 编译器不能发现或打开所选的源或包含文件. PARSING INVOKE-/#PRAGMA-LINE 当在命令行检测到参数计算,或在一个#pragma中检测到参数计算,就产生这样的错误. PARSING SOURCE-FILE/ANALYZING DECLARATIONS 源文件包含太多的外部参考.减少源文件访问的外部变量和函数的数目. WRITING TO FILE

C语言编译中的常见错误

C语言编译中的常见错误 1、警告类错误 ?‘XXX’declare but never used变量XXX已定义但从未用过。 ?‘XXX’is assigned a value which is never used变量XXX已赋值但从未用过。?Code has no effect 程序中含有没有实际作用的代码。 ? Non-portable pointer conversion不适当的指针转换,可能是在应该使用指针的 地方用了一个非0的数值。 ?Possib le use of ‘XXX’before definition表达式中使用了未赋值的变量 ?Possibly incorrect assignment这样的赋值可能不正确 ?Redeclaration of ‘main’一个程序文件中主函数main不止一个。 ?Suspicious pointer conversion可疑的指针转换。通常是使用了基本类型不匹配的指针。 ?Unreachable code程序含有不能执行到的代码。 2、错误或致命错误 ?Compound statement missing } in function main程序结尾缺少括号}。 ?“}”expected;“(”expected等复合语句或数组初始化的结尾缺少“)”;“(”。 ? Case outside of switch case不属于Switch结构,多由于switch结构中的花括 号不配对所致。 ?Case statement missing ‘:’ switch结构中的某个case之后缺少冒号。 ? Constant expression required定义数组时指定的数组长度不是常量表达式。 ? Declaration syntax error 结构体或联合类型的定义后缺少分号。 ? Declaration was expected 缺少说明,通常是因为缺少分界符如逗号、分号、右圆 括号等所引起的。 ?Default outside switch Default部分放到了switch结构之外,一般是因为花括号 不匹配而引起的。 ?do statement must have while do语句中缺少相应的while部分。 ? Expression syntax 表达式语法错。如表达式中含有两个连续的运算符

c语言编译常见错误列表

1."c" not an argument in function sum 该标识符不是函数的参数 2.array bounds missing ] in function main 缺少数组界限符"]" 3.Array size too large in function main 数组规模太大 4.bad file name format in include directive 在包含指令中的文件名格式不正确. 5.Call of non-function in function main 调用未经过定义的函数. 6.cannot modify a const object in function main 对常量不能进行修改. 7.character constant too long in function main 字符常量太大 8.constant expression required in funtion main 数组定义的时候,数组大小要求是常数 https://www.doczj.com/doc/5d13368550.html,pound statment missing } in function main 复合语句漏掉符号"{" 10.declaration syntax error in function main 宣告语法错误 11.expression syntax in function main 表达式语法错误 12. extra parameter in call to sum in function 调用函数时使用了过多的参数 13.illegal use of floating point in function main 浮点数的不合法使用 14.illegal pionter subtraction in function main 不合法的指针相减 15.invalid pointer addition in function main 无效的指针相加 16.out of memory in function main 内存不足 17.statement missing ; in function main 语句后面漏掉分号. 警告报错

编译原理56章作业答案

第五章 练习5.1.1: 对于图5-1中的SDD,给出下列表达式对应的注释语法分析树: 1)(3+4)*(5+6)n 练习5.2.4: 这个文法生成了含“小数点”的二进制数: S->L.L|L L->LB|B B->0|1 设计一个L属性的SDD来计算S.val,即输入串的十进制数值。比如,串101.101应该被翻译为十进制的5.625。提示:使用一个继承属性L.side来指明一个二进制位在小数点的哪一边。 答: 元文法消除左递归后可得到文法: S->L.L|L L->BL’ L’->BL’|ε B->0|1 使用继承属性L.side指明一个二进制位数在小数点的哪一边,2表示左边,1表示右边 使用继承属性m记录B的幂次 非终结符号L和L’具有继承属性inh、side、m和综合属性syn

练习5.3.1:下面是涉及运算符+和整数或浮点运算分量的表达式文法。区分浮点数的方法是看它有无小数点。 E-〉E+T|T T-〉num.num|num 1)给出一个SDD来确定每个项T和表达式E的类型 2)扩展(1)中得到的SDD,使得它可以把表达式转换成为后缀表达式。使用一个单目运算符intToFloat把一个整数转换为相等的浮点数 答: 练习5.4.4:为下面的产生式写出一个和例5.10类似的L属性SDD。这里的每个产生式表

示一个常见的C语言中的那样的控制流结构。你可能需要生成一个三地址语句来跳转到某个标号L,此时你可以生成语句goto L 1)S->if (C) S1 else S2 2)S->do S1 while (C) 3)S->’{’ L ‘}’; L -> LS|ε 请注意,列表中的任何语句都可以包含一条从它的内部跳转到下一个语句的跳转指令,因此简单地为各个语句按序生成代码是不够的。 第六章 练习6.1.1:为下面的表达式构造DAG ((x+y)-((x+y)*(x-y)))+((x+y)*(x-y)) 答:DAG如下

常见C语言错误提示信息

Ambiguous operators need parentheses 不明确的运算需要用括号括起Ambiguous symbol ''xxx'' 不明确的符号 Argument list syntax error 参数表语法错误 Array bounds missing 丢失数组界限符 Array size toolarge 数组尺寸太大 Bad character in paramenters 参数中有不适当的字符 Bad file name format in include directive 包含命令中文件名格式不正确 Bad ifdef directive synatax 编译预处理ifdef有语法错 Bad undef directive syntax 编译预处理undef有语法错 Bit field too large 位字段太长 Call of non-function 调用未定义的函数 Call to function with no prototype 调用函数时没有函数的说明 Cannot modify a const object 不允许修改常量对象 Case outside of switch 漏掉了case 语句 Case syntax error Case 语法错误 Code has no effect 代码不可述不可能执行到Compound statement missing{ 分程序漏掉"{" Conflicting type modifiers 不明确的类型说明符 Constant expression required

要求常量表达式 Constant out of range in comparison 在比较中常量超出范围Conversion may lose significant digits 转换时会丢失意义的数字Conversion of near pointer not allowed 不允许转换近指针 Could not find file ''xxx'' 找不到XXX文件 Declaration missing ; 说明缺少";" Declaration syntax error 说明中出现语法错误 Default outside of switch Default 出现在switch语句之外Define directive needs an identifier 定义编译预处理需要标识符Division by zero 用零作除数 Do statement must have while Do-while语句中缺少while部分Enum syntax error 枚举类型语法错误 Enumeration constant syntax error 枚举常数语法错误 Error directive :xxx 错误的编译预处理命令 Error writing output file 写输出文件错误 Expression syntax error 表达式语法错误 Extra parameter in call 调用时出现多余错误 File name too long 文件名太长 Function call missing ) 函数调用缺少右括号

gcc 常见的编译警告与错误(按字母顺序排列)备课讲稿

g c c常见的编译警告与错误(按字母顺序排 列)

gcc 常见的编译警告与错误(按字母顺序排列) C语言初学者遇到的最大问题往往是看不懂编译错误,进而不知如何修改程序。有鉴于此,本附录罗列了用gcc编译程序时经常出现的编译警告与错误。需要提醒读者的是,出现警告(warning)并不影响目标程序的生成,但出现错误(error)则无法生成目标程序。 为便于读者查阅,下面列出了经常遇到的警告与错误,给出了中英文对照(英文按字典顺序排列),并对部分错误与警告做了必要的解释。 #%s expects \FILENAME\ or … #%s 需要 \FILENAME\ 或… #%s is a deprecated GCC extension #%s 是一个已过时的 GCC 扩展 #%s is a GCC extension #%s 是一个 GCC 扩展 #~ error: #~ 错误: #~ In file included from %s:%u #~ 在包含自 %s:%u 的文件中 #~ internal error: #~ 内部错误: #~ no newline at end of file #~ 文件未以空白行结束

#~ warning: #~ 警告: #elif after #else #elif 出现在 #else 后 #elif without #if #elif 没有匹配的 #if #else after #else #else 出现在 #else 后 #else without #if #else 没有匹配的 #if #endif without #if #endif 没有匹配的 #if #include nested too deeply #include 嵌套过深 #include_next in primary source file #include_next 出现在主源文件中 #pragma %s %s is already registered #pragma %s %s 已经被注册 #pragma %s is already registered #pragma %s 已经被注册 #pragma once in main file #pragma once 出现在主文件中

C语言调试常见错误及修改方法(附习题)

1.调试 C 程序时常见的错误类型分析 一般情况下,错误主要分为两大类:一、语法错误。对于这种错误,用编译器很容易解决。所以,改错题的第一步是先编译,解决这类语法错误。下面总结了二级C 语言上机改错题中常见的语法错误: (1) 丢失分号,或分号误写成逗号。 (2) 关键字拼写错误,如本来小写变成大写。 (3) 语句格式错误,例如for 语句中多写或者少写分号。 (4) 表达式声明错误,例如:少了() (5) 函数类型说明错误。与main ()函数中不一致。 (6) 函数形参类型声明错误。例如:少* 等。 (7) 运算符书写错误,例如:/ 写成了。二、逻辑错误,或者叫语义错误,这和实现程序功能紧密相关,一般不能用编译器发现。对于逻辑错误可以按这样的步骤进行查找。 (1) 先读试题,看清题目的功能要求。 (2) 通读程序,看懂程序中算法的实现方法。 (3) 细看程序,发现常见错误点。 2.改错题的改错方式总结,当然这些总结只能对大部分改错行有效 1、若错误行是函数首部,可分为以下几种情况: A、该行最后若有分号则删除,中间若有分号则改成逗号 B、形参类型不一致的问题,特别是指针类型,若后面用到某形参时有指针运算则该形参必为指针类型;若形参是二维数组或指向m 个元素的指针变量,则第二维的长度必须与main 中对应数组的第二维长度相同 C、函数类型不一致的问题,若函数中没有return语句则函数类型为void,若有return语句则函数的类型必须与return 后变量的类型一致。 2、若错误行是if 或while 语句,则首先看有没有用小括号将整个表达式括起,若没有则加上小括号。 3、若错误行中有if、while 、for 则要特别注意条件表达式的错误问题: A、指针变量的应用,若表达式中有指针变量且没有指针运算符,则加上指针运算符 B、若条件表达式中只有一个等于号,则改成两个等于号,若为其它比较运算符则一般是进行逆转或加一个等于号 C、f or 中要用分号分隔表达式,而不是用逗号 4、语法错误 A、语句缺少分号,若错误行中有语句没有用分号结束,则加上分号。 B、大小写不对,若错误行中有大写字母则一般都改成小写字母。 5、指针变量的运用,若错误行中有指针变量,并且该变量名前没有指针运算符则一般都是加上指针运算符 6、若错误行为return 语句,则首先看是否是缺少分号若是则加上分号即可;否则就是return 后的变量或表达式错误(此时可通过看题意,来分析该返回哪一变量或表达式)

编译原理第4章作业答案

编译原理第4章作业 答案 本页仅作为文档封面,使用时可以删除 This document is for reference only-rar21year.March

第四章 习题4.2.1:考虑上下文无关文法: S->S S +|S S *|a 以及串aa + a* (1)给出这个串的一个最左推导 S -> S S * -> S S + S * -> a S + S * -> a a + S * -> aa + a* (3)给出这个串的一棵语法分析树 习题4.3.1:下面是一个只包含符号a和b的正则表达式的文法。它使用+替代表示并运算的符号|,以避免和文法中作为元符号使用的竖线相混淆: rexpr→ rexpr + rterm | rterm rterm→rterm rfactor | rfactor rfactor→ rfactor * | rprimary rprimary→a | b 1)对这个文法提取公因子 2)提取公因子的变换使这个文法适用于自顶向下的语法分析技术吗? 3)提取公因子之后,原文法中消除左递归 4)得到的文法适用于自顶向下的语法分析吗? 解

1)提取左公因子之后的文法变为 rexpr→ rexpr + rterm | rterm rterm→rterm rfactor | rfactor rfactor→ rfactor * | rprimary rprimary→a | b 2)不可以,文法中存在左递归,而自顶向下技术不适合左递归文法 3)消除左递归后的文法

rexpr -> rterm rexpr’ rexpr’-> + rterm rexpr’|ε rterm-> rfactor rterm’ rterm’-> rfactor rterm’|ε rfactor-> rprimay rfactor’ rfactor’-> *rfactor’|ε rprimary-> a | b 4)该文法无左递归,适合于自顶向下的语法分析 习题4.4.1:为下面的每一个文法设计一个预测分析器,并给出预测分析表。可能要先对文法进行提取左公因子或消除左递归 (3)S->S(S)S|ε (5)S->(L)|a L->L,S|S 解 (3) ①消除该文法的左递归后得到文法 S->S’ S’->(S)SS’|ε ②计算FIRST和FOLLOW集合 FIRST(S)={(,ε} FOLLOW(S)={),$} FIRST(S’)={(,ε} FOLLOW(S’)={),$} ③构建预测分析表

IAR常见编译错误

【转】IAR常见编译错误—比较全 IAR常见编译错误,比较全面的: 前面的序号表示错误编号 0 Format chosen cannot support banking Format unable to support banking. 1 Corrupt file. Unexpected end of file in module module (file) encountered XLINK aborts immediately. Recompile or reassemble, or check the compatibility between XLINK and C compiler. 2 Too many errors encountered (>100) XLINK aborts immediately. 3 Corrupt file. Checksum failed in module module (file). Linker checksum is linkcheck, module checksum is modcheck XLINK aborts immediately. Recompile or reassemble. 4 Corrupt file. Zero length identifier encountered in module module (file) XLINK aborts immediately. Recompile or reassemble. 5 Address type for CPU incorrect. Error encountered in module module (file) XLINK aborts immediately. Check that you are using the right files and libraries. 6 Program module module redeclared in file file. Ignoring second module XLINK will not produce code unless the Always generate output (-B) option (forced dump) is used. 7 Corrupt file. Unexpected UBROF – format end of file encountered in module module (file) XLINK aborts immediately. Recompile or reassemble. 8 Corrupt file. Unknown or misplaced tag encountered in module module (file). Tag tag XLINK aborts immediately. Recompile or reassemble. 9 Corrupt file. Module module start unexpected in file file XLINK aborts immediately. Recompile or reassemble. 10 Corrupt file. Segment no. segno declared twice in module module (file) XLINK aborts immediately. Recompile or reassemble. 11 Corrupt file. External no. ext no declared twice in module module (file) XLINK aborts immediately. Recompile or reassemble. 12 Unable to open file file XLINK aborts immediately. If you are using the command line, check the

常见gcc 编译错误整理

常见gcc 编译错误整理(开始)1 1 error: expected expression before 'else' else之前无表达式。 2 error: lvalue required as left operand of assignment 左值问题。 3 error: invalid storage class for function 'XXXXXX' 在文件的某个地方,丢失了一个大括号‘}’。 常见gcc编译警告整理(开始) 1、warning: no newline at end of file 在文件最后一行加上回车键 解释:在《Rationale for the C99 standard》一文中,有C99的相关信息: A backslash immediately before a newline has long been used to continue string literals, as well as preprocessing command lines. In the interest of easing machine generation of C, and of transporting code to machines with restrictive physical line lengths, the C89 Committee generalized this mechanism to permit any token to be continued by interposing a backslash/newline sequence. c/c++代码的每一行后面有一个“结束符”,也就是newline。避免当被include的文件展开后,前一个文件的最后一行与后一个文件的第一行直接被连接成一行从而造成错误。 2、warning: comparison between pointer and integer 解释:integer与pointer比较

VC6常见编译错误

目录 VC6.0编译常见错误 (1) 第一部分编译错误 (1) 1.error C2001: newline in constant (1) 2.error C2015: too many characters in constant (2) 3.error C2018: unknown character '0x##' (3) 4.error C2041: illegal digit '#' for base '8' (3) 5.error C2065: 'xxxx' : undeclared identifier (3) 6.error C2086: 'xxxx' : redefinition (5) 7.error C2374: 'xxxx' : redefinition; multiple initialization (5) 8.C2143: syntax error : missing ';' before (identifier) 'xxxx' (5) 9.error C2137: empty character constant (6) 10.error C2374: 'xxxx' : redefinition; multiple initialization (7) 第二部分链接错误 (7) 1.error LNK2001: unresolved external symbol _main (7) 2.error LNK2005: _main already defined in xxxx.obj (7) VC6.0编译常见错误 第一部分编译错误 1.error C2001: newline in constant 编号:C2001 直译:在常量中出现了换行。错误分析: (1)字符串常量、字符常量中是否有换行。

Keil C 编译器常见警告与错误信息

https://www.doczj.com/doc/5d13368550.html,/support/man/docs/c51/c51_c277.htm错误信息查询 Keil C 编译器常见警告与错误信息 error C132 :“****”not in formal parameter list 花了偶将近半个小时来查找错误,最终发现原来是在头文件里的一个函数声明时露了一个分号造成紧挨着在它下面声明的参数not in formal parameter list。 记在在这里,免得以后忘记了,同时也供大家分享。 下面是另外一些常见的错误提示: 1.第一种错误信息 ***WARNING L15: MULTIPLE CALL TO SEGMENT SEGMENT: ?PR?_WRITE_GMVLX1_REG?D_GMVLX1 CALLER1: ?PR?VSYNC_INTERRUPT?MAIN CALLER2: ?C_C51STARTUP ***WARNING L15: MULTIPLE CALL TO SEGMENT SEGMENT: ?PR?_SPI_SEND_WORD?D_SPI CALLER1: ?PR?VSYNC_INTERRUPT?MAIN CALLER2: ?C_C51STARTUP ***WARNING L15: MULTIPLE CALL TO SEGMENT SEGMENT: ?PR?SPI_RECEIVE_WORD?D_SPI CALLER1: ?PR?VSYNC_INTERRUPT?MAIN CALLER2: ?C_C51STARTUP - 该警告表示连接器发现有一个函数可能会被主函数和一个中断服务程序(或者调用中断服务程序的函数)同时调用,

编译时的常见错误

一、编译时的常见错误 1. 数据类型错误。此类错误是初学者编程时的常见现象, 下面是一些要引起注意的错误: (1) 所有变量和常量必须要加以说明。 (2) 变量只能赋给相同类型的数据。 (3) 对scanf()语句, 用户可能输入错误类型的数据项, 这将导致运行时出错, 并报出错信息。为避免这样的错误出现, 你就提示用户输入正确类型的数据。 (4) 在执行算术运算时要注意: a. 根据语法规则书写双精度数字。要写0.5, 而不是写.5; 要写1.0, 而不是1。尽管C语言会自动地把整型转换成双精度型, 但书写双精度型是个好习惯。让C语言为你做强行转换这是一种效率不高的程序设计风格。这有可能导致转换产生错误。 b. 不要用0除。这是一个灾难性的错误, 它会导致程序失败, 不管C 语言的什么版本, 都是如此, 执行除法运算要特别小心。 c. 确保所有的双精度数(包括那些程序输入用的双精度数) 是在实数范围之内。 d. 所有整数必须在整数允许的范围内。这适用于所有计算结果, 包括中间结果。 2. 将函数后面的";"忘掉。此时错误提示色棒将停在该语句下的一行, 并显示: Statement missing ; in function <函数名> 3. 给宏指令如#include, #define等语句尾加了";"号。 4. "{"和"}"、"("和")"、"/*"和"*/"不匹配。引时色棒将位于错误所在的行, 并提示出有关丢掉括号的信息。 5. 没有用#include指令说明头文件, 错误信息提示有关该函数所使用的参数未定义。 6. 使用了Turbo C保留关键字作为标识符, 此时将提示定义了太多数据类型。 7. 将定义变量语句放在了执行语句后面。此时会提示语法错误。 8. 使用了未定义的变量, 此时屏幕显示: Undefined symbol '<变量名>' in function <函数名> 9. 警告错误太多。忽略这些警告错误并不影响程序的执行和结果。编译时当警告错误数目大于某一规定值时(缺省为100)便退出编译器, 这时应改变集成开发环境Options/Compiler/Errors中的有关警告错误检查开关为off。 10. 将关系符"=="误用作赋值号"="。此时屏幕显示: Lvalue required in function <函数名> 二、连接时的常见错误 1. 将Turbo C库函数名写错。这种情况下在连接时将会认为此函数是用户自定义函数。此时屏幕显示: Undefined symbol '<函数名>' in <程序名> 2. 多个文件连接时, 没有在"Project/Project name中指定项目文件(.PRJ文件), 此时出现找不到函数的错误。 3. 子函数在说明和定义时类型不一致。 4. 程序调用的子函数没有定义。 三、运行时的常见错误 1. 路径名错误。在MS-DOS中, 斜杠(\)表示一个目录名; 而在Turbo C 中斜杠是个某个字符串的一个转义字符, 这样, 在用Turbo C 字符串给出一个路径名时应考虑"\"的转义的作用。例如, 有这样一条语句: file=fopen("c:\new\tbc.dat", "rb"); 目的是打开C盘中NEW目录中的TBC.DAT文件, 但做不到。这里"\"后面紧接的分别是"n"及"t", "\n"及"\t"将被分别编译为换行及tab字符, DOS将认为它是不正确的文件名而拒绝接受, 因为文件名中不能和换行或tab字符。正确的写法应为: file=fopen("c:\\new\\tbc.dat", "rb"); 2. 格式化输入输出时, 规定的类型与变量本身的类型不一致。例如: float l;

编译出错种类

VC++编译的常见错误 1、fatal error C1010: unexpected end of file while looking for precompiled header directive。 寻找预编译头文件路径时遇到了不该遇到的文件尾。(一般是没有#include "stdafx.h") 2、fatal error C1083: Cannot open include file: 'R…….h': No such file or directory 不能打开包含文件“R…….h”:没有这样的文件或目录。 3、error C2011: 'C……': 'class' type redefinition 类“C……”重定义。 4、error C2018: unknown character '0xa3' 不认识的字符'0xa3'。(一般是汉字或中文标点符号) 5、error C2057: expected constant expression 希望是常量表达式。(一般出现在switch语句的case分支中) 6、error C2065: 'IDD_MYDIALOG' : undeclared identifier “IDD_MYDIALOG”:未声明过的标识符。 7、error C2082: redefinition of formal parameter 'bReset' 函数参数“bReset”在函数体中重定义。 8、error C2143: syntax error: missing ':' before '{' 句法错误:“{”前缺少“;”。 9、error C2146: syntax error : missing ';' before identifier 'dc' 句法错误:在“dc”前丢了“;”。 10、error C2196: case value '69' already used 值69已经用过。(一般出现在switch语句的case分支中) 11、error C2509: 'OnTimer' : member function not declared in 'CHelloView' 成员函数“OnTimer”没有在“CHelloView”中声明。 12、error C2511: 'reset': overloaded member function 'void (int)' not found in 'B' 重载的函数“void reset(int)”在类“B”中找不到。 13、error C2555: 'B::f1': overriding virtual function differs from 'A::f1' only by return type or calling convention 类B对类A中同名函数f1的重载仅根据返回值或调用约定上的区别。 14、error C2660: 'SetTimer' : function does not take 2 parameters “SetTimer”函数不传递2个参数。 15、warning C4035: 'f……': no return value “f……”的return语句没有返回值。 16、warning C4553: '= =' : operator has no effect; did you intend '='? 没有效果的运算符“= =”;是否改为“=”? 17、warning C4700: local variable 'bReset' used without having been initialized 局部变量“bReset”没有初始化就使用。

编译原理 作业标准答案

《编译原理》第一次作业参考答案 一、下列正则表达式定义了什么语言(用尽可能简短的自然语言描述)? 1.b*(ab*ab*)* 所有含有偶数个a的由a和b组成的字符串. 2.c*a(a|c)*b(a|b|c)* | c*b(b|c)*a(a|b|c)* 答案一:所有至少含有1个a和1个b的由a,b和c组成的字符串. 答案二:所有含有子序列ab或子序列ba的由a,b和c组成的字符串. 说明:答案一要比答案二更好,因为用自然语言描述是为了便于和非专业的人员交流,而非专业人员很可能不知道什么是“子序列”,所以相比较而言,答案一要更“自然”. 二、设字母表∑={a,b},用正则表达式(只使用a,b, ,|,*,+,?)描述下列语言: 1.不包含子串ab的所有字符串. b*a* 2.不包含子串abb的所有字符串. b*(ab?)* 3.不包含子序列abb的所有字符串. b*a*b?a* 注意:关于子串(substring)和子序列(subsequence)的区别可以参考课本第119页方框中的内容. ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ 《编译原理》第二次作业参考答案 一、考虑以下NFA: 1.这一NFA接受什么语言(用自然语言描述)? 所有只含有字母a和b,并且a出现偶数次或b出现偶数次的字符串. 2.构造接受同一语言的DFA. 答案一(直接构造通常得到这一答案):

答案二(由NFA构造DFA得到这一答案): 二、正则语言补运算 3.画出一个DFA,该DFA恰好识别所有不含011子串的所有二进制串. 1.画出一个DFA,该DFA恰好识别所有不含011子串的所有二进制串.

JAVA常见编译错误信息及说明

Java编译错误信息及说明 1、java:33:不是语句 解释:程序中出现了没有任何意义的字符(串),可能是无意中打出了没有任何意义的字符; 2、java:34:需要';' 解释:某条语句没有以分号结束; 3、java:36:缺少返回语句 解释:带返回值的函数缺少return语句; 4、java:33:不兼容的类型 解释:运算符两边的数据类型不一致或者不能做隐式转换; 5、java:36:无法访问的语句 解释:此语句永远不可能被执行,可能是此语句之前存在类似于while(true)的语句,导致此语句永远不可能被执行; 6、java:34:非法的表达式开始 解释:有不符合语法规范的表达式出现; 7、java:34:找不到符号 解释:使用了没有定义或没有引入的变量; 8、java:33:非法字符:\65307 解释:在中文输入状态下输入了一些标点符号; 9、java:18:不可转换的类型 解释:运算符两边的数据类型不一致或者不能做隐式转换; 10、java:19:"else"不带有"if" 解释:编译器找到else语句但是没有找到与之对应的if语句,可能是由于大括号没有成对出现;

11、java:12:可能损失精度 解释:把高精确度类型的数据赋值给低精确度类型的变量; 12、java:17:需要')' 解释:括号没有成对出现; 13、java:8:可能尚未初始化变量s 解释:局部变量s没有赋初值; 14、java:7:不可比较的类型:int和Boolean 解释:运算符两边操作数的数据类型不符合运算符的使用规范; 15、java:6:已在isLeap(int)中定义year 解释:变量year被重复定义; 16、java:21:字符字面值的行结尾不合法 解释:程序语句的结尾不是java规定的结束符号,而是其他的符号; 17、java:9:需要<标识符> 解释:可能是由于用户指定了数据类型,但未指定该类型的变量名; 18、java:8:无法从静态上下文中引用非静态变量this 解释:在静态方法中使用了非静态变量this; 19、java:12:在switch或loop外部中断 解释:在非循环语句或非switch语句中使用了中断循环功能的语句break; 20、java:21:对于结果类型为void的方法,无法返回值 解释:空返回值方法中出现了return语句; 21、java:12:需要数组,但找到int 解释:在应该出现数组的地方没有找到数组类型的变量,而是找到int类型的变量; 22、java:13:无法将Node中的setData(int)应用于()

编译原理作业参考答案

第1章引言 1、解释下列各词 源语言:编写源程序的语言(基本符号,关键字),各种程序设计语言都可以作为源语言。 源程序: 用接近自然语言(数学语言)的源语言(基本符号,关键字)编写的程序,它是翻译程序处理的对象。 目标程序: 目标程序是源程序经过翻译程序加工最后得到的程序。目标程序 (结果程序)一般可由计算机直接执行。 低级语言:机器语言和汇编语言。 高级语言:是人们根据描述实际问题的需要而设计的一个记号系统。如同自然语言(接近数学语言和工程语言)一样,语言的基本单位是语句,由符号组和一组用来组织它们成为有确定意义的组合规则。 翻译程序: 能够把某一种语言程序(源语言程序)改变成另一种语言程序(目 标语言程序),后者与前者在逻辑上是等价的。其中包括:编译程序,解释程序,汇编程序。 编译程序: 把输入的源程序翻译成等价的目标程序(汇编语言或机器语言), 然后再执行目标程序(先编译后执行),执行翻译工作的程序称为编译程序。 解释程序: 以该语言写的源程序作为输入,但不产生目标程序。按源程序中语句动态顺序逐句的边解释边执行的过程,完成翻译工作的程序称为解释程序。 2、什么叫“遍” 指对源程序或源程序的中间形式(如单词,中间代码)从头到尾扫描一次,并作相应的加工处理,称为一遍。

3、简述编译程序的基本过程的任务。 编译程序的工作是指从输入源程序开始到输出目标程序为止的整个过程,整个过程可以划分5个阶段。 词法分析:输入源程序,进行词法分析,输出单词符号。 语法分析:在词法分析的基础上,根据语言的语法规则把单词符号串分解成各类语法单位,并判断输入串是否构成语法正确的“程序”。 中间代码生成:按照语义规则把语法分析器归约(或推导)出的语法单位翻译成一定形式的中间代码。 优化:对中间代码进行优化处理。 目标代码生成:把中间代码翻译成目标语言程序。 4、编译程序与解释程序的区别 编译程序生成目标程序后,再执行目标程序;然而解释程序不生成目标程序,边解释边执行。 5、有人认为编译程序的五个组成部分缺一不可,这种看法正确吗 编译程序的5个阶段中,词法分析,语法分析,语义分析和代码生成生成是必须完成的。而中间代码生成和代码优化并不是必不可少的。优化的目的是为了提高目标程序的质量,没有这一部分工作,仍然能够得到目标代码。 6、编译程序的分类 目前基本分为:诊断编译程序,优化编译程序,交叉编译程序,可变目标编译程序。

相关主题
文本预览
相关文档 最新文档