1. 翻译环境
在这个环境中源代码被转换为可执行的机器指令。
在符号表中只能看到全局的符号
编译阶段各源文件被独立编译生成目标文件(.o ),每个目标文件有自己符号表,链接阶段会将这些符号表合并汇总处理,以便解析符号引用等
2. 运行环境
它用于实际执行代码
程序执行的过程:
1. 程序必须载入内存中。在有操作系统的环境中:一般这个由操作系统完成。在独立的环境中,程序的载入必须由手工安排,也可能是通过可执行代码置入只读内存来完成。(点击一次exe文件就相当于载入内存,给小车下载代码也相当于载入内存)
2. 程序的执行便开始。接着便调用main函数。
3. 开始执行程序代码。这个时候程序将使用一个运行时堆栈(stack),存储函数的局部变量和返回地址。程序同时也可以使用静态(static)内存,存储于静态内存中的变量在程序的整个执行过程一直保留他们的值。
4. 终止程序。正常终止main函数;也有可能是意外终止。
3. 预处理详解
这些预定义符号都是语言内置的
切记不要加分号
用于对数值表达式进行求值的宏定义都应该加上括号,避免在使用宏时由于参数中的操作符或邻近操作符之间不可预料的相互作用
注意事项2:
##可以把位于它两边的符号合成一个符号。它允许宏定义从分离的文本片段创建标识符
注:
这样的连接必须产生一个合法的标识符。否则其结果就是未定义的
宏和函数对比:
宏通常被应用于执行简单的运算
比如在两个数中找出较大的一个:
一般功能简单的代码用宏定义,复杂的用函数包装
文件包含:
嵌套文件包含:
comm.h和comm.c是公共模块。
test1.h和test1.c使用了公共模块。
test2.h和test2.c使用了公共模块。
test.h和test.c使用了test1模块和test2模块。
这样最终程序中就会出现两份comm.h的内容。这样就造成了文件内容的重复。
如何解决这个问题那:
第二种就是直接在源文件的开头加入#pragma once
这算是我自己的笔记吧,还有命令行定义和条件编译我没写,想了解的参考《C语言深度解剖》学习