Linux开发

目录

Linux开发工具

Linux编辑器-vim使用

1. vim的基本概念

2. vim的基本操作 

3. vim正常模式命令集

4. vim末行模式命令集 

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

1. 背景知识

2. gcc如何完成

Linux调试器-gdb使用

1. 背景

2. 开始使用

3.获取程序运行中的PID和PPID

 

Linux项目自动化构建工具-make/Makefifile

背景

理解

实例代码

依赖关系

依赖方法

原理

项目清理

Linux第一个小程序-进度条

\r&&\n

行缓冲区概念

yum 

使用 git 命令行

安装 git

下载项目到本地


Linux开发工具

  • IDE(集成)例子

Linux开发_第1张图片

Linux编辑器-vim使用

vi/vim 的区别简单点来说,它们都是多模式编辑器,不同的是 vim vi 的升级版本,它不仅兼容 vi 的所有指令,而且还有一些新的特性在里面。例如语法加亮,可视化操作不仅可以在终端运行,也可以运行于x window mac os 、windows。

1. vim的基本概念

vim最基本 的三种模式 , 分别是命令模式( command mode )、插入模式(Insert mode )和底行模式( last line mode ),各模式的功能区分如下:
  • 正常/普通/命令模式(Normal mode)
控制屏幕光标的移动,字符、字或行的删除,移动复制某区段及进入Insert mode 下,或者到 last line mode
  • 插入模式(Insert mode)
只有在 Insert mode 下,才可以做文字输入,按「 ESC 」键可回到命令行模式。该模式是我们后面用的最频繁的编辑模式。
  • 末行模式(last line mode)
文件保存或退出,也可以进行文件替换,找字符串,列出行号等操作。 在命令模式下, shift+: 即可进入该模式。要查看你的所有模式:打开vim ,底行模式直接输入
:help vim-modes
我这里一共有 12 种模式 :six BASIC modes six ADDITIONAL modes

 Linux开发_第2张图片

2. vim的基本操作 

  • 进入vim,在系统提示符号输入vim及文件名称后,就进入vim全屏幕编辑画面:
  • $ vim test.c
  • 不过有一点要特别注意,就是你进入vim之后,是处于[正常模式],你要切换到[插入模式]才能够输入文字。
  • [正常模式]切换至[插入模式]
  • 输入a
  • 输入i
  • 输入o
  • [插入模式]切换至[正常模式]
  • 目前处于[插入模式],就只能一直输入文字,如果发现输错了字,想用光标键往回移动,将该字删除,可以先按一下「ESC」键转到[正常模式]再删除文字。当然,也可以直接删除。
  • [正常模式]切换至[末行模式]
  • shift + ;, 其实就是输入「:」
  • 退出vim及保存文件,[正常模式]下,按一下「:」冒号键进入「Last line mode,例如:
  • : w (保存当前文件)
  • : wq ( 输入「 wq , 存盘并退出 vim)
  • : q! (输入 q!, 不存盘强制退出 vim)

3. vim正常模式命令集

Linux开发_第3张图片

4. vim末行模式命令集 

 Linux开发_第4张图片

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

1. 背景知识

  1. 预处理(进行宏替换)
  2. 编译(生成汇编)
  3. 汇编(生成机器可识别代码)
  4. 连接(生成可执行文件或库文件)

2. gcc如何完成

格式 gcc [ 选项 ] 要编译的文件 [ 选项 ] [ 目标文件 ]
预处理 ( 进行宏替换 )
  • 预处理功能主要包括宏定义,文件包含,条件编译,去注释等。
  • 预处理指令是以#号开头的代码行。
  • 实例: gcc –E hello.c –o hello.i
  • 选项“-E”,该选项的作用是让 gcc 在预处理结束后停止编译过程。
  • 选项“-o”是指目标文件,“.i”文件为已经过预处理的C原始程序。
  • 预处理过后仍是C语言
编译(生成汇编)
  • 在这个阶段中,gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查无误后,gcc 把代码翻译成汇编语言
  • 用户可以使用“-S”选项来进行查看,该选项只进行编译而不进行汇编,生成汇编代码。
  • 实例: gcc –S hello.i –o hello.s
汇编(生成机器可识别代码)
  • 汇编阶段是把编译阶段生成的“.s”文件转成目标文件
  • 读者在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码了
  • 实例: gcc –c hello.s –o hello.o
