回 帖 发 新 帖 刷新版面

主题:[转帖]Turbo C 2.0集成开发环境的使用(2)

此命令生成一个.EXE的文件, 并显示生成的.EXE文件名。其中.EXE文件名是下
面几项之一。
    1. 由Project/Project name说明的项目文件名。
    2. 若没有项目文件名, 则由Primary C file说明的源文件。
    3. 若以上两项都没有文件名, 则为当前窗口的文件名。
    .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(删除信息)
    把错误信息从信息窗口中清除掉。sp;    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
    六、Options(选择菜单)
    按Alt+O可进入Options菜单, 该菜单对初学者来说要谨慎使用。
    .Compiler(编译器)
    本项选择又有许多子菜单, 可以让用户选择硬件配置、存储模型、调试技术、
代码优化、对话信息控制和宏定义。这些子菜单如下:
    Model
    共有Tiny, small, medium, compact, large, huge 六种不同模式可由同户选
择。
    Define
    打开一个宏定义框, 同户可输入宏定义。多重定义可同分号, 赋值可用等号。
    Code generation;                如果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      将光标移动到下一个断点处。

  

    1.5.2 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中的缺省值。  
    它又有许多任选项, 这些任选项告诉编译器产生什么样的目标代码。
     Calling convention  可选择C或Pascal方式传递参数。




转载自:http://www.yzcc.com

回复列表 (共5个回复)

沙发

您好 我想请问个问题  
  

关于turbo设置的一个 简单的问题


每次编译成功后一连接就会出现这么个错误:
link error:unable to open input file'cos.obj'


请问这是怎么回事呢 那个目录我也是设置正确的

谢谢

板凳

这个是你的TC2中工作目录没有对。

在TC2中FILE->CHANGE DIR

改为你源代码所在目录

3 楼

我有个C程序  出现了40条警告信息
C:\Documents and Settings\wwwfox\×&Agrave;&Atilde;&aelig;\he1.c(40) : warning C4047: '=' : 'struct list *' differs in levels of indirection from 'int '


d Settings\wwwfox\×&Agrave;&Atilde;&aelig;\he1.c(98) : warning C4013: 'strdup' undefined; assuming extern returning int

'reverse' undefined; assuming extern returning int
C:\Documents and Settings\wwwfox\×&Agrave;&Atilde;&aelig;\he1.c(198) : warning C4013: 'strlen' undefined; assuming extern returning int
C:\Documents and Settings\wwwfox\×&Agrave;&Atilde;&aelig;\he1.c(203) : warning C4033: 'reverse' must return a value[em18][em18]

4 楼

看错误类型,应该是一些类型警告。建议贴出源程序。

你用的VC6?

5 楼

请看MSDN上的解释,注意例子:

Compiler Warning (level 1) C4047


'identifier1' : 'operator' : different levels of indirection from 'identifier2'

Indirection refers to accessing a variable through a pointer. Just as a pointer can refer, or point, to a variable (one level of indirection), a pointer can also point to another pointer that, in turn, points to a variable (two levels of indirection). Because two pointers that have different levels of indirection possibly refer to two different things (one could be pointing to a variable, while the other could be pointing to another pointer), the compiler issues warning C4047 whenever you include such pointers in an expression.

For example, the following code generates this warning but is compiled without change:

void main() {
    char **p;// two levels of indirection
    char *q; // one level of indirection
    p = q;   // warning C4047
}



Compiler Warning (level 3) C4013
'function' undefined; assuming extern returning int

An undefined function was called. The compiler assumed an external function that returned an int type.

Make sure that the function name is spelled correctly. All external functions should be prototyped as extern.







Compiler Warning (level 1) C4033
'function' must return a value

The given function did not return a value.

Only functions with a return type of void can use the return command without an accompanying return value.

An undefined value will be returned when this function is called.








也就是说:

C4047警告是:一重指针和二重指针互相赋值时,会出现的警告;
C4013警告是:你的“strdup”,“revers”,“strlen”函数没有定义,建议包含string。h
C4033警告是:你的“revers”函数应该有个返回值


我来回复

您尚未登录,请登录后再回复。点此登录或注册