文章目录
- 1.查看版本
- 2.程序的翻译
- 3.gcc指令
-
- [3.1gcc hello.c -o hello](#3.1gcc hello.c -o hello)
- [3.2gcc -E hello.c -o hello.i](#3.2gcc -E hello.c -o hello.i)
- [3.3gcc -S hello.c -o hello.s](#3.3gcc -S hello.c -o hello.s)
- [3.4gcc -c hello.c -o hello.o](#3.4gcc -c hello.c -o hello.o)
- [3.5gcc hello.o -o hello](#3.5gcc hello.o -o hello)
- 4.动静态库[详讲链接阶段]
1.查看版本
gcc -v
.
2.程序的翻译
3.gcc指令
3.1gcc hello.c -o hello
gcc hello.c -o hello
.将名为hello.c的源代码文件编译为可执行文件hello。编译后的可执行文件可以通过运行./hello
命令来执行。
gcc hello.c
.将名为hello.c的源代码文件编译为可执行文件a.out。编译后的可执行文件可以通过运行./a.out
命令来执行。
3.2gcc -E hello.c -o hello.i
-E: 进行程序编译 完成预处理后 停止编译
3.3gcc -S hello.c -o hello.s
-S: 从当前文件进行程序编译 完成编译阶段 停止编译
3.4gcc -c hello.c -o hello.o
-c: 从当前文件开始编译 完成汇编阶段 停止编译
3.5gcc hello.o -o hello
其余指令(了解)
-g 生成调试信息。GNU 调试器可利用该信息。
-shared 尽量使用动态库,生成文件较小[系统有动态库]
-O0/-O1/-O2/-O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高
-w 不生成任何警告信息。
-Wall 生成所有警告信息。
4.动静态库[详讲链接阶段]
4.1初步认识
链接方式:
- 动态链接--- 需要动态库
- 静态链接--- 需要静态库
头文件找声明 库里找实现 声明+实现+代码关联起来==>.exe
Linux: .so(动态库) .a(静态库)
Windows: .dll(动态库) .lib(静态库)
cpp
一些指令也是c语言写的
4.2动态链接
将当前程序会访问到的方法/接口的地址记录在可执行程序中 建立关联
依赖那个动态库 动态库出现错误 当前程序也会出现错误 但是会节省资源
在学校有些无聊 想要出去上网 问了学长网吧在大北街 从学校翻墙出去到网吧 为了方便逃跑让网管开一台靠窗的机器 结束之后 回到学校继续进行之后的愿望清单
这实际上就是动态链接的过程 那些能在学校里完成的事情 就好比你写的for/while 而printf这种无法在学校完成的库函数需要按照学长的指示去目的地找动态库(网吧)完成 这一来一回就是动态链接
4.3静态链接
将库里面该接口/方法的实现 直接拷贝一份在可执行程序中
举例: 想要上网 不再按照学长的指示去校外 而是买了一台ps5 自己在寝室写完作业当要玩游戏时就可以直接玩
相对动态链接 更安全一些 动态库是否出现错误不影响当前程序 但是可能会重复占用资源(100个含printf的程序同时运行)
cpp
我们的库在哪里呢?
云服务器下先下载
gcc/g++形成的可执行程序默认是动态链接的
ldd打印/查看程序运行所需的共享库,常用来解决程序因缺少某个库文件而不能运行的一些问题。ldd不是一个可执行程序,而只是一个shell脚本
如何调用静态库?
gcc hello.c -o sthello -static
.使用静态链接的方式形成可执行程序(大小是动态链接生成的可执行程序的十几/几十倍甚至更多)