『Linux』基础开发工具

软件包管理器

什么是软件包

  • 在Linux下安装软件,一个通常的办法是下载到程序的源码,并进行编译得到可执行程序
  • 但是这样太麻烦了,于是有些人把一些常用的软件提前编译好,做成软件包(可以理解为windows上的安装程序)放在一个服务器上,通过包管理器可以很方便的获取到这个编译好的软件包,直接进行安装。
  • 软件包和软件包管理器,就好比应用和应用商店的关系。
  • yum(Yellow Dog Updater,Modified)是Linux下非常常用的一种包管理工具。主要应用在Fedora、RedHat、CentOS等发行版上。

注意:yum的所有操作都必须保证网络畅通
命令

ping www.baidu.com

查看网络是否畅通(如下为畅通状态)。
在这里插入图片描述

查看软件包

命令

yum list

由于软件包的数量非常之多,这里我们需要搭配grep命令使用,筛选出我们关注的包。
示例

yum list | grep rzsz

在这里插入图片描述
注意

  • 软件包名称主版本号.此版本号.源程序发行号-软件包的发行号.主机平台.CPU架构
  • "x86_64"后缀表示64位操作系统的安装包,"i686"后缀表示32位系统安装包。选择包时要和系统匹配。
  • "el7"表示操作系统发行版的版本。"el7"表示是CentOS 7/RedHat 7"el6"表示CentOS 6/RedHat 6
  • 最后一列,base表示的是"软件源"的名称,类似于"小米应用商店","华为应用商店"这样的概念。

软件包安装

命令

$ su
# yum install lrzsz

yum会自动找到都有哪些软件包需要下载,这时候敲"y"确认安装
出现如下"complete"字样,表示安装完成
在这里插入图片描述

软件包卸载

命令

$ su
# yum remove lrzsz

出现如下字样,表示卸载成功
在这里插入图片描述

查看已安装的软件包

命令

yum list installed

效果如下
在这里插入图片描述

Linux开发工具

编辑器vim

在这里插入图片描述

vim简介

vim共有十二种模式,有三种是最常用的,分别是命令模式、插入模式和普通模式

  • 命令模式
    输入冒号进入命令模式,可以进行文件保存或退出,也可以进行文本替换,字符串查找,列出行号等。
  • 插入模式
    只有在插入模式,才可以做文字输入。按esc键可以回到普通模式。
  • 普通模式
    控制屏幕光标的移动,字符、字或行的删除,移动复制某区段。

vim基本操作

命令

$ vimtutor

进入vim教程。可以自行联系vim的一些基本操作,注意,退出时使用:q!退出不保存修改
在这里插入图片描述

vim简单配置

这里推荐几个简单而又关键的配置

" 将jk映射为esc
inoremap jk <esc>

"显示行号
set number

" 设置换行自动缩进长度为4个空格
set shiftwidth=4

"设置tab宽度
set tabstop=4

" 去除vi一致性,必须要添加
set nocompatible              

更多高级的配置以及插件安装,请自行探索

编译器gcc/g++

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

函数库

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

动态库和静态库

  • 静态库是指编译链接时,把库文件的代码全部加入到可执行文件中,因此生成的文件比较大,但在运行时也就不再需要库文件了。其后缀名一般为".a"。
  • 动态库与之相反,在编译链接时并没有把库文件的代码加入到可执行文件中,而是在程序执行时由运行时链接文件加载库,这样可以节省系统的开销。动态库一般后缀名为".so",如前面所述的libc.so.6就是动态库。gcc在编译时默认使用动态库。完成了链接之后,gcc就可以生成可执行文件,如下所示。gcc hello.o -o hello
  • gcc默认生成的二进制程序,是动态链接的,可以通过file命令验证。

gcc选项

  • -E:只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里面。
  • -S:编译到汇编语言不进行汇编和链接。
  • -c:编译到目标代码。
  • -o:文件输出到文件。
  • -static:此选项对生成的文件采用静态链接
  • -g生成调试信息。
  • -shared:此选项将尽量使用动态库,所以生成文件比较小,但是需要系统有动态库。
  • -O0/O1/O2/O3:编译器的优化选项的四个级别-O0表示没有优化-O1为缺省值-O3优化级别最高
  • -w:不生成任何警告信息。
  • -Wall:生成所有警告信息。

调试器gdb

  • 程序的发布方式有两种,debug模式和release模式
  • Linux gcc/g++出来的二进制程序,默认是release模式
  • 要使用gdb调试,加上-g选项。

基本使用

命令gdb binfile
退出ctrl + dquit

基本调试命令
  • list/l 行号:显示binfile源代码,接着上次的位置往下列,每次列10行。
  • list/l 函数名:列出某个函数的源代码。
  • run/r:运行程序。
  • next/n:单条执行。
  • step/s:进入函数调用
  • break/b 行号:在某一行设置断点。
  • break/b 函数名:在某个函数开头设置断点。
  • info break:查看断点信息。
  • finish:执行到当前函数的返回,然后停下来等待命令。
  • print§:打印表达式的值,通过表达式可以修改变量的值或者调用函数。
  • p 变量:打印变量值
  • set var:修改变量的值。
  • continue/c:从当前位置开始连续而非单步执行程序。
  • delete breakpoints:删除所有断点。
  • delete breakpoints n:删除序号为n的断点。
  • disable breakpoints:禁用断点。
  • enable breakpoints:启用断点。
  • info/i breakpoints:查看当前设置的所有断点。
  • display 变量名:跟踪查看一个变量,每次停下来都显示它的值。
  • undisplay:取消对先前设置的那些变量的跟踪。
  • until X行号:跳至X行
  • breaktrace/bt:查看各级函数条用堆栈及参数
  • info (i)locals:查看当前栈帧局部变量的值
  • quit:退出gdb

