C语言综合研究1

搭建一个tcc环境

研究过程:

问题引出:为什么要使用tcc环境,甚至连图形界面都没有,为什么要使用这样的化境?

按照我们学习的本质来讲,可能是为了体验C语言底层的相关特性,但是在研究1中尚不能体会这点,所以这个问题待后续回答

我们将相关文件放到DOS环境下的C盘中去,用记事本书写一个简单的c程序。

使用c:\c\tcc a.c命令打算对.c文件进行编译。

发现,提示错误:不能找到a.c文件。

那么应该是无法识别路径,或者是相关的问题?那么推测是,难道tcc  环境在工作的时候需要一个索引路径的文件支持?

随即我们使用了诸如 minic\tc c\a.c.发现可以找到a,c文件并打开它,于是得出结论,路径问题并不由tcc来决定,而是由操作系统DOS决定。虽然考虑到这一点,但是仍不知道怎么做,于是百度

最终知道应该 用 cd c\命令使目录更改为C:\C>

这样顺利的编译连接生成a.exe文件。

但是仍不知道这样做的原因是是什么 为什么tc的时候就没有这个问题。

之后处于好奇心,将tlink.exe删除,发现只能能够生成.obj文件,但是不能生成.exe文件,如果不删除tlink.exe发现可以直接生成.exe文件,这说明了tcc.exe程序有调用tlink.exe程序的作用,而其本身能够实现编译功能。

又做了如下尝试,算是对之前研究的回忆,在tlink.exe删除后,删除了其他必要文件,发现仍让能够生成.obj文件,说明这些文件在编译阶段不是必须的,而这个再次说明了什么是:连接!

做完这些工作,运行生成的.exe文件,显示了“hello world!”。

已解决:

1.通过这个研究做到了最基本的事情,搭建一个tcc环境并对.c文件进行编译连接生成.exe文件。

2.认识到了tcc负责生成.obj文件,tlink负责生成.exe文件,但tcc会调用tlink 文件。

3.对之前的研究进行回顾,进一步认识了“编译”,“连接”这个概念

未解决:

1.tcc甚至连图形界面都没有,我们为什么使用tcc?

2.教材所说的有两个最大64K的段,试问如何验证?以及,这个是什么意思?

感悟:

通过建立tcc环境,实现了对.c文件的编译连接,总体来说tcc比tc少了很多文件,这对于我们研究c语言是极其有帮助的,可以让我们抓住一些更为核心的东西,而忽略那些目前阶段不需要了解的东西。

stay foolish,stay hungry