sudo是linux系统管理指令,是允许系统管理员让普通用户执行一些或者全部的root命令的一个工具,如halt,reboot,su等等。这样不仅减少了root用户的登录 和管理时间,同样也提高了安全性。sudo不是对shell的一个代替,它是面向每个命令的。
但是为什么我们的sudo指令用不了?如:
使用sudo命令的根本原因是为了暂时提升当前用户权限,而root用户基本上不受权限影响,所以是可以随便使用sudo命令的,但每个普通用户却不一定都能使用sudo命令,因为普通用户要受权限影响,只有被root用户添加到信任列表里面的人才可以用sudo命令,因为root用户也怕你拿着他的权限去到处瞎搞。
第一步:用root用户进入 /etc/sudoers 这个文件
指令:vim /etc/sudoers
进入后的界面是这样的。如:
第二步:找到添加白名单的地方,并添加白名单成员。如:
第三步:强制保存并退出。如:
命令:wq!
注意:直接保存是保存不了的,就算root用户也不行。
最后:回到普通用户来验证下,发现可以使用了。如:
1.预处理
2.编译(生成汇编)
3.汇编(生成机器码即机器可识别的代码)
4.链接(生成可执行文件或库文件)
格式 gcc [选项] 要编译的文件 [选项] [目标文件]
预处理(进行宏替换)
实例指令:gcc –E test.c –o test.i
选项“-E”,该选项的作用是让 gcc 在预处理结束后停止编译过程。
选项“-o”是指目标文件,“.i”文件为已经过预处理的C原始程序。
预处理的功能主要包括宏定义,文件包含,条件编译,去注释等。如:
编译(生成汇编)
实例指令: gcc –S test.i –o test.s
用户可以使用“-S”选项来进行查看,该选项只进行编译而不进行汇编,生成汇编代码。
在这个阶段中,gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查无误后,gcc 把代码翻译成汇编语言。如:
汇编(生成机器可识别代码)
实例指令: gcc –c test.s –o test.o
汇编阶段是把编译阶段生成的“.s”文件转成目标文件
读者在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码了。如:
链接(生成可执行文件或库文件)
实例指令: gcc test.o –o test
在成功编译之后,就进入了链接阶段。如:
我们的C程序中,并没有定义“printf”的函数实现,且在预编译中包含的“stdio.h”中也只有该函数的声明,而没有定义函数的实现,那么,是在哪里实“printf”函数的呢?
答案是:系统把这些函数实现都被做到名为 libc.so.6 的库文件中去了,在没有特别指定时,gcc 会到系统默认的搜索路径“/usr/lib”下进行查找,也就是链接到 libc.so.6 库函数中去,这样就能实现函数“printf”了,而这也就是链接的作用。
函数库一般分为动态库和静态库
sudo yum install -y glibc-static
sudo yum install -y libstdc++-static
file指令可以查看库是动态链接还是静态链接如:
总结(动vs静):
动态库因为是共享库,有效的节省资源(磁盘空间、内存空间、网络空间等)【优】动态库一旦缺失,导致各个程序都无法运行【缺】
静态库,不依赖库,程序可以独立运行【优】体积大,比较消耗资源【缺】
为什么第2次使用make会失效呢?如:
答案:提高编译效率。
那它是怎么做的呢?
只需要比较可执行程序的最近修改时间和源文件的最近修改时间
当.exe新于.c源文件 是老的,不需要重新编译
当.exe旧于.c源文件 是新的,需要重新编译
结论:make会根据源文件和目标文件的新旧,判断是否需要重新执行依赖关系进行编译!
那么我想让依赖关系总是被执行该怎么办?用.PHONY:伪目标。如:
补充:特殊符号$@ $^
gbg file
退出:q