项目自动化构建工具make/makefile

格式:

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

简单演示

hello.c
#include <stdio.h>

int main(){
	
	printf("hello, world!\n");

	return 0;
}
makefile
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:run
 run:
     ./hello
 
 .PHONY:clean
 clean:
     rm hello.i
     rm hello.s
     rm hello.o
     rm hello 
效果
[sss@aliyun make]$ make
gcc -E hello.c -o hello.i
gcc -S hello.i -o hello.s
gcc -c hello.s -o hello.o
gcc hello.o -o hello
[sss@aliyun make]$ make run
./hello
hello, world!
[sss@aliyun make]$ make clean
rm hello.i
rm hello.s
rm hello.o
rm hello
[sss@aliyun make]$ ll
total 8
-rw-rw-r-- 1 sss sss  75 May 17 11:12 hello.c
-rw-rw-r-- 1 sss sss 261 May 17 11:18 makefile

三个常见的预定义变量

  • $@:要生成的目标对象。
  • $^:所有的依赖对象。
  • $<:依赖对象中的第一个。

原理

  • make会在当前目录找名字为makefile或Makefile的文件。
  • 如果找到,它会找文件中的第一个目标文件,在上面的例子中,它会找到"hello"这个文件,并把这个文件作为最终的目标文件。
  • 如果hello文件不存在,或是hello所依赖的后面的hello.o文件修改时间要比hello这个文件新,那么,它就会执行后面所定义的命令来生成hello这个文件。
  • 如果hello所依赖的hello.o文件不存在,那么make会在当前文件中找目标为hello.o文件的依赖性,如果找到则再根据那一个规则生成hello.o文件。
  • 如果hello.o依赖的文件hello.s也不存在,则会去找hello.s的依赖文件hello.i,如果hello.i也不存在,就去找hello.i的依赖文件hello.c。hello.c一定是存在的,不然你还写什么makefile。然后hello.i之后,再去生成hello.s,再去生成hello.o,再去生成可执行文件hello。
  • 这就是整个make的依赖性,make会一层又一层的去找文件的依赖关系,直到最终编译出第一个目标文件
  • 找寻文件的过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make根本不理
  • make只管文件的依赖性,如果在我找了依赖关系之后,冒号后面的文件还是不在,make就会罢工

项目清理

  • 像clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要make执行。即命令:make clean。来清除所有目标文件,以便重新编译。
  • 但是一般我们这种clean的目标文件,我们将它设置为伪目标,用.PHONY修饰,伪目标的特性是,总是被执行的。

git配置

  • 安装git。
[root@aliyun sss]# yum install git
  • 验证是否安装成功。
[sss@aliyun ~]$ git --version
git version 1.8.3.1
  • 配置git,配置用户名、邮箱、Windows提交到Linux上是否自动转换换行符、字符集。
[sss@aliyun ~]$ git config --global user.name "sss-0916"
[sss@aliyun ~]$ git config --global user.email "sss-0916@qq.com"
[sss@aliyun ~]$ git config --global core.autocrlf false
[sss@aliyun ~]$ git config --global gui.encoding utf-8
  • 生成ssh key
[sss@aliyun ~]$ ssh-keygen -t rsa -C "sss-0916@qq.com"
需要填写的,全部回车默认即可。
  • 查看ssh key
[sss@aliyun ~]$ cat ~/.ssh/id_rsa.pub
将打印到屏幕上的ssh key拷贝下来。
  • 打开github
    GitHub
    在这里插入图片描述
    点击Settings
    在这里插入图片描述
    点击SSH and GPG keys,然后点击New SSH key
    在这里插入图片描述
    将前面复制的ssh key粘贴到Key中,在随便取一个Title。点击Add SSH key
  • 测试是否配置成功
[sss@aliyun ~]$ ssh -T git@github.com
  • 出现下面一段话,即证明配置成功。
Hi sss-0916! You've successfully authenticated, but GitHub does not provide shell access.

遇到的问题

按前面配置完之后,每次克隆仓库到本地,都会有警告
Warning: Permanently added the RSA host key for IP address '52.74.223.119' to the list of known hosts.
解决方案
[root@aliyun git_space]# vim /etc/hosts
在最后加上一行:
192.30.252.128  github.com
保存退出即可。
git push失败
[sss@aliyun Linux]$ git add block.c 
[sss@aliyun Linux]$ git commit -m "2019_05_17"
[master (root-commit) 6853cdd] 2019_05_17
 1 file changed, 55 insertions(+)
 create mode 100644 block.c
[sss@aliyun Linux]$ git push
warning: push.default is unset; its implicit value is changing in
Git 2.0 from 'matching' to 'simple'. To squelch this message
and maintain the current behavior after the default changes, use:

  git config --global push.default matching

To squelch this message and adopt the new behavior now, use:

  git config --global push.default simple

See 'git help config' and search for 'push.default' for further information.
(the 'simple' mode was introduced in Git 1.7.11. Use the similar mode
'current' instead of 'simple' if you sometimes use older versions of Git)

Warning: Permanently added the RSA host key for IP address '13.250.177.223' to the list of known hosts.
No refs in common and none specified; doing nothing.
Perhaps you should specify a branch such as 'master'.
error: failed to push some refs to 'git@github.com:sss-0916/Linux.git'
解决办法
[sss@aliyun Linux]$ git config --global push.default simple

这样配置之后就正常了

[sss@aliyun Linux]$ git push
Counting objects: 3, done.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 587 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To git@github.com:sss-0916/Linux.git
 * [new branch]      master -> master
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值