1.操作演示
新建.c类型的文件并打开:
panda@Panda:~$ vim a.c
然后保存退出当前程序。
用gcc编译该程序,如果无报错则会生成可执行文件:
panda@Panda:~$ gcc -o a a.c
用ls命令查看,生成了一个名为a的可执行文件,运行该文件:
panda@Panda:~$ ./a
2. gcc使用
编译命令格式:
gcc [-option] 生成的文件名 源文件名;
g++ [-option] 生成的文件名 源文件名;
备注:文件名可以包含文件的绝对路径,也可以使用相对路径;
如果命令中不包含输出可执行文件的文件名,则会生成一个默认的,linux平台为a.out,windows平台为 a.exe;
参数选项
-E 只进行预处理;
-S 只进行预处理和编译;
-c 只进行预处理、编译和汇编;
-o file 指定生成的输出文件名为file;
3.C语言编译过程
分布编译:
预处理 :gcc -E hello.c -o hello.i,该步完成宏定义展开、头文件展开、条件编译等,同时将代码中的注释删除,这里不会检查语法;
编译:gcc -S hello.i -o hello.s,检查语法,将预处理后的文件编译生成汇编文件;
汇编:gcc -c hello.s -o hello.o,将汇编文件生成目标二进制文件;
链接:gcc hello.o -o hello_elf,c语言写的程序是需要依赖各种库的,所以编译之后还需要把库链接到最终的可执行程序中去。
4.程序执行过程
内存四区:代码区、数据区、栈区和堆区;
中央处理器:运算器、控制器和寄存器;