2024年网络安全最新嵌入式学习DAY16 --- 1


头文件中写的内容:  
 1.预处理指令  
 ->防止头文件重复包含的预处理指令  
 ->宏定义  
 2.类型定义  
 typedef  
 3.函数声明


使用头文件的目的:  
 给函数调用时,做语法检查  
 提供类型定义,宏定义



注意:
任何C语言工程中,有且仅有一个main函数。
在C语言中,凡是看到以#开头的指令,大多都是预处理指令


GCC编译器的编译流程:  
 1.预处理:  
 作业:处理预处理指令  
 预处理指令:  
 *常用的:  
 #include  
 #define  
 #if  
 #ifdef  
 #endif  
 #else  
 #elif  
 #ifndef  
 不常用的:  
 #pragam  
 #error*


#if开头的常用于代码过滤和条件编译  
 预处理的命令:  
 gcc -E xxx.c -o xxx.i


2.编译  
 作用:将.c/.i原文件编译成.s汇编文件  
 编译指令:  
 gcc -S xxx.c/i  
 不用-o重命名,默认生成.s文件  
 可以通过汇编代码分析程序执行过程和过程中产生的错误。


3.汇编  
 作用:将汇编指令翻译成机器指令(二进制指令)  
 汇编指令:  
 gcc -c xxx.c/i/s  
 不用-o重命名,默认生成.o文件(我们称为目标文件)  
 目标文件是不可执行的二进制文件,因为没有链接库,所以不能执行。


4.链接  
 链接库


vi快速跳转:  
 一定是在命令行模式下:  
 光标快速回到文件开头:gg  
 光标快速回到文件末尾:shift g  
 光标快速移动到某一行:首先保证光标在第一行,输入想要跳转的行数,回车


函数调用的格式:  
 <函数返回值类型的变量> = <被调函数名>(<实参列表>);  
 <被调函数名>(<实参列表>);


例子:



int main()
{
man();
return 0;
}

		int main()
		{
			int ret = man();
			return 0;
		}

搭建工程目录:  
 mkdir myproname  
 cd myproname  
 mkdir bin obj include src


工程管理工具:  
 make  
 工程管理文件:Makefile/makefile


make遵循Makefile中编写的规则来管理工程


make的使用


make:编译工程  
 make clean:执行clean规则,清空编译产生的文件  
 make -C:进入制定的目录执行make


makefile的编写:  
 Makefile是一个文件,文件名为Makefile/makefile


目标: 依赖  
 规则


例子:



mystrlen.out : main.o myopt.o
gcc main.o myopt.o -o mystrlen.out
rm *.o
main.o : main.c
gcc -c main.c -o main.o
myopt.o : myopt.c
gcc -c myopt.c -o myopt.o
clean:
rm mystrlen.out


例子1:



myman : main.o man.o
gcc main.o man.o -o myman
rm *.o
main.o : main.c
gcc -c main.c -o main.o
man.o : man.c
gcc -c man.c -o man.o -D VER1


生成工程时:make  
 清空工程时:make clean


makefile可以自己推导编译命令:  
 例如:



mystrlen.out : main.o myopt.o
gcc main.o myopt.o -o mystrlen.out
rm *.o
main.o : main.c
myopt.o : myopt.c
clean:
rm mystrlen.out


makefile中的变量:



obj= main.o myopt.o
mystrlen.out : $(obj)
gcc main.o myopt.o -o mystrlen.out
rm $(obj)
main.o : main.c
myopt.o : myopt.c
clean:
rm mystrlen.out


常见的自动变量:  
 $\*:不包含扩展名的目标文件  
 $+:所有的依赖文件,以空格分开,并以出现的先后为序  
 $<:第一个依赖文件的名称  
 $?:所有时间戳比目标文件晚的依赖文件,并以空格分开  
 $@:目标文件的完整名称  
 $^:所有不重复的目标依赖文件,以空格隔开  
 $%:如果目标是归档成员,则该变量表示目标的归档成员名称


例子:



mystrlen.out : main.o myopt.o
gcc $+ -o $@
rm $+
main.o : main.c
myopt.o : myopt.c
.PHONY : clean
clean:
rm mystrlen.out



注意://.PHONY:用来修饰clean,使得此clean与其他clean区分开来,让执行make clean执行其下面的命令。


工程目录下嵌套的makefile  
 humpro-------------bin  
 |  
 |----------obj------------------Makefile  
 |  
 |----------include  
 |  
 |----------src------------------Makefile  
 |  
 |----------Makefile


工程目录中:  
 Makefile:  


### 一、网安学习成长路线图


网安所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/aa7be04dc8684d7ea43acc0151aebbf1.png)


### 二、网安视频合集


观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/f0aeee2eec7a48f4ad7d083932cb095d.png)


### 三、精品网安学习书籍


当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/078ea1d4cda342f496f9276a4cda5fcf.png)


### 四、网络安全源码合集+工具包


光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/e54c0bac8f3049928b488dc1e5080fc5.png)


### 五、网络安全面试题


最后就是大家最关心的网络安全面试题板块  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/15c1192cad414044b4dd41f3df44433d.png)![在这里插入图片描述](https://img-blog.csdnimg.cn/b07abbfab1fd4edc800d7db3eabb956e.png)  



**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以点击这里获取](https://bbs.csdn.net/topics/618540462)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 9
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值