【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】

目录

  • 一、sudo
    • 1.1为什么我用不了sudo命令
    • 1.2如何将普通用户添加到信任列表里面
  • 二、Linux编译器-gcc/g++使用
    • 2.1背景知识
    • 2.2gcc如何完成上面的4个功能?
    • 2.3函数库
  • 三、make/makefile
    • 3.1见一见make/makefile
    • 3.2make/makefile背景
    • 3.3make的使用失效
  • 四、Linux调试器-gdb使用

一、sudo

sudo是linux系统管理指令,是允许系统管理员让普通用户执行一些或者全部的root命令的一个工具,如halt,reboot,su等等。这样不仅减少了root用户的登录 和管理时间,同样也提高了安全性。sudo不是对shell的一个代替,它是面向每个命令的。
但是为什么我们的sudo指令用不了?如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第1张图片

1.1为什么我用不了sudo命令

使用sudo命令的根本原因是为了暂时提升当前用户权限,而root用户基本上不受权限影响,所以是可以随便使用sudo命令的,但每个普通用户却不一定都能使用sudo命令,因为普通用户要受权限影响,只有被root用户添加到信任列表里面的人才可以用sudo命令,因为root用户也怕你拿着他的权限去到处瞎搞。

1.2如何将普通用户添加到信任列表里面

第一步:用root用户进入 /etc/sudoers 这个文件

指令:vim /etc/sudoers

进入后的界面是这样的。如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第2张图片
第二步:找到添加白名单的地方,并添加白名单成员。如:
在这里插入图片描述
第三步:强制保存并退出。如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第3张图片

命令:wq!

注意:直接保存是保存不了的,就算root用户也不行。
最后:回到普通用户来验证下,发现可以使用了。如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第4张图片

二、Linux编译器-gcc/g++使用

2.1背景知识

1.预处理
2.编译(生成汇编)
3.汇编(生成机器码即机器可识别的代码)
4.链接(生成可执行文件或库文件)

2.2gcc如何完成上面的4个功能?

格式 gcc [选项] 要编译的文件 [选项] [目标文件]

预处理(进行宏替换)
实例指令:gcc –E test.c –o test.i
选项“-E”,该选项的作用是让 gcc 在预处理结束后停止编译过程。
选项“-o”是指目标文件,“.i”文件为已经过预处理的C原始程序。
预处理的功能主要包括宏定义,文件包含,条件编译,去注释等。如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第5张图片
编译(生成汇编)
实例指令: gcc –S test.i –o test.s
用户可以使用“-S”选项来进行查看,该选项只进行编译而不进行汇编,生成汇编代码。
在这个阶段中,gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查无误后,gcc 把代码翻译成汇编语言。如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第6张图片

汇编(生成机器可识别代码)
实例指令: gcc –c test.s –o test.o
汇编阶段是把编译阶段生成的“.s”文件转成目标文件
读者在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码了。如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第7张图片
链接(生成可执行文件或库文件)
实例指令: gcc test.o –o test
在成功编译之后,就进入了链接阶段。如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第8张图片

2.3函数库

我们的C程序中,并没有定义“printf”的函数实现,且在预编译中包含的“stdio.h”中也只有该函数的声明,而没有定义函数的实现,那么,是在哪里实“printf”函数的呢?
答案是:系统把这些函数实现都被做到名为 libc.so.6 的库文件中去了,在没有特别指定时,gcc 会到系统默认的搜索路径“/usr/lib”下进行查找,也就是链接到 libc.so.6 库函数中去,这样就能实现函数“printf”了,而这也就是链接的作用。
函数库一般分为动态库和静态库

  • 静态库是指编译链接时,把库文件的代码全部加入到可执行文件中,因此生成的文件比较大,但在运行时也就不再需要库文件了。其后缀名一般为“.a”
  • 动态库与之相反,在编译链接时并没有把库文件的代码加入到可执行文件中,而是在程序执行时由运行时链接文件加载库,这样可以节省系统的开销。动态库一般后缀名为“.so”,如前面所述的
    libc.so.6 就是动态库。gcc 在编译时默认使用动态库。完成了链接之后,gcc 就可以生成可执行文件。动态库不能缺失,一旦对应的动态库缺失,影响的不止一个程序,可能导致很多程序都无法进行正常运行!
    【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第9张图片
    安装c/c++的静态库的指令:
sudo yum install -y glibc-static
sudo yum install -y libstdc++-static

【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第10张图片
file指令可以查看库是动态链接还是静态链接如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第11张图片
总结(动vs静):
动态库因为是共享库,有效的节省资源(磁盘空间、内存空间、网络空间等)【优】动态库一旦缺失,导致各个程序都无法运行【缺】
静态库,不依赖库,程序可以独立运行【优】体积大,比较消耗资源【缺】

三、make/makefile

3.1见一见make/makefile

【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第12张图片
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第13张图片

【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第14张图片

3.2make/makefile背景

  • 一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作
  • makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。
  • make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,VisualC++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。

3.3make的使用失效

为什么第2次使用make会失效呢?如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第15张图片
答案:提高编译效率。

那它是怎么做的呢?
只需要比较可执行程序的最近修改时间和源文件的最近修改时间
当.exe新于.c源文件 是老的,不需要重新编译
当.exe旧于.c源文件 是新的,需要重新编译

结论:make会根据源文件和目标文件的新旧,判断是否需要重新执行依赖关系进行编译!
那么我想让依赖关系总是被执行该怎么办?用.PHONY:伪目标。如:
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第16张图片
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第17张图片
补充:特殊符号$@ $^
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第18张图片
【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第19张图片

四、Linux调试器-gdb使用

  • 开始使用:gbg file 退出:q

【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第20张图片

  • list/l 行号:显示binFile源代码,接着上次的位置往下列,每次列10行。

【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第21张图片

  • r或run:运行程序。(相当于vs里的F5)

【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第22张图片

  • break(b) 行号:在某一行设置断点
  • break 函数名:在某个函数开头设置断点
  • info break :查看断点信息。
    【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第23张图片
  • delete breakpoints:删除所有断点 delete
  • breakpoints n:删除序号为n的断点
    【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第24张图片
  • s或step:进入函数调用(逐语句)
  • n 或 next:单条执行(逐过程)
  • p 变量:打印变量值
  • display 变量名:跟踪查看一个变量,每次停下来都显示它的值
    【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第25张图片
  • undisplay:取消对先前设置的那些变量的跟踪(undisplay后面加上display的编号)如:
    【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第26张图片
  • until X行号:跳至X行
  • continue(或c):从当前位置开始连续而非单步执行程序
  • finish:执行到当前函数返回,然后挺下来等待命令
    disable breakpoints:禁用断点
    【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第27张图片
  • set var:修改变量的值(使用场景:比如i从0-100,想看看i=98是的代码)如:
    【Linux指令sudo、Linux编译器-gcc、make/makefile、gdb/g++】_第28张图片

你可能感兴趣的:(linux,服务器)