20145211《信息安全系统设计基础》第2周学习总结————愬秋风以开襟
教材学习内容总结
Vim相关操作
- vim可以仅仅通过键盘在任意模式之中进行切换,这就使得Vim可以不用进行菜单或者鼠标操作,并且最小化组合键的操作,对文字录入员或者程序员可以大大增强速度和效率。vim有6种基本模式(常用的是普通模式、插入模式和命令行模式)
- 普通模式(Normal mode):在普通模式中,用的编辑器命令,比如移动光标,删除文本等等。这也是Vim启动后的默认模式。在普通模式中,进入插入模式比较普通的方式是按a(append/追加)键或者i(insert/插入)键。
- 插入模式(Insert mode):在插入模式中,可以按ESC键回到普通模式。
可视模式(Visual mode):命令多与字母v有关,移动命令会扩大高亮的文本区域。高亮区域可以是字符、行或者是一块文本。 - 选择模式(Select mode):这个模式中,可以用鼠标或者光标键高亮选择文本,不过输入任何字符的话,Vim会用这个字符替换选择的高亮文本块,并且自动进入插入模式。
- 命令行模式(Command line mode):在命令行模式中,执行命令(:键),搜索(/和?键)或者过滤命令(!键)。在命令执行之后,Vim返回到命令行模式之前的模式,通常是普通模式。
- Ex模式(Ex mode):这和命令行模式比较相似,在使用:visual命令离开Ex模式前,可以一次执行多条命令。
- 三种常用模式的切换:
- 进入vim:
在终端中输入 vim 文件名;
在终端中输入vim,进入vim界面中,进入命令行模式输入:e 文件路径(文件名)
处于插入模式或命令行模式时只需要按Esc或者Ctrl+[即可进入普通模式; - 普通模式中按i(插入)或a(附加)键都可以进入插入模式;
普通模式中按:进入命令行模式; - 命令行模式中输入wq回车后保存并退出vim。
- 退出vim:
- 命令行模式下退出vim:从普通模式输入:进入命令行模式,输入wq回车,保存并退出编辑。
- 普通模式下退出vim:普通模式下输入Shift+zz即可保存退出vim
- 普通模式下删除文本:
- 使用vim编辑多个文件:
编辑多个文件有两种形式:一种是在进入vim前使用的参数就是多个文件;另一种就是进入vim后再编辑其他的文件。同时创建两个新文件并编辑$ vim 1.txt 2.txt。
默认进入1.txt文件的编辑界面:命令行模式下输入:n编辑2.txt文件,可以加!即:n!强制切换,之前一个文件的输入没有保存,仅仅切换到另一个文件;命令行模式下输入:N编辑1.txt文件,可以加!即:N!强制切换,之前文件内的输入没有保存,仅仅是切换到另一个文件。
进入vim后打开新文件:
命令行模式下输入:e 3.txt打开新文件3.txt
命令行模式下输入:e#回到前一个文件
命令行模式下输入:ls可以列出以前编辑过的文档
命令行模式下输入:b 2.txt(或者编号)可以直接进入文件2.txt编辑
命令行模式下输入:bd 2.txt(或者编号)可以删除以前编辑过的列表中的文件项目
命令行模式下输入:e! 4.txt,新打开文件4.txt,放弃正在编辑的文件
命令行模式下输入:f显示正在编辑的文件名
命令行模式下输入:f new.txt,改变正在编辑的文件名字为new.txt
恢复文件:vim -r进入文档后,输入:ewcover 1.txt来恢复。
GCC介绍
-
gcc 编译程序的流程(参数是ESc,文件的后缀是iso):
预处理:gcc –E hello.c –o hello.i;gcc –E调用cpp,产生预处理过的C原始程序
编译:gcc –S hello.i –o hello.s;gcc –S调用ccl,产生汇编语言原始程序
汇编:gcc –c hello.s –o hello.o;gcc -c调用as,产生目标文件
链接:gcc hello.o –o hello;gcc -o调用ld,产生可执行文件
运行:./hello -
gcc编译常用选项:-E(只预编译)、-S(只编译不汇编)、-o(将file文件指定为输出文件)、-c(只编译不链接)、-I dir(在头文件的搜索路径列表中添加dir目录)、-g(在可执行程序中包含标准调试信息)
库选项:-static(进行静态编译,即链接静态库、禁止使用动态库)、-shared(生成动态库文件、进行动态编译,在没有动态库时才会链接同名静态库)、-L dir(在库文件的搜索路径列表中添加dir目录)、-lname、-fPIC(生成使用相对地址的位置无关的目标代码,然后使用gcc的-static选项从该PIC目标文件生成动态库文件)
静态库是一系列的目标文件(.o文件)的归档文件((lib+name).a文件);链接阶段,选择静态库,后缀名为“.a”,选择动态库,后缀名为“.so”。
静态链接库的生成:gcc -c 文件名.c ar rcsv libxxx.a xxx.o;
静态库的使用:gcc -o 文件名 文件名.c -L. -lxxx //链接到静态库;
注意:-L:在库文件的搜索路径列表中添加dir目录,-l: 在头文件的搜索路径列表中添加dir目录。
静态库示例: -
共享库的生成:gcc -fPIC -c xxx.c gcc -shared -o libxxx.so xxx.o;共享库的使用:gcc -o main main.c -L. -lxxx
-
注册共享库的方法:
修改/etc/ld.so.conf文件
修改LD_LIBRARY_PATH环境变量
将库文件直接复制到/lib或者/usr/lib目录下:cp (lib+name).so /lib
动态库示例: -
gcc警告和出错选项列表:
-w:关闭所有告警
-Wall:允许发出gcc提供的所有有用的报警信息
-werror:把所有的告警信息转化为错误信息,并在告警发生时终止编译过程
GDB 使用
程序的运行状态有“运行”、“暂停”、“停止“三种。
主要操作:
查看文件:l
设置断点:在b后加入相对应的行号。例b 6
查看断点情况:设置完断点后键入info b,在gdb中可以设置多个断点。bt查询调用函数的情况
运行代码:默认从首行开始运行代码,键入r;r+行号:从该行号开始运行
查看变量值:p变量。例:p n
单步运行:n或s,s会进入函数,n不会进入函数
恢复程序运行:c
帮助信息:h
断点的设置:
函数:b 文件名.c:函数名
行:b 行数
条件:b 行数 if 表达式(例如:b 9 if == 12)
临时:tb [文件名:]行号或函数名 <条件表达式>
GDB测试示例:
Makefile 介绍
- 一个工程中的源文件不计其数,按其类型、功能、模块分别放在若干个目录中。makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至进行更复杂的功能操作。其带来的好处就是——“自动化编译”,一但写好,只需要一个make命令,整个工程完全编译,极大的提高了软件的开发效率。
- makefile文件编写规则:
目标文件:由make创建,通常是目标文件或可执行文件
依赖文件:创建目标体所依赖的文件
运行命令:创建每个目标体时需要的运行命令,必须以tab键开头
格式为:目标文件:依赖文件列表 [tab键]各目标体运行命令(注意不是空格)
使用make的格式:make 目标文件
makefile变量的定义:
递归展开方式:在引用该变量时进行替换(不能用于引用自己的情况),缺点:不能在变量后追加内容
格式定义:VAR = var
展开方式:在定义处展开,并只展开一次。优点:消除变量的嵌套引用
格式定义:VAR := var
make中变量的使用格式: $(变量名)
变量名的命名:不包括“:”、“#”、“=”以及结尾空格的任何字符串;变量名大小写不敏感
课后作业中的问题和解决过程
-
第一个问题的出现很神奇,在我非常方便的在linux下访问windows里的盘区的时候,有一天,他突然出现了这个error
看看报错:Please resume and shutdown Windows fully (no hibernation or fast restarting)译:请重启电脑把windows 完全关闭 (没有休眠或者快速启动)奇怪了,明明已经关机了啊?后来此发现,windows下为了快速启动,内核采用了“休眠”的模式,启动时就是混合启动,所以速度很快,一般8秒左右;
后来,我在网上找到一堆要在挂载区下修改读写权限的办法,感觉很复杂,完全不懂~我想,不就是没完全关机吗,我就切换到win10下,shutdown -s -t 1
表示毫无压力,ubuntu下又可以访问盘区了(其实这样只是写博客比较方便,一般我很少访问盘区)
下面是网上的办法。。。
在这种情况下,是没有办法设置读写权限的只能是-ro (read only只读)所以只能在/etc/fstab 里设置:UUID=1E7E5FE17E5FAFEF /media/222 ntfs ro,defaults,auto,nodev,nosuid,user,force 0 0 #只能是ro ,如果是rw启动会报错!
通过$ ls -all /dev/disk/by-uuid/ 可以查到UUID
注意:这样挂载不能对挂载盘的修改!!read only!!!
如果你的win8 没有设置快速启动或者没有什么问题的话,应该可以吧ro改为rw(读写)的
-
第二个问题是我安装wireshark时遇到的
安装后打开wireshark 提示权限不足消息:Couldn’t run /usr/bin/dumpcap in child process: Permission denied
先试了网上第一个方法:
sudo apt-get install libcap2-bin
;- 添加一个组,名字为
wireshark
我执行时,提示已经存在相同名字的组了
sudo groupadd wireshark
; - 把自己当前的用户名添加到 wireshark组
sudo usermod -a -G wireshark YOUR-USER-NAME newgrp wireshark
; - 修改组别
sudo chgrp wireshark /usr/bin/dumpcap
- 添加执行权限
sudo chmod 754 /usr/bin/dumpcap
- 最后一步:
Grant Capabilities
执行下面两句其中一句就可以了
sudo setcap cap_net_raw,cap_net_admin=eip /usr/bin/dumpcap
sudo setcap 'CAP_NET_RAW+eip CAP_NET_ADMIN+eip' /usr/bin/dumpcap
重启系统,发现全是鬼话。。
于是我又试了第二个方法,修改init.lua
终端运行sudo gedit /usr/share/wireshark/init.lua
倒数第二行原来为:dofile(DATA_DIR.."console.lua")
改为--dofile(DATA_DIR.."console.lua")
- 还有一个问题,你们发现没有,linux下耗电巨快,有没有,一个下午充了好几次电~
我在网上看了一下,说是双显卡的原因,不太懂,解决办法是关掉一个显卡,平时不用独立显卡的时候关闭Nvidia,启用intel集成显卡,然而并没有什么用。。。有大神解决的说一下 - 还有,巨坑的是linux下的浏览器都无法支持上edu。。说他的协议不可靠,简直了这linux的安全性能~
其他(感悟、思考等,可选)
- 每次到这一步都特别开心,毕竟千呼万唤始出来。前天读了《闲居赋》,里面有一句话还是让人感触蛮深的——愬寒风以开襟,愿同衾与穷女;翻译过来就是想敞开胸膛面对疾风,和没钱的女子盖一条被子;闲居的时候都不忘记穷人的疾苦,这思想境界~还是要多向古人学习,做一个高尚的人,做一个纯粹的人,做一个远离低级趣味的人!
-嗯。
学习进度条
代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | 重要成长 | |
---|---|---|---|---|
目标 | 5000行 | 30篇 | 400小时 | |
第一周 | 120/200 | 1/2 | 16/16 | 学习Linux核心命令 |
第二周 | 100/200 | 1/3 | 30/46 | 学习vim,gcc以及gdb的基本操作 |