TC 2.0 学习总结

转载 同时被 2 个专栏收录
282 篇文章 1 订阅
409 篇文章 4 订阅

《珍藏TC2.0》: TCC.exe,TLink.exe,TLib.exe 命令行选项及其使用!

http://blog.csdn.net/chenggil10/article/details/4176233
   
在开始看本文以前,我先说明一下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),目前国内大多为这种,(因为前段我将自己上传在269网络家园的TC2英文版推荐给十多家软件站),因此下载使用前请注意路径设置: 
设置方法为: OPTION->DIRECTORIES: 
INCLUDE: [TC2/3所在目录]/include 
LIB: [TC2/3所在目录]/lib 
output输出目录请自己设置一个工作目录,以免混在一起。 
最后还提醒一点:FILES中的Change dir(改变当前目录)中应设置为当前程序所在目录。 


一、C语言的起源 


C 语言是1972年由美国的Dennis Ritchie设计发明的, 并首次在UNIX操作系统 
的 DEC PDP-11 计算机上使用。 它由早期的编程语言 BCPL( Basic Combind 
Programming Language) 发展演变而来。在1970年, AT&T 贝尔实验室的 Ken 
Thompson根据BCPL语言设计出较先进的并取名为 B的语言, 最后导了C 语言的问世。 
随着微型计算机的日益普及, 出现了许多C 语言版本。由于没有统一的标准, 
使得这些C 语言之间出现了一些不一致的地方。为了改变这种情况, 美国国家标准 
研究所(ANSI)为C 语言制定了一套ANSI标准, 成为现行的C语言标准。 


二、C 语言的特点 


C 语言发展如此迅速, 而且成为最受欢迎的语言之一, 主要因为它具有强大的 
功能。许多著名的系统软件, 如DBASE Ⅲ PLUS、DBASE Ⅳ 都是由C 语言编写的。 
用C 语言加上一些汇编语言子程序, 就更能显示C 语言的优势了, 象PC- DOS 、 
WORDSTAR等就是用这种方法编写的。归纳起来C 语言具有下列特点: 
1. C是中级语言 
它把高级语言的基本结构和语句与低级语言的实用性结合起来。C 语言可以象 
汇编语言一样对位、字节和地址进行操作, 而这三者是计算机最基本的工作单元。 
2. C是结构式语言 
结构式语言的显著特点是代码及数据的分隔化, 即程序的各个部分除了必要的 
信息交流外彼此独立。这种结构化方式可使程序层次清晰, 便于使用、维护以及调 
试。C 语言是以函数形式提供给用户的, 这些函数可方便的调用, 并具有多种循 
环、条件语句控制程序流向, 从而使程序完全结构化。 
3. C语言功能齐全 
C 语言具有各种各样的数据类型, 并引入了指针概念, 可使程序效率更高。另 
外C 语言也具有强大的图形功能, 支持多种显示器和驱动器。而且计算功能、逻辑 
判断功能也比较强大, 可以实现决策目的。 
4. C语言适用范围大 
C 语言还有一个突出的优点就是适合于多种操作系统, 如DOS、UNIX,也适用于 
多种机型。 


三、 Turbo C 概述 


1 Turbo C 的产生与发展 


Turbo C 是美国Borland 公司的产品,Borland公司是一家专门从事软件开发、 
研制的大公司。该公司相继推出了一套 Turbo系列软件, 如Turbo BASIC, Turbo 
Pascal, Turbo Prolog, 这些软件很受用户欢迎。该公司在1987年首次推出Turbo 
C 1.0 产品, 其中使用了全然一新的集成开发环境, 即使用了一系列下拉式菜单, 
将文本编辑、程序编译、连接以及程序运行一体化, 大大方便了程序的开发。1988 
年, Borland 公司又推出Turbo C1.5版本, 增加了图形库和文本窗口函数库等, 而 
Turbo C 2.0 则是该公司1989年出版的。Turbo C2.0在原来集成开发环境的基础上 
增加了查错功能, 并可以在Tiny模式下直接生成.COM (数据、代码、堆栈处在同一 
64K 内存中) 文件。还可对数学协处理器 (支持8087/80287/80387等)进行仿真。 
Borland 公司后来又推出了面向对象的程序软件包Turbo C+ + , 它继承发展 
Turbo C 2.0 的集成开发环境, 并包含了面向对象的基本思想和设计方法。 
1991年为了适用Microsoft 公司的Windows 3.0 版本, Borland 公司又将Turbo 
C++ 作了更新, 即Turbo C 的新一代产品Borlandc C++也已经问世了。 




