_ 2. 进入 vitest 这个目录当中;
_ 3. 将 /etc/man.config 拷贝到本目录底下
_ 4. 使用 vi 开启本目录下的 man.config 这个档案;
_ 5. 在 vi 中设定一下行号;
_ 6. 移动到第 58 行,向右移动 40 个字符,请问您看到的双引号内是什么目录?
_ 7. 移动到第一行,并且向下搜寻一下“bzip2”这个字符串,请问他在第几行?
_ 8. 接着下来,我要将 50 到 100 行之间的 man 改为 MAN,并且一个一个挑选是否需要修改,如何下达指令?
_ 9. 修改完之后,突然反悔了,要全部复原,有哪些方法?
_ 10. 我要复制 51 到 60 行这十行的内容,并且贴到最后一行之后;
_ 11. 删除 11 到 30 行之间的 20 行;
_ 12. 将这个文件另存成一个 man.test.config 的文件;
_ 13. 到第 29 行,并且删除 15 个字符;
_ 14. 储存后离开
拓展练习:
1、 进入 home目录,查出系统命令 echo 所在目录并写入到文件test中。
2、 打印 test文件中所记录的命令创建的时间。
3、 进入到/home目录,找出 /etc目录下所有大于1M文件并将这些文件名写入到file文件中。
4、 进入到/home目录,找出 /etc目录下所有大于1M文件并将这些文件名(不带路径)写入到 file文件中。
练习答案:
_ 1. mkdir /tmp/vitest
_ 2. cd /tmp/vitest
_ 3. cp /etc/man.config .
_ 4. vi man.config
_ 5. :set nu
_ 6. 先按下 58G 再按下 40→会看到 /dir/bin/foo 这个字样在双引号内;
_ 7. 先执行 1G 或 gg 后,直接输入 /bzip2
_ 8. 直接执行 :50,100s/man/MAN/gc 即可
_ 9. (1)简单的方法可以一直按 u 恢复到原始状态,(2)使用不储存离开 :q! 之后,再重新读取一次该文件;
_ 10. 51G 然后再 10yy 之后按下 G 到最后一行,再p粘贴10行
_ 11. 11G 之后,再给他 20dd即可删除 20 行了;
_ 12. :w man.test.config
_ 13. 29G 之后,再给他 15x 即可删除 15 个字符;
_ 14. :wq!
拓展练习参考答案:
1、
cd /home;
echo `which echo`> test;
2、ll `cat test ` | awk ‘{print $6}’
3、cd /home;
find /etc/ -size +1M > file
4、cd /home;
find /etc/ -size +1M | awk -F/ '{print $NF}' > file
或者
for i in `find /etc/ -size +1M`; do basename $i; done;
make 命令:在开发一个系统时,一般是将一个系统分成几个模块,这样做提高了系统的可维护性,但由于各个模块间不可避免存在关联,所以当一个模块改动后,其他模块也许会有所更新,当然对小系统来说,手工编译连接是没问题,但是如果是一个大系统,存在很多个模块,那么手工编译的方法就不适用了。为此,在Linux系统中,专门提供了一个make命令来自动维护目标文件,与手工编译和连接相比,make命令的优点在于他只更新修改过的文件(在Linux中,一个文件被创建或更新后有一个最后修改时间,make命令就是通过这个最后修改时间来判断此文件是否被修改),而对没修改的文件则置之不理,并且make命令不会漏掉一个需要更新的文件。
文件和文件间或模块或模块间有可能存在倚赖关系,make命令也是依据这种依赖关系来进行维护的,所以我们有必要了解什么是依赖关系;make命令当然不会自己知道这些依赖关系,而需要程序员将这些依赖关系写入一个叫makefile的文件中。Makefile文件中包含着一些目标,通常目标就是文件名,对每一个目标,提供了实现这个目标的一组命令以及和这个目标有依赖关系的其他目标或文件名,以下是一个简单的Makefile的简单例子:
#一个简单的Makefile
prog:prog1.o prog2.o
gcc prog1.o prog2.o -o prog
prog1.o:prog1.c lib.h
gcc -c -I. -o prog1.o prog1.c
prog2.o:prog2.c
gcc -c prog2.c
以上Mamefile中定义了三个目标:prog、prog1和prog2,冒号后是依赖文件列表;
对于第一个目标文件prog来说,他有两个依赖文件:prog1.o和prog2.o,任何一个依赖文件更新,prog也要随之更新,命令gcc prog1.o prog2.o -o prog是生成prog的命令。make检查目标是否需要更新时采用递归的方法,递归从底层向上对过时目标进行更新,只有当一个目标所依赖的所有目标都为最新时,这个目标才会被更新。以上面的Makefile为例,我们修改了prog2.c,执行make时,由于目标prog依赖prog1.o和prog2.o,所以要先检查prog1.o和prog2.o是否过时,目标prog1.o依赖prog1.c和lib.h,由于我们并没修改这两个文件,所以他们都没有过期,接下来再检查目标prog2.o,他依赖prog2.c,由于我们修改了prog2.c,所以prog2.c比目标文件prog2.o要新,即prog2.o过期,而导致了依赖prog2.o的所有目标都过时;这样make会先更新prog2.o再更新prog。
如果某一行过长,已经到了文本编辑器的右边界,可用一个反斜杠()做换行符,反斜杠所连接的所有行都会被当成一行来处理;另外在Makefile中涉及的文件名允许使用通配符(?或*)。
有时候为了简化命令的书写,可以在Makefile中定义一些宏和使用缩写,下面是几个很使用的缩写:
$@ 代表该目标的全名
$* 代表已经删除了后缀的目标名
$《 代表该目标的第一个相关目标名
现在就可以使用缩写对以上Makefile做相应的修改:
#使用缩写的Makefile
prog:prog1.o prog2.o
gcc prog1.o prog2.o -o $@
prog1.o:prog1.c lib.h
gcc -c -I. -o $@ $《
prog2.o:prog2.c
gcc -c $*.c
在一个项目中,可能几个目标中使用同一个文件a.c,如果以后这个文件被修改,那么需要修改Makefile中所有的a.c,这样就比较麻烦,可以定义宏来解决这个问题,宏可以使Makefile更加清晰:
#使用缩写和宏的Makefile
MARCO = prog1.o prog2.o
prog:$(MARCO)
gcc prog1.o prog2.o -o $@
prog1.o:prog1.c lib.h
gcc -c -I. -o $@ $《
prog2.o:prog2.c
gcc -c $*.c
对于很大的项目来说,自己手写Makefile非常麻烦,而标准的GNU软件(如Apacle)都是运行一个configure脚本文件来产生Makefile;GNU软件automake和autoconf就是自动生成configure的工具。开发人员只需要先定义好宏,automake处理后会产生供autoconf使用的Makefine.in,再用autoconf就可以产生configure。要使用automake和autoconf必须安装:GNU Automake,GNU Autoconf,GNU m4,perl和GNU Libtool。
Ps:本文部分内容出自系统之家的文章,感谢该文章作者qipeng