Linux常用命令及组件

avatar
作者
猴君
阅读量:0

Linux

MultiTask 的意思是多任务,代表着 Linux 是一个多任务的操作系统。

SMP 的意思是对称多处理,代表着每个 CPU 的地位是相等的,对资源的使用权限也是相同的,多个 CPU 共享同一个内存,每个 CPU 都可以访问完整的内存和硬件资源。

ELF 的意思是可执行文件链接格式

Monolithic Kernel 的意思是宏内核,Linux 内核架构就是宏内核,意味着 Linux 的内核是一个完整的可执行程序,且拥有最高的权限。

  • 微内核,有一个最小版本的内核,一些模块和服务则由用户态管理;

  • 混合内核,是宏内核和微内核的结合体,内核中抽象出了微内核的概念,也就是内核中会有一个小型的内核,其他模块就在这个基础上搭建,整个内核是个完整的程序;

常用命令

echo(打印到终端)

cd(更改路径)

切换当前目录家路径:cd ~

切换俩个路径 cd -

ls(显示子文件)

-a:显示所有文件

-l:显示详情信息,文件类型, 文件所有者对文件的操作权限, 文件所属组用户对文件的操作权限, 其他人对文件的操作权限, 硬链接计数, 文件所有者, 文件所属组, 文件大小, 文件的修改日期, 文件名

-F: 目录之外文件加/

mkdir(创建目录)

-p :多级目录

rm(删除)

rmdir:只能删除空目录

-i: 删除的时候给提示 -f: 强制删除文件, 没有提示直接删除并且不能恢复, 慎用

cp(拷贝)

cp [options] source dest 或 cp [选项] 源文件 目标文件

mv(移动、改名)

mv [options] source dest
mv [options] source... directory

  • -b: 当目标文件或目录存在时,在执行覆盖前,会为其创建一个备份。
  • -i: 如果指定移动的源目录或文件与目标的目录或文件同名,则会先询问是否覆盖旧文件,输入 y 表示直接覆盖,输入 n 表示取消该操作。
  • -f: 如果指定移动的源目录或文件与目标的目录或文件同名,不会询问,直接覆盖旧文件。
  • -n: 不要覆盖任何已存在的文件或目录。
  • -u:当源文件比目标文件新或者目标文件不存在时,才执行移动操作。

cat、head、tail(文件查看)

cat:如果文件太大数据就不能完全显示出来了,因此该命令适合查看比较小的文件内容。

head -行数 文件名(默认十行)

tail -行数 文件名(默认十行)

ln(软连接、硬连接)

语法: ln -s 源文件路径 软链接文件的名字(可以带路径)

ln 源文件 硬链接文件的名字(可以带路径)

chmod权限修改

chmod [+-=] wrx(读、写、执行)

chmod [+-=]421(读、写、执行)

chown(修改所属者)

chown 新的所有者 文件名

chown 新的所有者:新的组名 文件名

tree(树状目录)

tree [-L n] # 查看当前目录的结构, n为显示的目录层数 tree 目录名 [-L n] # 查看指定目录的结构, n为显示的目录层数

pwd(显示当前目录)

torch(创建空文件)

which(显示实际路径)

>、>>

>: 将文件内容写入到指定文件中, 如果文件中已有数据, 则会使用新数据覆盖原数据

>>: 将输出的内容追加到指定的文件尾部

文件压缩

tar

c: 创建压缩文件 z: 使用gzip的方式进行文件压缩 j: 使用bzip2的方式进行文件压缩 v: 压缩过程中显示压缩信息, 可以省略不写 f: 指定压缩包的名字

tar 参数 生成的压缩包的名字 要压缩的文件(文件或者目录)

解压缩:

x: 释放压缩文件内容 z: 使用gzip的方式进行文件压缩, 压缩包后缀为.tar.gz j: 使用bzip2的方式进行文件压缩, 压缩包后缀为.tar.bz2 v: 解压缩过程中显示解压缩信息 f: 指定压缩包的名字

zip

zip [-r] 压缩包名 要压缩的文件

unzip 压缩包名 -d 解压目录(默认当前目录)

查找

find

find 搜索的路径 -name 要搜索的文件名

find 搜索的路径 -type 文件类型

-size 4k 表示的区间为 (4-1k,4k], 表示一个区间, 大于3k,小于等于4k -size -4k: [0k, 4-1k], 表示一个区间, 大于等于0 并且 小于等于3k -size +4k: (4k, 正无穷), 表示搜索大于4k的文件

-maxdepth: 最多搜索到第多少层目录 , -mindepth: 至少从第多少层开始搜索

gcc、g++

预处理: 在这个阶段主要做了三件事: 展开头文件 、宏替换 、去掉注释行,这个阶段需要GCC调用预处理器来完成, 最终得到的还是源文件, 文本格式 编译: 这个阶段需要GCC调用编译器对文件进行编译, 最终得到一个汇编文件

汇编: 这个阶段需要GCC调用汇编器对文件进行汇编, 最终得到一个二进制文件

链接: 这个阶段需要GCC调用链接器对程序需要调用的库进行链接, 最终得到一个可执行的二进制文件

区别

在代码编译阶段(第二个阶段):

后缀为 .c 的,gcc 把它当作是C程序,而 g++ 当作是 C++ 程序 在链接阶段(最后一个阶段): g++ 可以自动链接到标准C++库, gcc如果要链接到标准C++库需要加参数 -lstdc++

g++ 会自动定义__cplusplus宏,但是这个不影响它去编译C程序

gcc 需要根据文件后缀判断是否需要定义 __cplusplus 宏 (规则参考第一条)

静态库/动态库

在Linux中静态库以lib作为前缀, 以.a作为后缀, 中间是库的名字自己指定即可, 即: libxxx.a

ar rcs 静态库的名字(libxxx.a) 原材料(*.o)

在Linux中动态库以lib作为前缀, 以.so作为后缀, 中间是库的名字自己指定即可, 即: libxxx.so

gcc 源文件(*.c) -c -fpic

gcc -shared 与位置无关的目标文件(*.o) -o 动态库(libxxx.so)

动态库无法加载问题

找到相关的配置文件

用户级别: ~/.bashrc —> 设置对当前用户有效 系统级别: /etc/profile —> 设置对所有用户有效

添加export LD_LIBRARY_PATH =$LD_LIBRARY_PATH :动态库的绝对路径

重启终端

优缺点

优点:

静态库被打包到应用程序中加载速度快 发布程序无需提供静态库,移植方便 缺点:

相同的库文件数据可能在内存中被加载多份, 消耗系统资源,浪费内存 库文件更新需要重新编译项目文件, 生成新的可执行程序, 浪费时间。

优点:

可实现不同进程间的资源共享 动态库升级简单, 只需要替换库文件, 无需重新编译应用程序 程序猿可以控制何时加载动态库, 不调用库函数动态库不会被加载 缺点:

加载速度比静态库慢, 以现在计算机的性能可以忽略 发布程序需要提供依赖的动态库

    广告一刻

    为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!