2 Turbo C 2.0基本配置要求 


Turbo C 2.0可运行于IBM-PC系列微机, 包括XT, AT及IBM 兼容机。 此时要求 
DOS 2.0或更高版本支持, 并至少需要448K的RAM, 可在任何彩、单色80列监视器上 
运行。支持数学协处理器芯片, 也可进行浮点仿真, 这将加快程序的执行。 


3 Turbo C 2.0内容简介 


Turbo C 2.0有六张低密软盘(或两张高密软盘)。下面对Turbo C 2.0的主要文 
件作一简单介绍: 
INSTALL.EXE 安装程序文件 
TC.EXE 集成编译 
TCINST.EXE 集成开发环境的配置设置程序 
TCHELP.TCH 帮助文件 
THELP.COM 读取TCHELP.TCH的驻留程序 
README 关于Turbo C的信息文件 
TCCONFIG.EXE 配置文件转换程序 
MAKE.EXE 项目管理工具 
TCC.EXE 命令行编译 
TLINK.EXE Turbo C系列连接器 
TLIB.EXE Turbo C系列库管理工具 
C0?.OBJ 不同模式启动代码 
C?.LIB 不同模式运行库 
GRAPHICS.LIB 图形库 
EMU.LIB 8087仿真库 
FP87.LIB 8087库 
*.H Turbo C头文件 
*.BGI 不同显示器图形驱动程序 
*.C Turbo C例行程序(源文件) 
其中: 上面的?分别为: 
T Tiny(微型模式) 
S Small(小模式) 
C Compact(紧凑模式) 
M Medium(中型模式) 
L Large(大模式) 
H Huge(巨大模式)




