免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234下一页
最近访问板块 发新帖
查看: 7395 | 回复: 30
打印 上一主题 下一主题

[C] 询问一段代码的合法性 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-06-19 14:04 |只看该作者 |倒序浏览
本帖最后由 slackware12 于 2010-06-19 14:40 编辑

请各位大虾帮帮忙, 解本人一个惑吧. 头要爆了.


  1. int main(void)
  2. {
  3.         int num = 10;
  4.         void *p = #

  5.         *p = 39;    // 此处表达式是不合法的, 但是为什么呢?
  6.         *p + 3;    // 此处代码的也是不合法的, 和上面的问题应该是一样的性质, 但是到底是为什么?
  7.                         // 标准C 有没有规定, 不能对void *型的指针进行间接访问(即进行'*'操作符) ??

  8.         return 0;
  9. }

  10. int main(void)
  11. {
  12.         int *space =(int *) 10;
  13.         void **pp = (void **)&space;
  14.         *pp = (void *)349;     // 为什么此处表达式是通过编译的? pp 是一个void *指针,
  15.                                      // 其指向一个目标空间(此目标空间存储void *型值, 姑且把void *当成 A类型)的地址,
  16.                                      //但是损失了目标空间的地址类型(A *), 那么p 在不知道(A *)的情况下, 怎么能确定目标空间的大小?

  17.         return 0;
  18. }



复制代码

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
2 [报告]
发表于 2010-06-19 14:07 |只看该作者
有。拿分走人……

论坛徽章:
0
3 [报告]
发表于 2010-06-19 14:10 |只看该作者
回复 2# starwing83


    我找不到!   =。=!!  可能是我英语太差的缘故吧。 能否指明一下C99标准文档的页数?

论坛徽章:
0
4 [报告]
发表于 2010-06-19 14:12 |只看该作者
  1. int main(void)

  2. {

  3.         int num = 10;

  4.         void *p = num;
复制代码
void *p=num的意思是void型指针p指向一块地址是0x0000000A的内存。

后面的操作都是对0x0000000A内存进行的操作,出现错误的原因是内块内存还没有映射到程序的地址空间,段错误。

论坛徽章:
0
5 [报告]
发表于 2010-06-19 14:14 |只看该作者
回复 4# 聪聪知不道


    I'm sorry . 那个num 少加了个'&'.

论坛徽章:
0
6 [报告]
发表于 2010-06-19 14:17 |只看该作者
  1. #include <stdio.h>

  2. int main()
  3. {
  4.     int a = 10;
  5.     void* pa = a; // void指针指向地址10
  6.     printf("%d\n", (unsigned)pa);
  7.     printf("%d\n", *(int*)pa);

  8.     *pa = 1; // 不能对void指针进行赋值(类型不确定!!)
  9.     pa = 2; // 改边void指针指向地址2
  10.     return 0;
  11. }
复制代码
自己看吧。注释

论坛徽章:
0
7 [报告]
发表于 2010-06-19 14:20 |只看该作者
本帖最后由 聪聪知不道 于 2010-06-19 14:22 编辑

回复 5# slackware12


void *是通用型指针,就是通过这个指针访问到的那块内容是什么类型是不确定的。

那么通过这块内存访问到的内容到底占用多少个字节的内存呢?编译器是不知道的。

所以这时候对他进行解除引用操作,编译器不知道应该怎么处理。

这个不看标准,按照正常逻辑推理一下应该也可以得到答案。

论坛徽章:
0
8 [报告]
发表于 2010-06-19 14:21 |只看该作者
回复 1# slackware12


    空指针指向未知数据类型,上面操作非法的。。。肯定连编译器都通不过。

论坛徽章:
0
9 [报告]
发表于 2010-06-19 14:23 |只看该作者
回复 8# wmmy2008


    ISO C文档上哪一页写了这个规定? 我想去看看。 能顺便给个页数吗?

论坛徽章:
0
10 [报告]
发表于 2010-06-19 14:27 |只看该作者
回复 7# 聪聪知不道


    我也知道那个肯定是错误的, 但是我一个同学非要我show the ISO C 文档, 我也没办法。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP