1.什么是软件包?
将一些常用的软件提前编译好, 做成软件包(可以理解成windows上的安装程序)放在一个服务器上, 通过软件包管理器可以很方便的获取到这些编译好的软件包, 直接进行安装。软件包和软件包管理器, 就好比 "App" 和 "应用商店" 这样的关系。yum(Yellow dog Updater, Modifified)是Linux下非常常用的一种包管理器. 主要应用在Fedora, RedHat, Centos等发行版上.
2.rz/sz的使用
这个工具用于 windows 机器和远端的 Linux 机器通过 XShell 传输文件。安装完毕之后可以通过拖拽的方式将Windows机器中的程序上传到Linux机器中。也可以以指令的方式进行使用。
3.yum基本命令和使用
1)查看软件包
yum list 显示所有软件包 例:yum list | grep lrzsz ---查找rzsz相关的软件包
2)下载安装软件包
yum install 安装软件包 例:yum install lrzsz
3)卸载软件包
yum remove 卸载软件包 例:yum remove lrzsz
注意:安装和卸载软件包需要root权限,同时yum的所有操作必须保证主机网络畅通(ping 指令可以验证网络是否畅通)
1.vim的基本概念
vim的3种常用模式(vim一共有12种模式,但只有3种模式最常用),分别是命令(普通)模式(normal mode)、底行模式(last line mode)、插入模式(insert mode)。
正常/普通/命令模式:控制屏幕光标的移动,字符、字或行的删除,移动复制某区段及进入Insert mode下,或者到 last line mode
插入模式:只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。该模式是我们后面用的最频繁的编辑模式。
底行模式:文件保存或退出,也可以进行文件替换,找字符串,列出行号等操作。 在命令模式下,shift+: 即可进入该模式。要查看你的所有模式:打开vim,底行模式直接输入:help vim-modes
2.vim的基本操作
1)vim打开和退出文件
a.打开文件
基本命令:vim +文件名;例vim test.c
注意:使用vim打开文件时,如果文件存在则打开文件,如果文件不存在则在当前目录下创建该文件并打开。
b.退出文件
使用vim打开一个文件,要想退出必须在底行模式下使用命令退出。①w保存文件;②q!强制退出文件(不保存);③wq保存并退出;
2)vim三种模式的相互切换
a.插入模式、底行模式切换到普通模式:Esc键
b.普通模式切换到底行模式:shift+: 键
c.插入模式切换到底行模式:Esc键切换到普通模式,再shift+: 键切换到底行模式
d.正常模式切换到插入模式:i / a / o键均可切换到插入模式
i:光标处于上次所在位置不变
a:光标默认处于上次光标所在位置的下一个位置
o:上次光标所在位置的下一行(会自动换行,使后边内容后移一行)
3)vim下的基本命令
a.普通模式的基本命令
b.底行模式下的基本命令
c.其他命令(普通模式)
1.gcc编译C语言程序的过程
C语言程序的编译分预处理、编译、汇编和链接四步,在gcc下每一步的具体操作如下:
预处理:展开头文件、宏替换、去掉注释、条件编译
命令:gcc file.c -E -o file.i 使用E选项堆.c文件进行编译生成.i文件
编译:将c程序编译形成汇编代码
命令:gcc file.i -S -o file.s .s文件为生成的汇编代码文件
汇编:将汇编形成二进制目标文件
命令:gcc file.s -c -o file.o .o文件为生成的二进制目标文件
链接:将目标文件和系统库链接形成可执行程序
命令:gcc file.o -o file file为生成的可执行程序
gcc常用选项:-E(.i) -S(.s) -c(.o) -o(可执行程序)
2.函数库和链接方式
1)动态库和静态库
静态库:静态库是指编译链接时,把库文件的代码全部加入到可执行文件中,因此生成的文件比较大,但在运行时也就不再需要库文件了。其后缀名一般为“.a”。
动态库:动态库与之相反,在编译链接时并没有把库文件的代码加入到可执行文件中,而是在程序执行时由运行时链接文件加载库,这样可以节省系统的开销。动态库一般后缀名为“.so”,如前面所述的 libc.so.6 就是动态库。gcc 在编译时默认使用动态库。完成了链接之后,gcc
2)静态链接和动态链接
gcc默认使用的是动态库进行动态链接,在编译时加上-static选项就会使用静态库进行静态链接。
静态链接和动态链接的比较
动态链接:程序体积比较小,节省系统资源;一旦库确实所有依赖的程序都不可运行了
静态链接:程序体积比较大,浪费系统资源;当库缺失时不会影响其他程序的执行
gdb是Linux下常用的调试器工具,程序的发布有两种形式,debug版本和release版本,只有debug版本的程序才能进行调试(release版本的程序没有调试信息)。Linux下默认生成的是release版本的,需要生成debug版本的程序需要加上-g选项即可。
相关命令
make是一个命令工具,是一个解释makefifile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefifile都成为了一种在工程方面的编译方法。make是一条命令,makefifile是一个文件,两个搭配使用,完成项目自动化构建。
1.原理
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只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,那么对不起,我就不工作啦。
2.依赖关系和依赖方法
依赖关系:在使用gcc命令编译C语言程序时,如:gcc -c hello.s -o hello.o命令中,需要通过hello.s文件生成hello.o文件,即生成hello.o文件需要依赖hello.s文件。同样在Makefile中也需要这样的依赖关系,例如Makefile中hello.o:hello.s就是依赖hello.s生成hello.o文件。
依赖方法:在Makefile中除了需要这样的依赖关系之外,还需要执行这样依赖关系的依赖方法,Makefile中的依赖方法就形如:gcc -c hello.s -o hello.o这样的命令。同时需要注意的是Makefile中依赖方法需要以tab键开头。
伪目标:Makefile中.PHONY修饰的表明是一个伪目标,如.PHONY:clean就表示clean是一个伪目标,伪目标的表明该目标总是被执行的。
3.项目清理
在软件工程项目中,像clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要make执行。即命令——“make clean”,以此来清除所有的目标文件,以便重编译。但是一般我们这种clean的目标文件,我们将它设置为伪目标,用 .PHONY 修饰,伪目标的特性是,总是被执行的。可以将我们的 hello 目标文件声明成伪目标,测试一下
4.示例
//初级版
hello:hello.o //生成hello需要依赖hello.o
gcc hello.o -o hello //上条语句所需的依赖方法
hello.o:hello.s //生成hello.o需要依赖hello.s文件
gcc hello.s -c -o hello.o
hello.s:hello.i
gcc hello.i -S -o hello.s
hello.i:hello.c
gcc hello.c -E -o hello.i
.PHONY:clean //生成clean伪目标
clean:
rm -rf *.i *.s *.o
//中级版,可以使用$@代替待生成文件,#^代替依赖关系文件
hello:hello.o //生成hello需要依赖hello.o
gcc $^ -o $@ //上条语句所需的依赖方法
hello.o:hello.s //生成hello.o需要依赖hello.s文件
gcc $^ -c -o $@
hello.s:hello.i
gcc $^ -S -o $@
hello.i:hello.c
gcc $^ -E -o $@
.PHONY:clean //生成clean伪目标
clean:
rm -rf *.i *.s *.o
//高级版,Makefile文件中可以定义变量
h=hello
h1=hello.o
h:h1 //生成hello需要依赖hello.o
gcc $^ -o $@ //上条语句所需的依赖方法
h1:hello.s //生成hello.o需要依赖hello.s文件
gcc $^ -c -o $@
hello.s:hello.i
gcc $^ -S -o $@
hello.i:hello.c
gcc $^ -E -o $@
.PHONY:clean //生成clean伪目标
clean:
rm -rf *.i *.s *.o //其他文件名也可以使用定义变量的方式进行替换
1.克隆本地仓库:git clone 仓库连接
2.git add 添加代码
3.git comnit -m ’information‘提交改动到本地
4.git push同步到远程服务器
Linux下默认使用的是动态链接,生成的是release版本