最赞回答 / 小雾3378873
一段程序执行太快了,若想知道该程序在执行过程的每一步执行后对结果的影响或者了解该语句的作用,则需要一种调试工具,让他动作变慢,并且随着你的控制让他一步一步的执行,而且其间你可以用一些命令查看内存,验证结果,这就是gdb调试工具的作用。以下是我的笔记:GDB可以对程序进行断点调试,单步调试,如果用gdb调试,需要对程序重新编译,格式为:gcc –g main.c –o main.out这样生成的main.out才能用gdb调试。需要注意的是,在调试的时候不能删除原代码文件,即main.c ,如果将main....
2016-04-11
最新回答 / 实时编程
0x1 代表一个地址 不管是32位 还是64位系统 都是 使用 一个 32位 2进制 或者64位二进制 来 寻找这个地址而地址 里面 保存的 数据 是一个 8位 2进制数这个 8位2进制 恰巧是一个字节 所以 从0x1 到0x5 增加了 4个字节 不管是 32位 还是64位 地址只是表达 具体位置 里面的 内容 确实个8位的 2进制数 而已
2016-04-01
最新回答 / 慕后端9788028
我按楼主程序运行,在Linux下同样出现相同的情况,执行到循环时,gdb也不能打出值来。换了c-free ,第三个输出就出现莫名的值,我认为这是编译器的问题。
2016-03-26
已采纳回答 / 咸鱼干儿
因为在RAM内存中最小的存储单位是8bit也就是1Byte,但是地址总线是32位,所以可以寻址的空间是2^32=4G个最小存储单位,也就是4GB。编号的数字大小不代表内存最小存储单位的大小呀。
2016-03-09
最赞回答 / 慕后端9788028
p[4]=101代表从初始位置(a的地址就始)以四个字节为一步,向前走4步,到达某个位置,然后对这个位置进行初始化赋值,即把101赋给这个地址所代表的内存空间。p[4],*p=101,p[4]代表从初始位置(a的地址就始)以四个字节为一步,向前走4步,到达某个位置。*p=101,代表此时指针指向的地址(即走了四步后所在位置)并对这个地址所在的内存空间进行初始化,赋值101。p+=3于p=p+3等同,加的是步数,原理跟p[3]一样
2016-03-09
已采纳回答 / qq_朕有一车刁民_0
==为什么不会被覆盖,不过你要想避免被覆盖就把数组分为全局和局部的,两个都是全局的肯定会被后者覆盖,前者全局后者局部的,在局部使用的数组不会被覆盖。
2016-02-15