免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: gigabyte
打印 上一主题 下一主题

给内存地址"0x123456789"赋值为0,请写出代码 [复制链接]

论坛徽章:
0
51 [报告]
发表于 2010-03-11 12:06 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
52 [报告]
发表于 2010-03-11 12:07 |只看该作者
"指针p本身的地址是由链接器给出"是什么意思?
下面的指针p的地址是链接器给出的吗?
x2 发表于 2010-03-11 11:42


虚拟地址空间中,进程的用户空间栈的起始地址(栈底)应该是链接器给出的吧(我记得应该是接近3G且小于3G的某个值),那运行时指针p的地址(因为p在main函数中,所以应该在栈地址空间内)也应该在这个范围之内了。

论坛徽章:
0
53 [报告]
发表于 2010-03-11 12:08 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
38
2017金鸡报晓
日期:2017-02-08 10:39:4215-16赛季CBA联赛之深圳
日期:2023-02-16 14:39:0220周年集字徽章-年
日期:2022-08-31 14:25:28黑曼巴
日期:2022-08-17 18:57:0919周年集字徽章-年
日期:2022-04-25 13:02:5920周年集字徽章-20	
日期:2022-03-29 11:10:4620周年集字徽章-年
日期:2022-03-14 22:35:1820周年集字徽章-周	
日期:2022-03-09 12:51:3220周年集字徽章-年
日期:2022-02-10 13:13:4420周年集字徽章-周	
日期:2022-02-03 12:09:4420周年集字徽章-20	
日期:2022-01-25 20:14:2720周年集字徽章-周	
日期:2022-01-13 15:12:33
54 [报告]
发表于 2010-03-11 12:14 |只看该作者
*(int*)(0x123456789)=0;

*(long*)(0x123456789)=0;

*(short*)(0x123456789)=0;

*(char*)(0x123456789)=0;

论坛徽章:
0
55 [报告]
发表于 2010-03-11 12:17 |只看该作者
虚拟地址空间中,进程的用户空间栈的起始地址(栈底)应该是链接器给出的吧(我记得应该是接近3G且小于 ...
new_learner 发表于 2010-03-11 12:07

在i386上好像是由寄存器给的?

  1.     main:
  2.     leal    4(%esp), %ecx
  3.     andl    $-16, %esp
  4.     pushl   -4(%ecx)
  5.     pushl   %ebp
  6.     movl    %esp, %ebp
  7.     pushl   %ecx
  8.     subl    $32, %esp ;;;************这里*************
  9.     movl    $16909060, -24(%ebp)
  10.     movl    $84281096, -20(%ebp)
  11.     movl    $151653132, -16(%ebp)
  12.     leal    -24(%ebp), %eax
  13.     movl    %eax, -12(%ebp)
复制代码

论坛徽章:
0
56 [报告]
发表于 2010-03-11 13:31 |只看该作者
学习

论坛徽章:
0
57 [报告]
发表于 2010-03-11 13:32 |只看该作者
好 列害

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
58 [报告]
发表于 2010-03-11 16:22 |只看该作者
题目:给内存地址"0x123456789"赋值为0,请写出代码

我的做法是
int *p;
p = 0x123456789;
*p =  ...
gigabyte 发表于 2010-03-07 21:45



    谁玩这种找死的程序?

论坛徽章:
0
59 [报告]
发表于 2010-03-11 20:01 |只看该作者
谁告诉你地址链接出来的?需要链接的是全局符号,比如全局变量、函数等等。不是全局的,私有的,就 ...
iamybj 发表于 2010-03-11 12:08


哈哈,如果自动变量也给它个具体地址,那更好玩了。你先看清原帖吧。

论坛徽章:
0
60 [报告]
发表于 2010-03-11 20:08 |只看该作者
回复  bukkake


   64位机器的int也是64位的,,一般来说int和cpu的字长相同
iamybj 发表于 2010-03-11 12:06


过去8位机上的C编译器,int多数是16位的,因为8位太短,不实用。但也有例外,有些用于控制的C编译器,是8位的。
64位编译器也有32位int的。
一句话,因需而定。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP