[TakeLionOS汇编与C语言自学笔记-第五课] 版权所有 2021年 江志剑 按照《21天学通C语言》(第七版),有如下二个例子。 一个例子输出一段话,另一个例子计算年份: //1、files:hello1.c hello1no.s hello1.exe #include int main(void) { printf("This is an example of sometjing printed!"); return 0; } //2、files:helloyear.c helloyearno.s helloyear.exe #include #define TARGET_AGE 88 int year1, year2; int calcYear(int year1); int main(void) { printf("What year was the subject born?"); printf("Enter as a 4-digit year (YYYY):"); scanf("%d", &year1); year2 = calcYear(year1); printf("Someone born in %d will be %d in %d.", year1, TARGET_AGE, year2); return 0; } int calcYear(int year1) { return (year1 + TARGET_AGE); } 我是用GCC 8.1.0在命令行窗口运行的。 GCC编译时候,其实有四个步骤: 1、预处理:gcc -E hello.c -o hello.i 2、编译生成汇编语言:gcc -S hello.i -o hello.s 3、汇编:gcc -c hello.s -o hello.o 4、链接生成可执行文件:gcc hello.o -o hello 这时候,我想看一下第二步生成的汇编语言代码。 因为本身就是研究操作系统的一部分,所以要研究底层的汇编语言。 结果发现是AT&T格式的汇编语言风格,而且大量使用汇编宏。 所以启用了GCC的编译选项-fno-asynchronous-unwind-tables,直接预处理为cfi宏的汇编指令。 这里就是包含*no.s形式的文件。 比较发现,第一个文件和第二个文件,关键看寄存器的使用以及子函数的调用。 还有就是全局变量的使用。 我们学习汇编语言,因为零基础不知道学习什么?所以先有个概念。 比如这时候,几节课下来,就知道了该认真学习寄存器的用法了。 这是一个基本概念,现在反复用到了。 最后的LEAVE指令,等效于“MOV ESP,EBP”和“POP EBP”两条指令。 这个指令调整了数据栈指针ESP,并将EBP的数值恢复到调用这个函数之前的初始状态。 毕竟函数要在退出之前恢复这些寄存器的值。
2021-08-30 14:01:22 33KB 汇编 C GCC OS
[TakeLionOS汇编与C语言自学笔记-第四课] 版权所有 2021年 江志剑 按照《21天学通C语言》(第七版),有如下二个例子。其中一个改为输出黑桃符号,是练习题3修改一下的: //1、files:helloxy.c helloxy.i helloxyno.s helloxy.exe #include int x,y; int main(void) { for (x = 0; x < 10;x++, printf("\n")) for ( y = 0; y < 10; y++) printf("X"); return 0; } //2、files:helloxyq.c helloxyq.i helloxyqno.s helloxyq.exe #include int x,y; int main(void) { for (x = 0; x < 10;x++, printf("\n")) for ( y = 0; y < 10; y++) printf("%c",6); return 0; } 我是用GCC 8.1.0在命令行窗口运行的。 GCC编译时候,其实有四个步骤: 1、预处理:gcc -E hello.c -o hello.i 2、编译生成汇编语言:gcc -S hello.i -o hello.s 3、汇编:gcc -c hello.s -o hello.o 4、链接生成可执行文件:gcc hello.o -o hello 这时候,我想看一下第二步生成的汇编语言代码。 因为本身就是研究操作系统的一部分,所以要研究底层的汇编语言。 结果发现是AT&T格式的汇编语言风格,而且大量使用汇编宏。 所以启用了GCC的编译选项-fno-asynchronous-unwind-tables,直接预处理为cfi宏的汇编指令。 这里就是包含*no.s形式的文件。 比较发现,第一个文件和第二个文件,其余基本一样,但是第20行不一样了: helloxy.s:movl $88, (%esp) //大写X helloxyq.s:movl $6, (%esp) //黑桃 也没有出现.ascii宏,因为不是输出字符串了,而是输出字符X和黑桃符号。 最后的LEAVE指令,等效于“MOV ESP,EBP”和“POP EBP”两条指令。 这个指令调整了数据栈指针ESP,并将EBP的数值恢复到调用这个函数之前的初始状态。 毕竟函数要在退出之前恢复这些寄存器的值。
2021-08-25 17:01:49 42KB 汇编 C GCC OS
计算机二级python科目,本人自学笔记,有需要自取
2021-08-24 19:39:53 7.06MB python 计算机二级 笔记 markdown
1
郝斌老师数据结构视频对应的自学笔记及详细代码。在此感谢郝斌老师的视频,真的很有帮助
2021-08-24 15:28:40 3.06MB 数据结构
1
[TakeLionOS汇编与C语言自学笔记-第三课] 版权所有 2021年 江志剑 按照《21天学通C语言》(第七版),有如下二个修改版的例子。其中一个改为输出黑桃符号,其中一个改为输出红心符号,是练习题6修改一下的: //1、files:helloqq.c helloqq.i helloqq.s helloqqno.s helloqq.exe #include int main(void) { printf("%c",6); return 0; } //2、files:helloq.c helloq.i helloq.s helloqno.s helloq.exe #include int main(void) { printf("%c",3); return 0; } 我是用GCC 8.1.0在命令行窗口运行的。 GCC编译时候,其实有四个步骤: 1、预处理:gcc -E hello.c -o hello.i 2、编译生成汇编语言:gcc -S hello.i -o hello.s 3、汇编:gcc -c hello.s -o hello.o 4、链接生成可执行文件:gcc hello.o -o hello 这时候,我想看一下第二步生成的汇编语言代码。 因为本身就是研究操作系统的一部分,所以要研究底层的汇编语言。 结果发现是AT&T格式的汇编语言风格,而且大量使用汇编宏。 这里就是不包含*no.s形式的文件。 所以启用了GCC的编译选项-fno-asynchronous-unwind-tables,直接预处理为cfi宏的汇编指令。 这里就是包含*no.s形式的文件。 比较发现,第一个文件和第二个文件,其余基本一样,而且第12行开始的调用函数完全一样了: helloqq.s:call _putchar helloq.s:call _putchar 也没有出现.ascii宏,因为不是输出字符串了,而是输出黑桃和红心符号。 唯一差别就是第12行:movl $6, (%esp)和movl $3, (%esp) 这样就能开始领会汇编语言的奥妙,开始学到汇编语言了。因为其他都是一样的,照抄即可。 最后的LEAVE指令,等效于“MOV ESP,EBP”和“POP EBP”两条指令。 这个指令调整了数据栈指针ESP,并将EBP的数值恢复到调用这个函数之前的初始状态。 毕竟函数要在退出之前恢复这些寄存器的值。
2021-08-23 13:02:26 42KB 汇编 C GCC OS
按照《21天学通C语言》(第七版),有如下二个例子。其中一个改为输出红心符号,是练习题6修改一下的: //1、files:hello.c hello.i hello.s hellono.s hello.exe #include int main(void) { printf("Hello, World!"); return 0; } //2、files:helloq.c helloq.i helloq.s helloqno.s helloq.exe #include int main(void) { printf("%c",3); return 0; } 我是用GCC 8.1.0在命令行窗口运行的。 GCC编译时候,其实有四个步骤: 1、预处理:gcc -E hello.c -o hello.i 2、编译生成汇编语言:gcc -S hello.i -o hello.s 3、汇编:gcc -c hello.s -o hello.o 4、链接生成可执行文件:gcc hello.o -o hello 这时候,我想看一下第二步生成的汇编语言代码。 因为本身就是研究操作系统的一部分,所以要研究底层的汇编语言。 结果发现是AT&T格式的汇编语言风格,而且大量使用汇编宏。 这里就是不包含*no.s形式的文件。 所以启用了GCC的编译选项-fno-asynchronous-unwind-tables,直接预处理为cfi宏的汇编指令。 这里就是包含*no.s形式的文件。 比较发现,第一个文件和第二个文件,其余基本一样,但是第12行开始的调用函数完全不一样了: hello.s:call _printf helloq.s:call _putchar 也没有出现.ascii宏,因为不是输出字符串了,而是输出红心符号。 最后的LEAVE指令,等效于“MOV ESP,EBP”和“POP EBP”两条指令。 这个指令调整了数据栈指针ESP,并将EBP的数值恢复到调用这个函数之前的初始状态。 毕竟函数要在退出之前恢复这些寄存器的值。
2021-08-22 18:01:27 42KB 汇编 C GCC OS
AS400初学者自学笔记整理,AS400初学者学习笔记
2021-08-16 22:00:51 1.37MB AS400学习
1
按照《21天学通C语言》(第七版),有如下三个例子。其中一个改为输出中文: //1、files:hello.c hello.i hello.s hellono.s hello.exe #include int main(void) { printf("Hello, World!"); return 0; } //2、files:hello1.c hello1.i hello1.s hello1no.s hello1.exe #include int main(void) { printf("This is an example of sometjing printed!"); return 0; } //3、files:hellocn.c hellocn.i hellocn.s hellocnno.s hellocn.exe #include int main(void) { printf("这样打印输出一个字符 , %c\n 一个数字 , %d\n 一个浮点数字 , %f", 'z', 123,456.789); return 0; } 如果直接编译运行,则为出现乱码。 怎么解决中文乱码? 然后观察三个文件的汇编语言版本的差异。 从中学习汇编与C语言知识。
2021-08-16 13:01:06 64KB 汇编 C GCC OS
免费下载,纯自学笔记,解释说明详细!!! 保证半小时内搞定所有markdown基础语法!!!
2021-08-14 01:34:01 5KB markdown
1
STM32自学笔记.zip
2021-08-13 09:09:16 35.23MB 自学笔记