链接(生成可执行文件或库文件)
  • 在成功编译之后,就进入了链接阶段。
  • 实例: gcc hello.o –o hello
  • 分为动态链接和静态链接
  • 动态链接要动态库
  • 动态链接:将库中我要的方法的地址,填入我的可执行程序中,建立关联!
  • 静态链接要静态库
  • 静态链接:将库中方法的实现,真的拷贝到我们的可执行程序中

Linux开发_第5张图片 在这里涉及到一个重要的概念:函数库

  • 我们的C程序中,并没有定义“printf”的函数实现,且在预编译中包含的“stdio.h”中也只有该函数的声明,而没有定义函数的实现,那么,是在哪里实“printf”函数的呢?
  • 最后的答案是:系统把这些函数实现都被做到名为 libc.so.6 的库文件中去了,在没有特别指定时,gcc 会到系统默认的搜索路径“/usr/lib”下进行查找,也就是链接到 libc.so.6 库函数中去,这样就能实现函“printf”,而这也就是链接的作用
函数库一般分为静态库和动态库两种。
  • 静态库是指编译链接时,把库文件的代码全部加入到可执行文件中,因此生成的文件比较大,但在运行时也就不再需要库文件了。其后缀名一般为“.a”Linux开发_第6张图片
  • 动态库与之相反,在编译链接时并没有把库文件的代码加入到可执行文件中,而是在程序执行时由运行时链接文件加载库,这样可以节省系统的开销。动态库一般后缀名为“.so”,如前面所述的 libc.so.6 就是动态库。gcc 在编译时默认使用动态库。完成了链接之后,gcc 就可以生成可执行文件,如下所示。 gcchello.o –o helloLinux开发_第7张图片
  • gcc默认生成的二进制程序,是动态链接的,这点可以通过 file 命令验证。   
gcc 选项
  • -E 只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里面
  • -S 编译到汇编语言不进行汇编和链接
  • -c  编译到目标代码
  • -o 文件输出到 文件
  • -static 此选项对生成的文件采用静态链接
  • -g 生成调试信息。GNU 调试器可利用该信息。
  • -shared 此选项将尽量使用动态库,所以生成文件比较小,但是需要系统由动态库.
  • -O0
  • -O1
  • -O2
  • -O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高
  • -w  不生成任何警告信息。
  • -Wall 生成所有警告信息。
gcc 选项记忆
esc,iso 例子

Linux调试器-gdb使用

1. 背景

  • 程序的发布方式有两种,debug模式和release模式
  • Linux gcc/g++出来的二进制程序,默认是release模式
  • 要使用gdb调试,必须在源代码生成二进制程序的时候, 加上 -g 选项Linux开发_第8张图片
  • [hp@VM-4-9-centos lesson7]$ readelf -S mytest| grep -i debug
      [27] .debug_aranges    PROGBITS         0000000000000000  00001061
      [28] .debug_info       PROGBITS         0000000000000000  00001091
      [29] .debug_abbrev     PROGBITS         0000000000000000  00001189
      [30] .debug_line       PROGBITS         0000000000000000  00001214
      [31] .debug_str        PROGBITS         0000000000000000  0000126a
    

    readelf 读取其中文件

2. 开始使用

gdb binFile 退出: ctrl + d quit 调试命令:
  • listl 行号:显示binFile源代码,接着上次的位置往下列,每次列10行。
  • listl 函数名:列出某个函数的源代码。
  • gdb会记录最近一次指令,按回车可继续执行上次指令
  • rrun:开始调试,如果没有断点则直接运行
  • n next:单条执行。
  • sstep:进入函数调用
  • break(b) +行号:在某一行设置断点
  • break 函数名:在某个函数开头设置断点
  • info break :查看断点信息。
  • fifinish:执行到当前函数返回,然后挺下来等待命令
  • print(p):打印表达式的值,通过表达式可以修改变量的值或者调用函数​​​​​​​
  • p 变量:打印变量值。
  • set var:修改变量的值
  • continue(c):从当前位置开始连续而非单步执行程序
  • run(r):从开始连续而非单步执行程序
  • delete breakpoints:删除所有断点
  • delete breakpoints n:删除序号为n的断点
  • disable breakpoints +断点编号:禁用断点
  • enable breakpoints:启用断点
  • info(i) breakpoints:参看当前设置了哪些断点
  • display 变量名:跟踪查看一个变量,每次停下来都显示它的值
  • undisplay:取消对先前设置的那些变量的跟踪
  • until X行号:跳至X
  • breaktrace(bt):查看各级函数调用及参数
  • infoi) locals:查看当前栈帧局部变量的值
  • quit:退出gdb

