说明:Turbo C 的源程序错误分为三种类型:致命错误、一般错误和警告。
其中,致命错误通常是内部编译出错;一般错误指程序的语法错误、磁盘或内存
存取错误或命令行错误等;警告则只是指出一些得怀疑的情况,它并不防止编译
的进行。
下面按字母顺序A~Z分别列出致命错误及一般错误信息,英汉对照及处理方
法:
(一)、致命错误英汉对照及处理方法:
A-B致命错误
Bad call of in-line function (内部函数非法调用)
分析与处理:在使用一个宏定义的内部函数时,没能正确调用。一个内部函数以
两个下划线(__)开始和结束。
Irreducable expression tree (不可约表达式树)
分析与处理:这种错误指的是文件行中的表达式太复杂,使得代码生成程序无法
为它生成代码。这种表达式必须避免使用。
Register allocation failure (存储器分配失败)
分析与处理:这种错误指的是文件行中的表达式太复杂,代码生成程序无法为它
生成代码。此时应简化这种繁杂的表达式或干脆避免使用它。
(二)、一般错误信息英汉照及处理方法
#operator not followed by maco argument name(#运算符后没跟宏变元名)
分析与处理:在宏定义中,#用于标识一宏变串。“#”号后必须跟一个宏变元
名。
'xxxxxx' not anargument ('xxxxxx'不是函数参数)
分析与处理:在源程序中将该标识符定义为一个函数参数,但此标识符没有在函
数中出现。
Ambiguous symbol 'xxxxxx' (二义性符号'xxxxxx')
分析与处理:两个或多个结构的某一域名相同,但具有的偏移、类型不同。在变
量或表达式中引用该域而未带结构名时,会产生二义性,此时需修改某个域名或
在引用时加上结构名。
Argument # missing name (参数#名丢失)
分析与处理:参数名已脱离用于定义函数的函数原型。如果函数以原型定义,该
函数必须包含所有的参数名。
Argument list syntax error (参数表出现语法错误)
分析与处理:函数调用的参数间必须以逗号隔开,并以一个右括号结束。若源文
件中含有一个其后不是逗号也不是右括号的参数,则出错。
Array bounds missing (数组的界限符"]"丢失)
分析与处理:在源文件中定义了一个数组,但此数组没有以下右方括号结束。
Array size too large (数组太大)
分析与处理:定义的数组太大,超过了可用内存空间。
Assembler statement too long (汇编语句太长)
分析与处理:内部汇编语句最长不能超过480字节。
Bad configuration file (配置文件不正确)
分析与处理:TURBOC.CFG配置文件中包含的不是合适命令行选择项的非注解文
字。配置文件命令选择项必须以一个短横线开始。
Bad file name format in include directive(包含指令中文件名格式不正确)
分析与处理:包含文件名必须用引号("filename.h")或尖括号(<filename>)括起
来,否则将产生本类错误。如果使用了宏,则产生的扩展文本也不正确,因为无
引号没办法识别。
Bad ifdef directive syntax (ifdef指令语法错误)
分析与处理:#ifdef必须以单个标识符(只此一个)作为该指令的体。
Bad ifndef directive syntax (ifndef指令语法错误)
分析与处理:#ifndef 必须以单个标识符(只此一个)作为该指令的体。
Bad undef directive syntax (undef指令语法错误)
分析与处理:#undef指令必须以单个标识符(只此一个)作为该指令的体。
Bad file size syntax (位字段长语法错误)
分析与处理:一个位字段长必须是1—16位的常量表达式。
Call of non-functin (调用未定义函数)
分析与处理:正被调用的函数无定义,通常是由于不正确的函数声明或函数名拼
错而造成。
Cannot modify a const object (不能修改一个长量对象)
分析与处理:对定义为常量的对象进行不合法操作(如常量赋值)引起本错误。
Case outside of switch (Case 出现在switch外)
分析与处理:编译程序发现Case语句出现在switch语句之外,这类故障通常是由
于括号不匹配造成的。
Case statement missing (Case语句漏掉)
分析与处理:Case语必须包含一个以冒号结束的常量表达式,如果漏了冒号或在
冒号前多了其它符号,则会出现此类错误。
Character constant too long (字符常量太长)
分析与处理:字符常量的长度通常只能是一个或两个字符长,超过此长度则会出
现这种错误。
Compound statement missing (漏掉复合语句)
分析与处理:编译程序扫描到源文件未时,未发现结束符号 (大括号),此类故
障通常是由于大括号不匹配所致。
Conflicting type modifiers (类型修饰符冲突)
分析与处理:对同一指针,只能指定一种变址修饰符(如near 或far);而对于同
一函数,也只能给出一种语言修饰符(如Cdecl、pascal或interrupt)。
Constant expression required (需要常量表达式)
分析与处理:数组的大小必须是常量,本错误通常是由于#define常量的拼写错
误引起。
Could not find file 'xxxxxx.xxx' (找不到'xxxxxx.xx'文件)
分析与处理:编译程序找不到命令行上给出的文件。
Declaration missing (漏掉了说明)
分析与处理:当源文件中包含了一个struct或 union域声明,而后面漏掉了分
号,则会出现此类错误。
Declaration needs type or storage class(说明必须给出类型或存储类)
分析与处理:正确的变量说明必须指出变量类型,否则会出现此类错误。
Declaration syntax error (说明出现语法错误)
分析与处理:在源文件中,若某个说明丢失了某些符号或输入多余的符号,则会
出现此类错误。
Default outside of switch (Default语句在switch语句外出现)
分析与处理:这类错误通常是由于括号不匹配引起的。
Define directive needs an identifier (Define指令必须有一个标识符)
分析与处理:#define 后面的第一个非空格符必须是一个标识符,若该位置出现
其它字符,则会引起此类错误。
Division by zero (除数为零)
分析与处理:当源文件的常量表达式出现除数为零的情况,则会造成此类错误。
Do statement must have while (do语句中必须有While关键字)
分析与处理:若源文件中包含了一个无While关键字的 do语句,则出现本错误。
DO while statement missing ( (Do while语句中漏掉了符号 "(")
分析与处理:在do语句中,若 while关键字后无左括号,则出现本错误。
Do while statement missing;(Do while语句中掉了分号)
分析与处理:在DO语句的条件表达式中,若右括号后面无分号则出现此类错误。
Duplicate Case (Case情况不唯一)
分析与处理:Switch语句的每个case必须有一个唯一的常量表达式值。否则导致
此类错误发生。
Enum syntax error (Enum语法错误)
分析与处理:若enum说明的标识符表格式不对,将会引起此类错误发生。
Enumeration constant syntax error (枚举常量语法错误)
分析与处理:若赋给enum类型变量的表达式值不为常量,则会导致此类错误发
生。
Error Directive : xxxx (Error指令:xxxx)
分析与处理:源文件处理#error指令时,显示该指令指出的信息。
Error Writing output file (写输出文件错误)
分析与处理:这类错误通常是由于磁盘空间已满,无法进行写入操作而造成。
Expression syntax error (表达式语法错误)
分析与处理:本错误通常是由于出现两个连续的操作符,括号不匹配或缺少括
号、前一语句漏掉了分号引起的。
Extra parameter in call (调用时出现多余参数)
分析与处理:本错误是由于调用函数时,其实际参数个数多于函数定义中的参数
个数所致。
Extra parameter in call to xxxxxx(调用xxxxxxxx函数时出现了多余参数)
File name too long (文件名太长)
分析与处理:#include指令给出的文件名太长,致使编译程序无法处理,则会出
现此类错误。通常DOS下的文件名长度不能超过 64个字符。
For statement missing ) (For语名缺少")")
分析与处理:在 for语句中,如果控制表达式后缺少右括号,则会出现此类错
误。
For statement missing( (For语句缺少"(")
For statement missing; (For 语句缺少";")
分析与处理:在 for语句中,当某个表达式后缺少分号,则会出现此类错误。
Function call missing) (函数调用缺少")")
分析与处理:如果函数调用的参数表漏掉了右手括号或括号不匹配,则会出现此
类错误。
Function definition out ofplace (函数定义位置错误)
Function doesn't take a variable number of argument(函数不接受可变的参
数个数)
Goto statement missing label (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 (浮点运算非法)
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 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 syntax 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 addressable (必须是可编址的)
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 left side 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 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 many types in decleration (说明中类型太多)
Too much auto memory in function (函数中自动存储太多)
Too much global define in file (文件中定义的全局数据太多)
Two consecutive dots (两个连续点)
Type mismatch in parameter # (参数"#"类型不匹配)
Type mismatch in parameter # in call to 'XXXXXXX' (调用'XXXXXXX'时参数
#类型不匹配)
Type missmatch in parameter 'XXXXXXX' (参数'XXXXXXX'类型不匹配)
Type mismatch in parameter 'YYYYYYYY' in call to 'YYYYYYYY'(调用
'YYYYYYY'时参数'XXXXXXXX'数型不匹配)
Type mismatch in redeclaration of 'XXX' (重定义类型不匹配)
Unable to creat output file 'XXXXXXXX.XXX' (不能创建输出文件
'XXXXXXXX.XXX')
Unable to create turboc.lnk (不能创建turboc.lnk )
Unable to execute command 'xxxxxxxx'(不能执行'xxxxxxxx'命令)
Unable to open include file 'xxxxxxx.xxx' (不能打开包含文件
'xxxxxxxx.xxx')
Unable to open inputfile 'xxxxxxx.xxx' (不能打开输入文件
'xxxxxxxx.xxx')
Undefined label 'xxxxxxx' (标号'xxxxxxx'未定义)
Undefined structure 'xxxxxxxxx' (结构'xxxxxxxxxx'未定义)
Undefined symbol 'xxxxxxx' (符号'xxxxxxxx'未定义)
Unexpected end of file in comment started on line #(源文件在某个注释中
意外结束)
Unexpected end of file in conditional stated on line # (源文件在#行开
始的条件语句中意外结束)
Unknown preprocessor directive 'xxx' (不认识的预处理指令:
'xxx')Untermimated character constant (未终结的字符常量)
Unterminated string (未终结的串)
Unterminated string or character constant(未终结的串或字符常量)
User break (用户中断)
Value required (赋值请求)
While statement missing ( (While语句漏掉 '(')
While statement missing ) (While语句漏掉 ')')
Wrong number of arguments in of 'xxxxxxxx' (调用'xxxxxxxx'时参数个数错
误)
在开始看本文以前,我先说明一下C语言的安装和使用中最应该注意的地方:许
多网友在下载Turbo C 2.0和Turbo C++ 3.0后,向我问得最多的是在使用过程中
碰到如下问题:
1)出现找不到 stdio.h conio.h等include文件;
2)出现cos.obj无法连接之类的错误
这些问题是由于没有设置好路径引起的,目前下载的TC2,TC3按安装分类大
概有两种版本:一是通过install安装,这类应该已经设置好了路径;二是直接
解压后建立TC.EXE的快捷方式,在WINDOWS下双击即可运行(DOS下直接运行
TC.EXE),目前国内大多为这种,因此下载使用前请注意
路径设置:
设置方法为:
OPTION->DIRECTORIES:
INCLUDE: [TC2/3所在目录]/include
LIB: [TC2/3所在目录]/lib
output输出目录请自己设置一个工作目录,以免混在一起。最后还提醒一点:
FILES中的Change dir(改变当前目录)中应设置为当前程序所在目录。
一、 Turbo C 2.0的安装和启动
Turbo C 2.0的安装非常简单, 只要将1#盘插入A驱动器中, 在DOS的"A>" 下
键入: A>INSTALL 即可, 此时屏幕上显示三种选择:
1. 在硬盘上创造一个新目录来安装整个Turbo C 2.0系统。
2. 对Turbo C 1.5更新版本。这样的安装将保留原来对选择项、颜色和编辑功能
键的设置。
3. 为只有两个软盘而无硬盘的系统安装Turbo C 2.0。
这里假定按第一种选择进行安装, 只要在安装过程中按对盘号的提示, 顺序
插入各个软盘, 就可以顺利地进行安装, 安装完毕将在C盘根目录下建立一个TC
子目录, TC下还建立了两个了目录LIB和INCLUDE, LIB子目录中存放库文件,
INCLUDE子目录中存放所有头文件。运行Turbo C2.0时, 只要在TC 子目录下键入
TC并回车即可进入Turbo C 2. 0 集成开发环境。
二、 Turbo C 2.0集成开发环境的使用
进入Turbo C 2.0集成开发环境中后, 屏幕上显示:
──────────────────────────────
File Edit Run Compile Project Options Debug Break/watch
┌────────────Ed i t──────────────┐
│ Line 1 Col 1 Insert Indent Tab File Unindent c:NONAME.C │
│ │
│ │
│ │
│ │
│ │
│ │
│ │
│─────────Message─────────────── │
│ │
│ │
└────────────────────────────┘
F1-Help F5-Zoom F6-Switch F7-Trace F8-Step F9-Make F10-Menu
───────────────────────────────
其中顶上一行为Turbo C 2.0 主菜单, 中间窗口为编辑区, 接下来是信息窗口,
最底下一行为参考行。这四个窗口构成了Turbo C 2.0的主屏幕, 以后的编程、
编译、调试以及运行都将在这个主屏幕中进行。下面详细介绍主菜单的内容。
1.主菜单
主菜单在Turbo C 2.0主屏幕顶上一行, 显示下列内容:File Edit Run
Compile Project Options Debug Break/watch
除Edit外, 其它各项均有子菜单, 只要用Alt加上某项中第一个字母(即大写
字母), 就可进入该项的子菜单中。
File (文件)菜单 ----按Alt+F可进入File菜单, 该菜单包括以下内容:
.Load (加载)
装入一个文件, 可用类似DOS的通配符(如*.C)来进行列表选择。也可装入其它扩
展名的文件, 只要给出文件名(或只给路径)即可。该项的热键为F3, 即只要在主
菜单中按F3即可进入该项, 而不需要先进入File菜单再选此项。
.Pick (选择)
将最近装入编辑窗口的8个文件列成一个表让用户选择, 选择后将该程序装入编
辑区, 并将光标置在上次修改过的地方。其热健为Alt-F3。
.New (新文件)
说明文件是新的, 缺省文件名为NONAME.C, 存盘时可改名。
.Save (存盘)
将编辑区中的文件存盘, 若文件名是NONAME.C时, 将询问是否更改文件名, 其热
键为F2。
.Write to (存盘)
可由用户给出文件名将编辑区中的文件存盘, 若该文件已存在, 则询问要不要覆
盖。
.Directory (目录)
显示目录及目录中的文件, 并可由用户选择。
.Change dir (改变目录)
显示当前目录, 用户可以改变显示的目录。
.Os shell (暂时退出)
暂时退出Turbo C 2.0到DOS提示符下, 此时可以运行DOS 命令, 若想回到Turbo
C 2.0中, 只要在DOS状态下键入EXIT即可。
.Quit (退出)
退出Turbo C 2.0, 返回到DOS操作系统中, 其热键为Alt+X。
说明: 以上各项可用光标键移动色棒进行选择, 回车则执行。也可用每一项的第
一个大写字母直接选择。若要退到主菜单或从它的下一级菜单列表框退回均可用
Esc键,Turbo C 2.0所有菜单均采用这种方法进行操作, 以下不再说明。
Edit (编辑)菜单---按Alt+E可进入编辑菜单, 若再回车, 则光标出现在编辑窗
口, 此时用户可以进行文本编辑。编辑方法基本与wordstar相同,
可用F1键获得有关编辑方法的帮助信息。与编辑有关的功能键如下:
F1 获得Turbo C 2.0编辑命令的帮助信息
F5 扩大编辑窗口到整个屏幕
F6 在编辑窗口与信息窗口之间进行切换
F10 从编辑窗口转到主菜单
编辑命令简介:
PageUp 向前翻页
PageDn 向后翻页
Home 将光标移到所在行的开始
End 将光标移到所在行的结尾
Ctrl+Y 删除光标所在的一行
Ctrl+T 删除光标所在处的一个词
Ctrl+KB 设置块开始
Ctrl+KK 设置块结尾
Ctrl+KV 块移动
Ctrl+KC 块拷贝
Ctrl+KY 块删除
Ctrl+KR 读文件
Ctrl+KW 存文件
Ctrl+KP 块文件打印
Ctrl+F1 如果光标所在处为Turbo C 2.0库函数, 则获得有关该函数的帮助信息
Ctrl+Q[ 查找Turbo C 2.0双界符的后匹配符
Ctrl+Q] 查找Turbo C 2.0双界符的前匹配符
说明:
a. Turbo C 2.0的双界符包括以下几种符号:
花括符 { }
尖括符 < >
圆括符 ( )
方括符 [ ]
注释符 /* */
双引号 "
单引号 ''
Turbo C 2.0在编辑文件时还有一种功能, 就是能够自动缩进, 即光标定位和上
一个非空字符对齐。在编辑窗口中, Ctrl+OL为自动缩进开关的控制键。
Run (运行)菜单---按Alt+R可进入Run菜单, 该菜单有以下各项:
.Run (运行程序)
运行由Project/Project name项指定的文件名或当前编辑区的文件。如果对上次
编译后的源代码未做过修改, 则直接运行到下一个断点(没有断点则运行到结
束)。否则先进行编译、连接后才运行, 其热键为Ctrl+F9。
.Program reset (程序重启)
中止当前的调试, 释放分给程序的空间, 其热键为Ctrl+F2。
.Go to cursor (运行到光标处)
调试程序时使用, 选择该项可使程序运行到光标所在行。光标所在行必须为一条
可执行语句, 否则提示错误。其热键为F4。
.Trace into (跟踪进入)
在执行一条调用其它用户定义的子函数时, 若用Trace into项, 则执行长条将跟
踪到该子函数内部去执行, 其热键为F7。
.Step over (单步执行)
执行当前函数的下一条语句, 即使用户函数调用, 执行长条也不会跟踪进函数内
部, 其热键为F8。
.User screen (用户屏幕)
显示程序运行时在屏幕上显示的结果。其热键为Alt+F5。
Compile (编译)菜单---按Alt+C可进入Compile菜单, 该菜单有以下几个内容:
.Compile to OBJ (编译生成目标码)
将一个C源文件编译生成.OBJ目标文件, 同时显示生成的文件名。其热键为
Alt+F9。
.Make EXE file (生成执行文件)
此命令生成一个.EXE的文件, 并显示生成的.EXE文件名。其中.EXE文件名是下面
几项之一。
a. 由Project/Project name说明的项目文件名。
b. 若没有项目文件名, 则由Primary C file说明的源文件。
c. 若以上两项都没有文件名, 则为当前窗口的文件名。
.Link EXE file (连接生成执行文件)
把当前.OBJ文件及库文件连接在一起生成.EXE文件。
.Build all (建立所有文件)
重新编译项目里的所有文件, 并进行装配生成.EXE文件。该命令不作过时检查
(上面的几条命令要作过时检查, 即如果目前项目里源文件的日期和时间与目标
文件相同或更早, 则拒绝对源文件进行编译)。
.Primary C file (主C文件)
当在该项中指定了主文件后, 在以后的编译中, 如没有项目文件名则编译此项中
规定的主C文件, 如果编译中有错误, 则将此文件调入编辑窗口, 不管目前窗口
中是不是主C文件。
.Get info
获得有关当前路径、源文件名、源文件字节大小、编译中的错误数目、可用空间
等信息。
Project (项目)菜单---按Alt+P可进入Project菜单, 该菜单包括以下内容:
.Project name (项目名)
项目名具有.PRJ的扩展名, 其中包括将要编译、连接的文件名。例如有一个程序
由file1.c, file2.c, file3.c组成, 要将这3个文件编译装配成一个file.exe的
执行文件, 可以先建立一个file.prj的项目文件, 其内容如下:
file1.c file2.c file3.c
此时将file.prj放入Project name项中, 以后进行编译时将自动对项目文件中规
定的三个源文件分别进行编译。然后连接成file.exe文件。如果其中有些文件已
经编译成.OBJ文件, 而又没有修改过, 可直接写上.OBJ扩 展名。此时将不再编
译而只进行连接。例如: file1.obj file2.c file3.c 将不对file1.c进行编译,
而直接连接。 说明: 当项目文件中的每个文件无扩展名时, 均按源文件对待,
另外, 其中的文件也可以是库文件, 但必须写上扩展名.LIB。
.Break make on (中止编译)
由用户选择是否在有Warining(警告)、Errors(错误)、Fatal Errors( 致命错
误)时或Link(连接)之前退出Make编译。
.Auto dependencies (自动依赖)
当开关置为on, 编译时将检查源文件与对应的.OBJ文件日期和时间, 否则不进行
检查。
.Clear project (清除项目文件)
清除Project/Project name中的项目文件名。
.Remove messages (删除信息)
把错误信息从信息窗口中清除掉。
Options (选择菜单) ---按Alt+O可进入Options菜单, 该菜单对初学者来说要谨
慎使用。
.Compiler (编译器)
本项选择又有许多子菜单, 可以让用户选择硬件配置、存储模型、调试技术、代
码优化、对话信息控制和宏定义。这些子菜单如下: Model 共有Tiny, small,
medium, compact, large, huge 六种不同模式可由同户选择。
Define 打开一个宏定义框, 同户可输入宏定义。多重定义可同分号, 赋值可用
等号。
Code generation 它又有许多任选项, 这些任选项告诉编译器产生什么样的目标
代码。
Calling convention 可选择C或Pascal方式传递参数。
Instruction set 可选择8088/8086或80186/80286指令系列。
Floating point 可选择仿真浮点、数学协处理器浮点或无浮点运算。
Default char type 规定char的类型。
Alignonent 规定地址对准原则。
Merge duplicate strings 作优化用, 将重复的字符串合并在一起。
Standard stack frame 产生一个标准的栈结构。
Test stack overflow 产生一段程序运行时检测堆栈溢出的代码。
Line number 在.OBJ文件中放进行号以供调试时用。
OBJ debug information 在.OBJ文件中产生调试信息。
Optimization
Optimize for 选择是对程序小型化还是对程序速度进行优化处理。
Use register variable 用来选择是否允许使用寄存器变量。
Register optimization 尽可能使用寄存器变量以减少过多的取数操作。
Jump optimization 通过去除多余的跳转和调整循环与开关语句的办法, 压
缩代码。
Source
Indentifier length 说明标识符有效字符的个数, 默认为32个。
Nested comments 是否允许嵌套注释。
ANSI keywords only 是只允许ANSI关键字还是也允许Turbo C 2.0关键字
Error
Error stop after 多少个错误时停止编译, 默认为25个。
Warning stop after 多少个警告错误时停止编译, 默认为100个。
Display warning
Portability warning 移植性警告错误。
ANSI Violations 侵犯了ANSI关键字的警告错误。
Common error 常见的警告错误。
Less common error 少见的警告错误。
Names 用于改变段(segment)、 组( group) 和类(class)的名字, 默认值为
CODE,DATA,BSS。
.Linker (连接器)
本菜单设置有关连接的选择项, 它有以下内容:
Map file menu 选择是否产生.MAP文件。
Initialize segments 是否在连接时初始化没有初始化的段。
Devault libraries 是否在连接其它编译程序产生的目标文件时去寻找其缺省
库。
Graphics library 是否连接graphics库中的函数。
Warn duplicate symbols 当有重复符号时产生警告信息。
Stack warinig 是否让连接程序产生No stack的警告信息。
Case-sensitive link 是否区分大、小写字。
.Environment (环境)
本菜单规定是否对某些文件自动存盘及制表键和屏幕大小的设置
Message tracking
Current file 跟踪在编辑窗口中的文件错误。
All files 跟踪所有文件错误。
Off 不跟踪。
Keep message 编译前是否清除Message窗口中的信息。
Config auto save 选on时, 在Run, Shell或退出集成开发环境之前,如果Turbo
C 2.0的配置被改过, 则所做 的改动将存入配置文件中。选off时不存。
Edit auto save 是否在Run或Shell之前, 自动存储编辑的源文件。
Backup file 是否在源文件存盘时产生后备文件(.BAK文件)。
Tab size 设置制表键大小, 默认为8。
Zoomed windows 将现行活动窗口放大到整个屏幕, 其热键为F5。
Screen size 设置屏幕文本大小。
.Directories (路径)
规定编译、连接所需文件的路径, 有下列各项:
Include directories 包含文件的路径, 多个子目录用";"分开。
Library directories 库文件路径, 多个子目录用";"分开。
Output directoried 输出文件(.OBJ, .EXE, .MAP文件)的目录。
Turbo C directoried Turbo C 所在的目录。
Pick file name 定义加载的pick文件名, 如不定义则从current pick file中
取。
.Arguments (命令行参数)
允许用户使用命令行参数。
.Save options (存储配置)
保存所有选择的编译、连接、调试和项目到配置文件中, 缺省的配置文件为
TCCONFIG.TC。
.Retrive options 装入一个配置文件到TC中, TC将使用该文件的选择项。
Debug (调试)菜单
---按Alt+D可选择Debug菜单, 该菜单主要用于查错, 它包括以下内容:
.Evaluate
.Expression 要计算结果的表达式。
.Result 显示表达式的计算结果。
.New value 赋给新值。
.Call stack 该项不可接触。而在Turbo C debuger 时用于检查堆栈情况。
.Find function 在运行Turbo C debugger时用于显示规定的函数。
.Refresh display 如果编辑窗口偶然被用户窗口重写了可用此恢复编辑窗口的
内容。
Break/watch (断点及监视表达式)
---按Alt+B可进入Break/watch菜单, 该菜单有以下内容:
. Add watch 向监视窗口插入一监视表达式。
.Delete watch 从监视窗口中删除当前的监视表达式。
.Edit watch 在监视窗口中编辑一个监视表达式。
.Remove all watches 从监视窗口中删除所有的监视表达式。
.Toggle breakpoint 对光标所在的行设置或清除断点。
. Clear all breakpoints 清除所有断点。
. View next breakpoint 将光标移动到下一个断点处。
三、Turbo C 2.0的配置文件
所谓配置文件是包含Turbo C 2.0有关信息的文件, 其中存有编译、连接的选择
和路径等信息。可以用下述方法建立Turbo C 2.0的配置:
1. 建立用户自命名的配置文件
可以从Options菜单中选择Options/Save options命令, 将当前集成开发环境的
所有配置存入一个由用户命名的配置文件中。下次启动TC时只要在DOS下键入:
tc/c <用户命名的配置文件就会按这个配置文件中的内容作为Turbo C 2.0的选
择。
2. 若设置Options/Environment/Config auto save 为on, 则退出集成开发环境
时, 当前的设置会自动存放到Turbo C 2.0配置文件TCCONFIG.TC中。Turbo C 在
启动时会自动寻找这个配置文件。
3. 用TCINST设置Turbo C的有关配置, 并将结果存入TC.EXE中。Turbo C 在启动
时, 若没有找到配置文件, 则取TC.EXE中的缺省值。
--------------------------------------
随缘吧……
正文
C编译错误信息2007-02-13 12:29:00
【评论】 【打印】 【字体:大 中 小】 本文链接:http://blog.pfan.cn/redstar/23326.html
阅读(1819) | 评论(0)
版权声明:编程爱好者网站为此博客服务提供商,如本文牵涉到版权问题,编程爱好者网站不承担相关责任,如有版权问题请直接与本文作者联系解决。谢谢!
评论