linux基本命令以及库文件

一、linux命令

关于前后台任务切换:

  1. bg % + 任务号
  2. fg % + 任务号
  3. jobs :查看后台运行的进程
    在这里插入图片描述

批量结束进程: pkill + 进程名

在这里插入图片描述
监测系统运行状态: top
在这里插入图片描述
vim常用配置:

set nu
set tabstop=4
set softtabstop=4
set shiftwidth=4
set expandtab
set smartindent
set hlsearch

将文件打包或解包: tar + 参数 + 文件名
在这里插入图片描述
在这里插入图片描述
解压并拆包
在这里插入图片描述

将文件压缩或解压

压缩: gzip + 包名
解压: gzip -d + 包名
在这里插入图片描述

二、gcc

在这里插入图片描述
在这里插入图片描述
如果我们在cpp文件中用到IO流或者STL容器,gcc无法编译通过,因为gcc默认链接libc.so,而g++默认链接libc++.so

而g++是支持C语法的,可以编译C文件

main.c
在这里插入图片描述
预处理
在这里插入图片描述在这里插入图片描述
gcc -E main.c -o main.i :生成预编译文件,进行头文件引入以及宏替换,同时清理注释

main.i
在这里插入图片描述
编译

编译过程就是把预处理完的文件进行一系列词法分析、语法分析、语义分析及优化后生产相应的汇编文件,这个给过程往往是我们所说的整个程序构建的核心部分,也是最复杂的部分之一。

gcc -S main.i -o main.s:编译文件,生成汇编代码
在这里插入图片描述
汇编
在这里插入图片描述

gcc -c main.s -o main.o:汇编,生成机器指令
在这里插入图片描述
链接

此时生成的main.o只占可执行程序main的一部分,还需要再链接别的库,分配符号虚拟地址。多个.o文件整合,合并各个段。

gcc main.o -o main:链接其他文件,生成最后的可执行文件
在这里插入图片描述

三、使用makefile文件进行管理

main.c
在这里插入图片描述
foo.h
在这里插入图片描述

安装make: apt install make

编写makefile文件
在这里插入图片描述

make执行
在这里插入图片描述
清理文件
在这里插入图片描述
修改add.c后进行make
在这里插入图片描述

四、使用gdb调试程序

在这里插入图片描述

  1. l(list) :显示代码
  2. b + 行号/函数名(breakpoint):在指定位置加断点
  3. delete + 断点号:删除指定断点
  4. enable + 断点号:将断点设定为无效的,不加断点号,将所有断点设置为无效
  5. r(run):运行程序
  6. n(next):下一步
  7. c(continue):直接执行到下一个断点
  8. s :进入将要被调用的函数中执行
  9. finish :跳出当前函数
  10. p + 变量名(print):打印变量值
  11. 回车:重复上一行命令
  12. q:退出调试,中止进程
  13. info break:显示断点信息
  14. bt:显示函数调用栈

在这里插入图片描述

五、库文件

什么是库文件?

库是一组预先编译好的方法的集合。Linux系统存储的库的位置一般在:/lib/usr/lib。在 64 位的系统上有些库也可能被存储在/usr/lib64 下。库的头文件一般会被存储在/usr/include 下或其子目录下。

库有两种,一种是静态库,其命令规则为 libxxx.a ,一种是共享库,其命令规则为 libxxx.so

foo.h
在这里插入图片描述

add.c
在这里插入图片描述
max.c
在这里插入图片描述
main.c
在这里插入图片描述
第一步:先将需要生成库文件的所有.c文件编译成.o文件
在这里插入图片描述
第二步:使用 ar 命令将第一步编译的所有.o文件生成静态库( 后面不能跟.c文件 ),其中:

  • c 是创建库
  • r 是将方法添加到库中
  • v 显示过程
    在这里插入图片描述

非标准方法执行:
在这里插入图片描述

标准使用静态库的方法:

使用静态库libfoo.amain.c生成可执行文件的过程,其中-L 指定库的存储路径,-l 指定库的名称(不需要前面的lib和扩展名.a
在这里插入图片描述
下面将双引号"foo.h"改成尖括号<foo.h>

1 mv foo.h /usr/include

2 修改main.c
在这里插入图片描述
3 运行程序
在这里插入图片描述
除了C/C++的标准库外,如果需要链接别的库文件,需要使用-l参数手动连接

4 将库文件libfoo.a移动到默认的库目录/usr/lib
在这里插入图片描述
使用共享库

首先使用-shared -fPIC将二进制.o文件制作成动态库
在这里插入图片描述
-fPIC作用于编译阶段,告诉编译器产生与位置无关的代码,则产生的代码中,没有绝对地址,全部使用相对地址,故而代码可以被加载器加载到内存的任意位置,都可以正确的执行。这正是共享库所要求的,共享库被加载时,在内存的位置不是固定的。

使用ldd可以发现main程序找不到动态库,原因是系统加载共享库时,找不到对应的共享库文件libfoo.so, 但是该库确实在当前目录下存在 (只是gcc知道库在当前目录,但是main程序不知道)

这是为什么呢?因为系统默认只会去存储库的标准位置(/lib/usr/lib 等)加载,而不会在当前位置寻找。所以将库拷贝到/usr/lib 下,再执行程序,就可以成功。

使用ldd可以查看可执行程序使用了哪些.so共享库
在这里插入图片描述
可以看到,在Ubuntu上,/libusr/lib实际上是一个目录
在这里插入图片描述
如果只是临时设置一下查找共享库的位置,可以通过export LD_LIBRARY_PATH=路径 进行设置
在这里插入图片描述

静态库和共享库的区别

静态库在链接时将用到的方法包含到最终生成的可执行程序中,而共享库不包含,只做标记,在运行程序时,才动态加载。
在这里插入图片描述

如果不使用.so共享库,只使用.o静态库,当可执行文件特别多的时候,内存中会存在很多函数的拷贝。因为所有的可执行程序都包含了所需要的函数,这使得内存的利用率太低,所以大多数时候使用.so共享库

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bugcoder-9905

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值