3.获取程序运行中的PID和PPID

while :; do ps ajx | head -1 && ps axj | grep myproc | grep -v grep; sleep 1; echo "--------------------------------------------------"; done

 

Linux项目自动化构建工具-make/Makefifile

背景

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

理解

依赖例子

实例代码

C 代码
  1 #include   
  2 int main()  
  3 {  
  4      printf("hello Makefile!\n");  
  5       return 0;  
  6   
  7 } 
Linux开发_第10张图片 Makefifile文件 hello:hello.o gcc hello.o -o hello hello.o:hello.s gcc -c hello.s -o hello.o hello.s:hello.i gcc -S hello.i -o hello.s hello.i:hello.c gcc -E hello.c -o hello.i ​​​​​​​ 
 .PHONY:clean
       clean:
        rm -f hello.i hello.s hello.o hello   

依赖关系

  • 上面的文件 hello ,它依赖 hell.o
  • hello.o , 它依赖 hello.s
  • hello.s , 它依赖 hello.i
  • hello.i , 它依赖 hello.c

依赖方法

  • gcc hello.* -option hello.* ,就是与之对应的依赖关系

原理

  • make是如何工作的,在默认的方式下,也就是我们只输入make命令。那么,
  1. make会在当前目录下找名字叫“Makefifile”“makefifile”的文件。
  2. 如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到“hello”这个文件,并把这个文件作为最终的目标文件。
  3. 如果hello文件不存在,或是hello所依赖的后面的hello.o文件的文件修改时间要比hello这个文件新(可以用 touch 测试),那么,他就会执行后面所定义的命令来生成hello这个文件。
  4. 如果hello所依赖的hello.o文件不存在,那么make会在当前文件中找目标为hello.o文件的依赖性,如果找到则再根据那一个规则生成hello.o文件。(这有点像一个堆栈的过程)
  5. 当然,你的C文件和H文件是存在的啦,于是make会生成 hello.o 文件,然后再用 hello.o 文件声明make的终极任务,也就是执行文件hello了。
  6. 这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。
  7. 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make根本不理。
  8. make只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,那么对不起,我就不工作啦。

项目清理

​​​​​​​
  • 工程是需要被清理的
  • clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要make执行。即命令——“make clean”,以此来清除所有的目标文件,以便重编译。
  • 但是一般我们这种clean的目标文件,我们将它设置为伪目标,.PHONY 修饰,伪目标的特性是,总是被执行的。
  • 可以将我们的 hello 目标文件声明成伪目标,测试一下

​​​​​​​Linux第一个小程序-进度条

\r&&\n

回车概念:
        当光标锁定到任意位置时,采用回车光标将自动回到开头处
换行概念:        
        当光标锁定某一位置,采取换行操作光标将平移到下面一行

行缓冲区概念

  1 #include
  2 #include
  3 #include
  4 
  5 #define NUM 102
  6 int main()
  7 {
  8     char bar[NUM];
  9     memset(bar,0,sizeof(bar));
 10     int cnt=0;
 11     while(cnt<=100)
 12     {
 13         printf("[%-100s][%d%%]\r",bar,cnt);
 14         bar[cnt++]='#';
 15         fflush(stdout);
 16         usleep(30000);                                                                                                                                                                                       
 17     }
 18     printf("\n");
 19     return 0;
 20 }

yum 

Linux开发_第11张图片

使用 git 命令行

安装 git

yum install git

下载项目到本地

创建好一个放置代码的目录 .
git clone [url]
这里的 url 就是刚刚建立好的 项目 的链接. Linux开发_第12张图片

 三板斧第一招: git add

将代码放到刚才下载好的目录中
git add [ 文件名 ]
将需要用 git 管理的文件告知 git
三板斧第二招 : git commit
提交改动到本地
git commit .
最后的 "." 表示当前目录
提交的时候应该注明提交日志 , 描述改动的详细内容 .
三板斧第三招 : git push
同步到远端服务器上
git push
需要填入用户名密码 . 同步成功后 , 刷新 Github 页面就能看到代码改动了 .

其他情况:

  1. 可能第一次使用需要你配置用户名和邮箱 Linux开发_第13张图片
  2. 有时候无法提交,会出现提交冲突,无脑git pull
  3. 。gitignore # 不想提交某些后缀的文件同步到远端的git仓库,就可以添加到gitignore
  4. git rm 可以删除
配置免密码提交
https://blog.csdn.net/camillezj/article/details/55103149

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