1、常用的linux命令
ls cd mv mkdir rm mv cp pwd clear whoami touch cat more head tail rmdir ping ifconfig find grep man sudo
2、vim文本编辑器常用的操作
vim 三大模式:正常、插入、行底 切换方式 i Esc 光标移动: gg 光标跳转到第一行 G 光标跳转到最后一行 nG 跳转到第n行 删除代码: x 删除一个字符 nx 删除n个字符 dw/de 删除一个连续的字符串 dd 删除一行 ndd 删除n行 d$ 从光标处删到行尾 d^ 从光标处删到行首 dgg dG 复制代码: yy nyy p/P粘贴 替换代码: r 替换一个字符 cw 替换一个单词 R 进入替换模式 撤销操作: u 撤销上一次操作 U 撤销最后操作的一行的所有操作 ctrl+r 取消撤销操作 进入插入模式: i I a A o O 插入模式: jj Ctrl+x Ctrl+z Ctrl+p自动补全,正常模式下自动补全头文件main函数 行底模式: set nu、set nonu、 %s/old/new 全文每行替换第一个old %s/old/new/g 全文替换 >n n行代码向右缩进 <n /key 查询key关键词,n向下,N向上 !cmd 执行命令
3、gcc常用的编译参数
-E -S -c -o -I指定头文件加载路径 -l 指定加载的代码库 -lm -Wall -Werror -D 在命令行定义宏 -std 4、C代码变为可执行程序的过程 预处理 查看宏函数的替换结果,检查宏函数 gcc -E code.c -o code.i 编译 理解C代码底层的工作原理++i/i++区别,函数重载的原理 gcc -S code.i 汇编 生成代码库,静态库、共享库 gcc -c code.s ->code.o 目标文件(二进制代码) 链接 多文件编程的基础 gcc a.o b.o c.o … ->a.out
6、long字节数、char short 的取值范围?
7、int float、 指针 bool的零值判断 if(0num) if(0.0000001> f && f>-0,0000001) if(NULLp) if(flag)
8、C语言的类型限定符有哪些,功能分别是 static: 改变存储位置: 改变局部变量的存储位置:由stack栈内存改为data或者bss(由局部变量是否初始化决定) 被它修饰过的局部变量也称为静态局部变量 延长生命周期: 延长局部变量的生命周期 限制作用范围: 限制全局变量、函数只能在本文件中使用
const: 保护变量不被显示的修改
volatile
register 申请把变量的存储介质由内存改为寄存器,但是寄存器有限,不一定能百分百成功 auto
extern
typedef time_t size_t uint8_t 类型重定义,在定义变量之前加上typedef 变量名就变成了这种类型 注意:不是替换关系 typedef int num; #define int num
unsigned
signed
存储介质:硬盘<内存条<缓存<寄存器
9 与指针相关的知识点
1、什么是指针 指针就是一种特殊的数据类型,使用它可以定义指针变量,指针变量存储的就是整型数据,代表了内存的编号,通过这个编号可以访问到对应的内存
2、什么情况下使用指针 、函数之间是相互独立的,但是有时候需要共享变量。 函数传参是值传递 全局变量容易命名冲突 使用数组还需要传递长度 命名空间是独立的,但是地址空间是同一个,所以指针可以解决这个问题 2、由于函数之间传参是值传递(内存拷贝),对于字节数较多的变量,值传递的效率较低,如果传递变量的地址只需要传递4\8字节。 3、堆内存无法 取名字,它不像data、bss、stack让变量名与内存之间建立对应关系,只能使用指针记录堆内存的地址来使用该段内存。
3、使用指针要注意的·问题 空指针:值为NULL的指针变量都叫做空指针,如果对空指针进行解引用就会产生段错误
NULL也是一种错误标志,如果一个函数的返回值是指针类型,当函数执行错误时可以返回NULL,表示出错。
如何避免空指针带来的段错误:使用任何来历不明的指针前都先做判断
1、当函数的参数是指针时,别人传给你的有可能是空指针
2、从函数获取的返回值也可能是空指针
if(NULL == p)
注意:NULL在绝大多数系统中都是0,有个别系统是1
野指针:指向不确定的内存空间
对野指针进行解引用:
1、段错误
2、脏数据
3、一切正常
野指针比空指针危害更严重,因为它无法判断出来,而且可能是隐藏型的错误短时间难以发现
所有的野指针都是程序员自己制造的,如何避免产生野指针:
1、定义指针变量时一定要初始化 int* p = #
2、函数不要返回栈内存的地址
3、指针指向的内存释放后,指针变量要及时置空 = NULL
4、指针的运算 指针变量中存储的就是整数,理论上整型数据能使用的运算符它都可以使用,但大多数都是没有意义的。 指针 + n <> 指针 + 指针类型宽度*n 前进了n个元素 指针 - n <> 指针 - 指针类型宽度n 后退了n个元素 指针 - 指针 <==> 指针之前相差的总字节数/指针类型宽度 计算出两个指针之间相隔了多少个指针元素 5、const与指针 当我们为了提高传参效率而使用指针时,传参的效率提高了,但是变量也因此有了被修改的风险,而使用const与指针配合,可以保护指针指向的内存 const int p; 指针所指向的内存不可修改 int const* p; 同上 int* const p; 指针的指向不可修改 const int* const p; 指针的指向以及所指向的内存都不可以修改 int const* const p; 同上 6、数组指针与指针数组 指针数组: 就是由指针组成的数组,成员都是指针变量 类型* arr[长度]; 数组指针: 专门指向数组的指针 类型 (*arr)[长度];
8、二级指针 二级指针就是指向指针的指针,里面存储的是指针变量的地址。 定义: 类型** 变量名_pp; 赋值: 变量名_pp = &指针变量; int num = 10; int* p = # int** pp = &p; 解引用: *变量名_pp <=> 指针 **变量名_pp <=> *指针
|