上一页 1 ··· 13 14 15 16 17 18 19 20 21 ··· 32 下一页
摘要: 文件格式 (1)BIN文件:binary文件,即二进制文件。Bin目录用来保存项目生成后程序集,它有Debug和Release两个版本,分别对应的文件夹为bin/Debug和bin/Release,这个文件夹是默认的输出路径,我们可以通过:项目属性—>配置属性—>输出路径来修改。 (2)HEX文件: 阅读全文
posted @ 2018-09-13 17:05 小时候挺菜 阅读(1500) 评论(0) 推荐(0) 编辑
摘要: 在C语言中只能通过malloc()和其派生的函数进行动态的申请内存,而实现的根本是通过系统调用实现的(在linux下是通过sbrk()系统调用实现)。 malloc()到底从哪里得到了内存空间?答案是从堆里面获得空间。也就是说函数返回的指针是指向堆里面的一块内存。操作系统中有一个记录空闲内存地址的链 阅读全文
posted @ 2018-09-12 16:00 小时候挺菜 阅读(42158) 评论(4) 推荐(7) 编辑
摘要: 一般情况下我们最好是在一个平台上编译本平台的二进制程序,比如在32位平台上编译32位程序而在64位平台上编译64位程序。 现在64位的系统(这里主要指x86_64系统,包括AMD64和Intel的EM64T)已经开始广泛的使用起来了,甚至于你现在要是想买32位的处理器根本就没有。64位的系统在性能和 阅读全文
posted @ 2018-09-12 15:07 小时候挺菜 阅读(12223) 评论(1) 推荐(2) 编辑
摘要: 数组简介 如果各位猿友是一路跟着LZ看到这里的,那么数组的定义就非常简单了,它就是一个相同数据类型的数据集合。数组存储在一系列逻辑上连续的内存块当中,之所以说是逻辑上连续,是因为整个内存或者说存储器本身就是逻辑上连续的一个大内存数组。如果我们用Java语言的类型来表示我们的存储器的话,可以看做是by 阅读全文
posted @ 2018-09-11 20:01 小时候挺菜 阅读(5917) 评论(0) 推荐(1) 编辑
摘要: 栈帧的结构 倘若我们要想搞清楚过程的实现,就必须先知道栈帧的结构是如何构成的。栈帧其实可以认为是程序栈的一段,而程序栈又是存储器的一段,因此栈帧说到底还是存储器的一段。那么既然是一段,肯定有两个端点,这个不需要LZ再普及了吧。 这两个端点其实就是两个地址,一个标识着起始地址,一个标识着结束地址,而这 阅读全文
posted @ 2018-09-11 20:00 小时候挺菜 阅读(6656) 评论(1) 推荐(3) 编辑
摘要: 条件码寄存器 这个子标题在之前就提到过,条件码寄存器与普通的寄存器不同,它们都是1位寄存器,换句话说,它们当中的值只有0和1。当有算术与逻辑操作发生时,这些条件码寄存器当中的值会相应的发生变化,这算是比较神奇的地方吧。 书中列出了四种常用的寄存器,它们的名字与作用分别如下所述,以下是LZ的理解。 C 阅读全文
posted @ 2018-09-11 19:58 小时候挺菜 阅读(857) 评论(0) 推荐(1) 编辑
摘要: 我们先来看看这些指令的大致介绍,如果各位看过上一章的话,会发现这里的指令有的会有些眼熟,但是它们的作用却截然不同。以下是书中的一张概图。 第一个指令有些眼熟吧,它就是我们上一章当中的imul乘法指令的双字形式。不过可以看出,这里的imull指令已经完全变了味道,它将结果存入两个寄存器。接下来,我们来 阅读全文
posted @ 2018-09-11 09:14 小时候挺菜 阅读(357) 评论(0) 推荐(0) 编辑
摘要: eal指令是非常神奇的一个指令,它可以取一个存储器操作数的地址,并且将其赋给目的操作数。如果用C语言当中来对应的话,它就相当于&运算。 比如对于leal 4(%edx,%edx,4),%eax这条指令来讲,我们假设%edx寄存器的值为x的话,那么这条指令的作用就是将 4 + x + 4x = 5x 阅读全文
posted @ 2018-09-10 15:53 小时候挺菜 阅读(1270) 评论(0) 推荐(0) 编辑
摘要: mov指令 mov指令的作用是将源操作数S中的数据复制到目的操作数D中,mov指令有一个数据格式和两个操作数,因此一般的形式为[movx S D]。其中x为数据格式,S为源操作数,D为目的操作数。 这里举一个简单的例子,比如我们有一条指令为movl %edx %eax。那么它的执行过程就如下图所示。 阅读全文
posted @ 2018-09-10 15:32 小时候挺菜 阅读(542) 评论(0) 推荐(0) 编辑
摘要: 无符号数加法 对满足0 =< x, y<2w的x和y有: 例如:无符号数65535 + 1 为10000000000000000,由于超过16位,所以截断后0~15位都是0,因此结果为0 结果为0 补码加法运算 补码加法运算就是先按照无符号加法进行运算,而后在进行无符号和有符号的转换 对满足 -2w 阅读全文
posted @ 2018-09-10 11:17 小时候挺菜 阅读(552) 评论(0) 推荐(0) 编辑
上一页 1 ··· 13 14 15 16 17 18 19 20 21 ··· 32 下一页