[[[四 重要文件的说明 


1, TCC.EXE 和 TC.EXE     


Turbo c包有两种编译器,集成开发环境下的叫做TC.EXE和命令行方式的叫做TCC.EXE. 
集成开发环境包括:集成编辑器、命令行编译器、连接器、调试器。


Trubo C的命令行编译连接 
所谓命令行编译,是指在dos下,调用Trubo C的tcc.exe程序.来完成对turbo C源程序的编译连接工作.当选择对后缀为*.asm的汇编程序文件编译时,tcc还要调用TASM后才能对后缀为.asm的文件进行编译,这种方式适合于c程序与汇编语言混合编程的编译连接,当c程序嵌入汇编指令时,也必须用此方法编译连接。 
命令行编译的格式为: 
tcc [选项1 选项2 ...]文件名1 文件名2...其中选项是指对后面给出的文件进行连接时的选择项,可选的常用选择项如下所示:每个选项前都带有"-"号,且大小写是区分的。文件名是指源文件.c或目标文件.obj或库文件.lib当不指定只编译不连接时,tcc将完成编译和连接两个步骤,对.lib库只进行形式上的连接,标准库用户不用进行连接。 
例如: 
tcc -ib:/include -lb:/lib -etest start.c body.obj myc当执行该命令时,表示将start.c源文件和body.obj目标文件及myc.c(命令行中该文件无后缀),分别进行编译(对body.obj文件不再编译),然后连接生成名为test的执行文件test.exe(由-test给出). 
-ib:/include 表示包含文件的路径是b:/include 
-ib:/lib 表示库文件的路径是b:/lib 
又例如: 
tcc -ms -efile -lc:/tc/lib file1 file2.obj graphics.lib 
其中-ms表示选择小内存模式进行编译,它也是turbo c的缺省编译模式,将file1进行编译,然后和file2.obj 及graphics.lib进行连接.生成file.exe的可执行文件.其中graphcis.lib库的路径为c:/tc/lib,即意为在c:/tc/lib目录下去寻找graphics.lib文件.当进行混合编程时,如果已有汇编程序s3.asm其命令行可写为 
tcc ic:/tc/include -lc:/tc/lib -mm s1 s2 s3.asm mylib.lib 
表示用中模式(-mm)编译源文件s1.c和s2.c,调用TASM对s3.asm进行编译,然后连接生成可执行文件s1.exe,编译时,到c:/tc/include目录中去找包含文件,到 
c:/tc/lib目录中去找库文件mylib.lib.


tcc的帮助: 
Turbo C Version 2.0 Copyright (c) 1987, 1988 Borland International 
Syntax is: TCC [ options ] file[s]       * = default; -x- = turn switch x off 
-1 80186/286 Instructions -A Disable non-ANSI extensions 
-B Compile via assembly -C Allow nested comments 
-Dxxx Define macro -Exxx Alternate assembler name 
-G Generate for speed -Ixxx Include files directory 
-K Default char is unsigned -Lxxx Libraries directory 
-M Generate link map -N Check stack overflow 
-O Optimize jumps -S Produce assembly output 
-Uxxx Undefine macro -Z Optimize register usage 
-a Generate word alignment -c Compile only 
-d Merge duplicate strings -exxx Executable file name 
-f * Floating point emulator -f87 8087 floating point 
-gN Stop after N warnings -iN Maximum identifier length N 
-jN Stop after N errors -k Standard stack frame 
-lx Pass option x to linker -mc Compact Model 
-mh Huge Model -ml Large Model 
-mm Medium Model -ms * Small Model 
-mt Tiny Model -nxxx Output file directory 
-oxxx Object file name -p Pascal calls 
-r * Register variables -u * Underscores on externs 
-v Source level debugging -w Enable all warnings 
-wxxx Enable warning xxx -w-xxx Disable warning xxx 
-y Produce line number info -zxxx Set segment names


2, TLINK.EXE 为连接程序,把各个obj文件连接程exe文件 


    obj文件是什么? 
    目标文件,其内容为 完成某种功能的代码,只不过存储的机器码. 
    可以这样理解 目标文件 即为 子程序或子函数 
    tlink.exe作用是什么? 
    把 启动代码(也是obj文件,负责设置环境,调用main函数,等作用) + main函数所在obj +main函数所用到的obj 连接起来生成exe文件. 


3, TLIB.EXE 对lib文件进行操作的一个工具. 


    lib文件是什么? 
    obj文件的集合,可以使用tlib.exe 从lib文件中取出obj文件,向lib文件加入obj文件,等操作 


4, *.h文件 
    在include文件夹中包含了turbo c提供的库函数说明,只是说明而已 
    如果用户需要使用某个函数功能,需要把对应的头文件包含进来 
    当然用户可以定义自己头文件 


5, 设置路径 


    TC集成开发环境中设置 Options/Directories下设置 include,lib路径 
    使用命令行编译的话 需要对TURBOC.CFG文件进行编辑就可以了(使用纯文本编辑器就可以) 


[[[[五 建造自己的编辑环境 


这个过程,实际上是为了了解turbo c对c语言的编译,连接过程.并加深对编译,连接,obj,lib的理解 
建立一个新的文件夹(以后用到什么,则从tc下拷贝过来) 
1   使用dos自带的edit编辑器 
2   使用tcc作为编译器 
3   使用tlink作为连接器 
实际上还是需要其他文件比如 c0s.obj ,cs.lib,等 
例子: 对a.c进行编译连接 
编译:tcc -c a.c         //只对a.c进行编译 生成a.obj 
连接:tlink c0s a,a,,cs    //把 启动代码 和 a的代码 连接起来,这个过      程中还需要用到cs.lib中的一些代码 


也可以 tcc a.c   同时完成编译连接 
注意:在使用到图形库的时候,需要把graphics.lib显示输入,例如:tcc a.c graphics.lib 


写个程序,看看是否可以编译,连接成功? 
大家可以试试 


[[[[六 说明 
献给开始学习c语言的朋友 
文章1,2,3部分 取自网上资料 
推荐文章:http://www.3800hk.com/Article/cxsj/cjing/jcjccj/2005-08-06/Article_18835.html 


四、 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 C 2.0时, 只要在TC 子目录下键入TC并回车即可进入Turbo C 2. 0 
集成开发环境。 




五、 Turbo C 2.0集成开发环境的使用 


进入Turbo C 2.0集成开发环境中后, 屏幕上显示: 
────────────────────────────── 
File Edit Run Compile Project Options Debug Break/watch 
┌────────────Edit──────────────┐ 
│ 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加上某项中第一个字母(即大写字 
母), 就可进入该项的子菜单中。 
(1)、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所有菜单均采用这种方法进行操作, 以下不再说明。 
(2)、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的双界符包括以下几种符号: 
花括符 {和} 
尖括符 <和> 
圆括符 (和) 
方括符 [和] 
注释符 /*和*/ 
双引号 " 
单引号 ' 
b. Turbo C 2.0在编辑文件时还有一种功能, 就是能够自动缩进, 即光标定位 
和上一个非空字符对齐。在编辑窗口中, Ctrl+OL为自动缩进开关的控制键。 
(3)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。 


(4)、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(获得有关当前路径、源文件名、源文件字节大小、编译中的错误数 
目、可用空间等信息。 
(5)、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(删除信息) 
把错误信息从信息窗口中清除掉。 
(6)、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将使用该文件的选择项。 
(7)、Debug(调试)菜单 
按Alt+D可选择Debug菜单, 该菜单主要用于查错, 它包括以下内容: 
Evaluate 
Expression 要计算结果的表达式。 
Result 显示表达式的计算结果。 
New value 赋给新值。 
Call stack 该项不可接触。而在Turbo C debuger 时用于检 
查堆栈情况。 
Find function 在运行Turbo C debugger时用于显示规定的函数。 
Refresh display 如果编辑窗口偶然被用户窗口重写了可用此恢复 
编辑窗口的内容。 


(8)、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中的缺省值。
========

关于tcc、tlink的编译链接机制的研究

http://www.mamicode.com/info-detail-505191.html


1、学习过程


在c:\下建立文件夹c,并将编译器tcc.exe、连接器tlink.exe、相关文件c0s.obj、cs.lib、emu.lib、maths.lib放入文件夹中。


要搭建一个简单的C语言编译环境,需要TC2.0、c0s.obj、emu.lib、maths.lib、graphics.lib、cs.lib文件。而这里用编译器tcc.exe、连接器tlink.exe代替了TC2.0,而且相关文件也少了graphics.lib,为什么这样也可以呢?我们先尝试在新建立的环境下编译连接一个文件:


用命令“tcc hello.c”编译连接生成文件hello.obj和hello.exe:


运行结果为:


在编译连接过程中,第一次我用tcc hello.c编译,发现只生成了hello.obj文件,然后我又用tlink hello.obj连接生成hello.exe文件,结果发现运行这个exe文件会出错。经过检查后发现,我把相关文件里的maths.lib错误地复制成了mathl.lib,可能在连接文件时发生了错误,导致exe文件出错。


那么这个环境与之前的环境相比,少了TC2.0、graphics.lib,多了tcc.exe、tlink.exe。在网上查阅资料发现graphics.lib是一个c语言图形库,TC2.0连接需要这个而tcc.exe不需要,我们可以理解为tc2.0在tcc.exe的基础上多了这么一个扩展,每一个库文件都相当于一个小模块,支持一种扩展。我们需要的时候,只需要添加相应的库文件就行了。


从功能上来看,tcc.exe只能从cmd编译当前目录下已存在的文件,而TC2.0则支持文件的创建、修改、保存、编译、连接,是集成了tcc.exe和tlink.exe的一个c语言小型开发平台。


那么既然新建立的环境将所需要的相关文件减少到了4个,那么是不是还可以减少呢?经过实验,我发现不论去掉哪一种相关文件,在编译时都会出错,生成一个错误的hello.obj文件,并且cmd会有相似的提示:


所以我们可以断定,在该环境下,4个相关文件必须都在才能保证编译的成功。


补充研究:在网上查询资料发现,TC2.0是一个集成的开发环境,它集成了以下文件:


INSTALL.EXE 安装程序文件


TC.EXE 集成编译 


TCINST.EXE 集成开发环境的配置设置程序


TCHELP.TCH 帮助文件 


THELP.COM 读取


TCHELP.TCH的驻留程序


README 关于Turbo C的信息文件 


TCCONFIG.EXE 配置文件转换程序


MAKE.EXE 项目管理工具


TCC.EXE 命令行编译


TLINK.EXE Turbo C系列连接器


TLIB.EXE Turbo C系列库管理工具


C0?.OBJ 不同模式启动代码


C?.LIB 不同模式运行库


GRAPHICS.LIB 图形库 


EMU.LIB 8087仿真库


FP87.LIB 8087库


*.H Turbo C头文件


*.BGI 不同显示器图形驱动程序 


*.C Turbo C例行程序(源文件) 


其中: 上面的?分别为: 


T Tiny(微型模式) 


S Small(小模式) 


C Compact(紧凑模式) 


M Medium(中型模式) 


L Large(大模式) 


H Huge(巨大模式)


这个在TC的安装文件夹里其实也可以看出来:


 技术分享


但是我们之前的研究发现只需要需要TC2.0就可以成功编译文件,而不需要tcc.exe也在目录下,所以TC2.0是把tcc.exe集成在自己的文件内部的,而不是对外部的编译器进行调用。


查看tcc.exe的功能:


可以看到tcc的命令格式是:tcc [选项] [文件名]


缺少正确的相关文件会对编译造成怎样的影响呢?我先用完整的相关文件进行编译,生成的exe文件有8kb,而删去cs.lib后进行编译,发现生成的exe文件只有536字节,比正确的文件要小得多,所以我认为在用tlink进行连接时因为相关文件的缺失导致有很大一部分相关文件都没有连接进来。


在网上查阅资料发现启动代码有T Tiny(微型模式) 、S Small(小模式)、C Compact(紧凑模式) 、M Medium(中型模式) 、L Large(大模式) 、H Huge(巨大模式),那么分别对应的相关文件应该为:c0t.obj,ct.lib,c0s.obj,cs.lib...果然,我们在TC2.0的lib库里发现了相关文件;




我发现,其他的模式都有对应的c0*.obj和c*.lib文件,而微型模式只有c0t.obj文件,这是为什么呢?是该模式的编译特性决定他们只要用一个文件吗?我们来试试是否可以编译成功,将c0t.obj拷贝到c:\c文件夹下,再用tcc -mt hello.c编译,发现可以编译连接成功,生成的exe文件也能成功运行,所以微型模式的编译是不需要特定的lib文件,这说明微型模式在编译时不需要向文件里面加入专门的库函数。




要实现打印出子函数的段地址和偏移地址,首先要知道,子函数的段地址和偏移地址放在哪里。我们在《20140426_综合研究2研究报告》中发现:(1)函数的名字就代表它的偏移地址。(2)函数的调用在汇编里是采用call-ret方法实现的。另外我们知道汇编中存储当前段地址的寄存器为CS寄存器。


首先填充main函数,分别打印每一个函数的偏移地址,以及运行函数后CS寄存器的值:




显示结果为:




发现main函数的偏移地址为21b,f1的偏移地址为1fa,f2的偏移地址为205,f3的偏移地址为210,cs寄存器的一直为1a2.那么CS里的值真的是子函数的段地址的值吗?我们用debug加载程序:


发现main()、f1()、f2()、f3()的偏移地址是对的。但是段地址应为076a而不是打印出来的CS寄存器的值1a2。


如果用长整形将main函数和f1的值全部打印出来:




则段地址还是1a2。但是用debug查看并不一样。那么问题在哪里呢?


在网上查看,发现有一个相似问题的解释是这样的:“调试的情况下 是用调试器来实对 单步 断点异常的处理。加载了更多的函数。 当然地址会不一样了。”


我觉得可能是直接运行和debug调试分配的内存空间不一样,如上所说,debug调试要加载更多的函数,所以main函数的段地址会相对较大。


但是这里是子函数和main函数在一个段里,所以子函数的段地址可以在主函数里用_CS


表示,如果子函数和main函数不在一个段里呢?我们知道:用tcc hello.c生成的文件可有两个段,一个为代码段,一个为栈和数据段。所以子函数和主函数都要在同一个代码段里。那么如果代码量超过64kb,一个段存放不下,怎么办?在网上查阅资料如下:


C 语言中提供了6种编译模式,这6种模式是:


微模式(Tiny),小模式(Small),中模式(Medium),紧凑模式(Compact),大模式(Large)和巨模式(Huge)。它们之间的关系如下图所示。用户可以按照自己的程序大小及需要进行选择。
      │ 小程序   │ 大程序
  ━━━━┿━━━━━━┿━━━━━━━━
   小数据 │ 微,小   │ 中
   大数据 │ 紧凑    │ 大,巨




  所谓小程序就是指程序只有一个程序段,大小不超过64KB,缺省的码(函数)指针是near(近程指针)。所谓大程序就是指程序只有多个程序段,每个程序段不超过64KB,但总程序量可超过64KB,缺省的码指针是far(远程指针)。小数据就是指数据只有一个数据段,缺省的数据指针是near。大数据就是指数据有多个数据段,缺省的数据指针是far。


由上可知,我们所说的只有一个代码段的程序是小程序,它的代码不超过64kb,在编译时会以默认的编译模式:小模式来编译。即前面研究里所说的tcc a.c生成的exe文件有一个代码段,一个栈和数据段就可以理解了。我们用TC2.0的时候不可缺少的相关文件里有关编译模式的是c0s.obj和cs.lib,所以TC2.0默认的编译模式是小模式。所以默认的编译只能编译代码量不超过64kb的文件。 


关于不同模式的区别,查询资料如下:


C语言编译模式—微模式(Tiny)
    在微模式下程序中的数据及代码均放在同一段内,即它们不超过 64KB。在微模式下代码段、堆栈段和数据段的段地址均相同,即CS=DS=SS=ES。在微模式下,数据指针都是 near,一般小程序可采用此编译模式进行编译。还可用 DOS 中的 EXE2BIN 转换程序将.EXE 程序转换成.COM 程序。代码段、数据段和堆栈段均在同一段内,对它们进行寻址时,均以同一地址偏移的参考点,具有这种特点的段又称为属于同一组段(DGROUP),栈是向上生长的,即每压栈一次,栈指针SP减2,即向地址减少的方向移动,它开始的初始值指向栈底,即0xffff(64KB)。堆是向下生长的,即向增加地址的方向改变。堆和栈地址相向生长,当两者未相遇时,便出现了自由空间。一般程序均是这种状态,当占用栈地址较多时,两者可能重合并覆盖部分堆空间。


C语言编译模式—小模式(Small)
在小模式下,程序中的代码放在64KB的代码段内,数据放在64KB的数据段内。在小模式下,栈段、附加数据段和数据段均指向同一地址,它们合三为一,即DS=SS=ES,指针都是near,一般程序均采用小模式编译。在小模式下,内存分配如下图所示。从图中可以看出数据段、堆栈段和附加段为同一段组,即它们的偏移地址均以同一段地址为参考点。


C语言编译模式—中模式(Medium)
在中模式下,所有数据放在64KB的数据段内,因而数据段内使用near,代码量可以大于64KB(允许达到1MB),因而可以在不同的代码段内,代码段使用(far远程指针)。这种编译模式适用于大代码量、小数据量的大程序。中模式下的内存分配如下图所示。


C语言编译模式—紧凑模式(Compact)


在紧凑模式下,数据量超过64KB时,可放在多个数据段中,数据段内的指针是(far)。代码量不超过64KB时,可在一个段内,因而代码段内指针为近程的(near)。但在该模式下,静态数据仍不能超过64KB,堆用far指针来存取。紧凑模式下的内存结构如下图所示。




C语言编译模式—大模式(Large)


大模式下,代码及数据均采用far指针,且都可达到1MB。静态数据仍跟紧凑模式一样,不能超过64KB。大模式下的内存结构如下图所示。


C语言编译模式—巨模式(Huge)


巨模式下,代码段及数据段均用far指针,代码分布在不同的代码段内,数据也分布在不同的数据段内,它们来自不同的源程序,大堆栈只有一个。而且静态数据大小允许超过64KB。巨模式下的内存结构如下图所示。


即不同模式的区别在于可编译的代码量和数据量不一样。那么在编译的时候对于超过64kb的文件该如何选择编译模式呢?


无论采用哪一种编译模式,C 源程序编译生成的代码和数据量都不能超过64KB,对于超过的源程序,可以视代码或数据多少将其分解成两个或多个程序分别编译。大代码量程序要选用大代码编译模式(中模式、大模式和巨模式),大数据量程序应选用大数据编译模式(紧凑模式、大模式和巨模式),这样编译生成的.obj 文件将会带给连接程序信息,将代码和数据安排在不同段内。这样生成的.exe 文件在加载时将告诉 DOS 该程序应如何装入代码段和数据段,如何初始化寄存器。这样,就可确定在不同编译模式下开辟数据区的大小,即大于64KB,或不超过64KB。


 
2、解决的问题


   (1)TC2.0集成了tcc.exe、tlink.exe,并且包含了更多的功能。而tcc.exe、tlink.exe、c0s.obj、cs.lib、emu.lib、maths.lib是编译c文件必不可少的文件。


(2)怎么打印所有函数的段地址和偏移地址?


答:可以用printf(“%lx”,(long)函数名);来打印,这样段地址和偏移地址是连在一起的,也可以用printf(“%x     %x”,_CS,函数名);来打印,这样段地址和偏移地址是分开的。


   (3)为什么输出的段地址和debug调试的段地址不一样?


答:debug调试要加载更多的函数,所以main函数的段地址会相对较大。


   (4)用tcc hello.c生成的文件可有两个段,一个为代码段,一个为栈和数据段。所以子函数和主函数都要在同一个代码段里。那么如果代码量超过64kb,一个段存放不下,怎么办?


答:那应该使用别的内存编译模式,TC下默认的模式是小模式,只支持64kb以下的代码和数据,若代码和数据超过64kb,可以使用大模式或者巨模式。


3、研讨会解决的问题


   (1)如果缺少相关文件,tcc.exe会调用tlink.exe吗?生成的obj文件是含有其他相关文件吗?


答:根据讨论,如果缺少相关文件,tcc.exe调用了tlink.exe但是无法找到文件,需要再用tlink.exe来连接obj文件,生成exe文件。如果缺少相关文件,tlink会连接其他相关文件。经过实验,如果缺少maths.lib,程序能够输出helloworld,而如果缺少c0s.obj或者cs.lib编译成的exe文件就会运行出错,这是因为maths.lib是运算相关的库,如果程序里没有运算的话,即使缺少也不影响程序的执行,而c0s.obj或者cs.lib是程序启动运行所需要的文件,所以一旦缺少就会出错。


修改:经过再次的实验,我发现缺少maths.lib文件,编译连接生成的exe文件也会显示出错,这说明之前的结论是不成立的。tcc.exe的功能是把c源文件编译成二进制obj文件,再调用tlink.exe进行连接生成exe文件。即只要执行一条命令就能把c源文件编译连接成可执行的exe文件。我们没有改变tcc.exe文件的内容,那么tcc还是会调用tlink,只是因为相关文件不全而出错导致tlink没有正确执行连接而已。实验发现先用tcc -c hello.c或者tcc -linclude hello.c将源文件编译成obj文件,再连接成exe文件还是执行出错,在网上有资料说这样编译连接会导致返回错误,但没有说明具体原因。我觉得可能单独用tlink连接hello.obj会在调用相关文件上出错,就是说tlink没有调用相关文件的能力,只是tcc调用它的时候告诉它应该按什么顺序来连接,它才能正常连接。但是这个猜想和上面的问题一样,我暂时还找不到方法和资料来验证,希望学长能在衍生课上讲一讲,具体的问题是这样的:


如果缺少相关文件,生成的obj文件是含有其他相关文件吗?为什么一定要tcc.exe调用tlink.exe才能生成正确的可执行文件?


(2)为何在原来的平台上即使没有tcc和tlink也能够编译链接成功。


答:TC2.0集成有多种编译器,c语言和汇编语言是可以混合编译的。如果出现汇编语言,那么TC2.0就会调用tcc.exe来进行编译。Turbo c包有两种编译器,集成开发环境下的叫做TC.EXE和命令行方式的叫做TCC.EXE. 集成开发环境包括:集成编辑器、命令行编译器、连接器、调试器。


(3)库文件是怎么搜索的?


答:在turboc.CFG中可以指定tcc可以用来搜索的库文件的位置。但是用TC2.0修改路径不会保存在turboc.CFG中,而是生成另一个配置文件。


(4)三种模式,是否可以互相的替换


答:其实c语言编译有6种模式,这6种模式编译的结果都是一样的,只是支持的数据大小和程序大小不一样。


(5)为何打印出来的段地址的值和用debug调试的时候出来的地址的值是不一样的?


答:编译时给定了偏移地址,载入时cmd或者debug再给定段地址,所以段地址不一样。


(6)假如代码量超过了64K后,会如何?


答:那么就不能用默认的内存编译模式(小模式)来编译,会出错。应该用支持大程序的模式来编译(如中模式、大模式、巨模式)。编译器会把代码分成几个不超过64kb的程序来编译。


(7)为什么打印出来的偏移地址改变,在平常的时候main函数的偏移地址是1fa但是此时的main函数的偏移地址不是这样的了?


答:主函数的偏移地址不一定是1fa,而是第一个程序的偏移地址是1fa。之后函数的偏移地址按程序的长度发生变化。其实原理和汇编语言里不同段的地址不同是一样的。C0s.Obj里的函数加载完后正好到了1fa处应该加载源文件的内容了,这时那个函数在第一个就把哪个函数放在1fa处。


(8)如何用一条语句打印出段地址和偏移地址。


答:可以用printf(“%lx”,main);打印出段地址和偏移地址。


4、学习感想


其实TC2.0也是别人写的方便开发者使用的一个程序。它是调用了tcc.exe、tlink.exe和一些库文件来实现程序的编译连接,而更高级的开发工具只是编写的功能更全、调用的文件更多、采用更高级的编译器和连接器而已。它们都是由这一个小小的tcc.exe衍生开的。庞大的、复杂的事物,其实可能起核心作用的就是那么一点点东西而已。


========


Windows下用TCC编译Lua源码

http://demon.tw/software/compile-lua-with-tcc.html


心血来潮研究了一下怎么用TCC源码编译Lua。


花了些时间阅读TCC和Lua的帮助文档,得到下面的批处理build-lua.bat:


@echo off
rem Author: Demon
rem Date: 2012/6/2
rem Website: http://demon.tw
set INSTALL_TOP=C:\Lua
set INSTALL_BIN=%INSTALL_TOP%\bin
set INSTALL_INC=%INSTALL_TOP%\include
set INSTALL_LIB=%INSTALL_TOP%\lib
if not exist %INSTALL_BIN% mkdir %INSTALL_BIN%
if not exist %INSTALL_INC% mkdir %INSTALL_INC%
if not exist %INSTALL_LIB% mkdir %INSTALL_LIB%


cd src
tcc -r -o liblua.a lapi.c lcode.c lctype.c ldebug.c ldo.c ldump.c lfunc.c lgc.c llex.c lmem.c lobject.c lopcodes.c lparser.c lstate.c lstring.c ltable.c ltm.c lundump.c lvm.c lzio.c lauxlib.c lbaselib.c lbitlib.c lcorolib.c ldblib.c liolib.c lmathlib.c loslib.c lstrlib.c ltablib.c loadlib.c linit.c
tcc -o lua.exe liblua.a lua.c
tcc -o luac.exe liblua.a luac.c


>nul copy lua.exe  %INSTALL_BIN%
>nul copy luac.exe %INSTALL_BIN%
>nul copy liblua.a %INSTALL_LIB%
for %%i in (lua.h luaconf.h lualib.h lauxlib.h lua.hpp) do (
>nul copy %%i %INSTALL_INC%
)
%INSTALL_BIN%\lua.exe -i
将其保存到Lua源码的根目录,运行即可。批处理水平不高,写得不好的地方请不要见笑。
========
  • 2
    点赞
  • 0
    评论
  • 7
    收藏
  • 扫一扫,分享海报

©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值