标题:奇怪的const问题
只看楼主
ssqq_1
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-4-8
结帖率:0
已结贴  问题点数:20 回复次数:6 
奇怪的const问题
typedef struct MSG_s{
     int a;
     int b;
} MSG_t;

int tmp = 0;
//定义两个不同初始化形式的变量
const MSG_t msg = {0,0};   
const MSG_t cmd = {0,tmp};

int main(int argc, char* argv[])
{
    MSG_t * ptr = (MSG_t*)&msg;
   
    //显示tmp地址
    printf(" tmp :%d\n", &tmp);
 
    // 显示msg变量修改前后的值
    printf("Old: msg = {%d, %d}\n", msg.a, msg.b);
    //ptr->a = 3;
    //ptr->b = 5;
    printf("New: msg = {%d, %d}\n", msg.a, msg.b);

    // 显示msg相关变量的地址
    printf("****msg Addr***\n");
    printf(" msg :%d\n", &msg);
    printf("msg.a:%d\n", &(msg.a));
    printf("msg.b:%d\n", &(msg.b));
    printf(" ptr :%d\n", ptr);

    ptr = (MSG_t*)&cmd;
    // 显示cmd变量修改前后的值
    printf("Old: cmd = {%d, %d}\n", cmd.a, cmd.b);
    ptr->a = 3;
    ptr->b = 5;
    printf("New: cmd = {%d, %d}\n", cmd.a, cmd.b);

    // 显示cmd相关变量的地址
    printf("****cmd Addr***\n");
    printf(" cmd :%d\n", &cmd);
    printf("cmd.a:%d\n", &(cmd.a));
    printf("cmd.b:%d\n", &(cmd.b));
    printf(" ptr :%d\n", ptr);
   
    return 0;
}

这段代码中为什么msg变量不可修改,而cmd可以?
屏蔽掉对msg的修改后显示内容为:
 tmp :4357464
Old: msg = {0, 0}
New: msg = {0, 0}
****msg Addr***
 msg :4337712
msg.a:4337712
msg.b:4337716
 ptr :4337712
Old: cmd = {0, 0}
New: cmd = {3, 5}
****cmd Addr***
 cmd :4357472
cmd.a:4357472
cmd.b:4357476
 ptr :4357472
搜索更多相关主题的帖子: const 
2010-04-08 17:25
kingsroot
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:284
专家分:1159
注 册:2010-3-28
得分:6 
这个和编译器的优化有关系,首先你声明的tmp是个变量,在编译的时候,编译器是不会对这个变量作优化的,而msg你是直接使用常数赋值,而且前面又加了个const,编译器会直接把认为程序运行的时候这个值一直不变,而把他放到静态存储空间中去(及只读存储空间),但是你的cmd是用一个变量赋值的,编译器不会优化,还是把它放到全局变量空间里面,你用ptr = (MSG_t*)&cmd直接把原来的const属性又消除了,所以当然可以改了哦,不信你可以把tmp用const修饰 你就2个都不能改了
2010-04-08 17:53
ldg628
Rank: 12Rank: 12Rank: 12
等 级:火箭侠
威 望:3
帖 子:526
专家分:3036
注 册:2009-6-23
得分:6 
const MSG_t cmd = {0,tmp};这样定义是通不过编译的(.cpp可以.c不行)

vc,gcc中,msg,cmd的值都修改不了,执行的时候会报错,wintc都能够修改。具体的结果跟不同的编译器有关

现在标准的编译器应该是不能修改的


[ 本帖最后由 ldg628 于 2010-4-8 18:50 编辑 ]
2010-04-08 17:56
ssqq_1
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-4-8
得分:0 
谢谢各位了 我这段代码在VC6.0下测试的,看地址也没找出问题来
2010-04-08 18:04
itma
Rank: 4
等 级:业余侠客
帖 子:105
专家分:266
注 册:2010-2-8
得分:6 
const MSG_t cmd = {0,tmp};
const就把他放到了静态存储区了,不能改的,但是tmp又是个变量,是放在动态存储空间的,于是。。。
2010-04-08 18:05
kingsroot
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:284
专家分:1159
注 册:2010-3-28
得分:0 
你要的话 我可以给你个完整的调试结构或者地址maps
2010-04-08 18:07
ssqq_1
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-4-8
得分:0 
好的 谢了 发我邮箱里吧 songqing_buaa@,C语言以前都没用的这么用过,
2010-04-08 18:13



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-302226-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.746961 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved