const在指针赋值时候注意事项:assignment discards ‘const’ qualifier from pointer target type的解决方法

const 与 define 都可以创建类似功能的符号常量。但是const可以创建const-数组、指针、指向const的指针。很重要的一点const能使不需要修改的数据变成只读的模式:

#include <stdio.h>
int main (vid)
{
    double rate[5] = {88.99, 100.12, 59.45, 183.11, 340.5};
    const double locked[5] = {0.08, 0.075, 0.0725, 0.07};
    double *pnc = rate ;

    pnc = locked; 
    pnc = &rate[3];

    return 0;
}

以上的代码会出现错误:assignment discards ‘const’ qualifier from pointer target type, 

字面意思是:赋值从指针目标类型中丢弃“const”限定符 , 也就是说const这个限定符号被丢弃了。其实从程序中可以看出来,因为指针 pnc 是普通指针,那么就可以改修这个指针所指向的值或者重新赋值。

但是这个指针指向的值是一个const的数组,  那么也就是说const double locked[ ] 这个数组里面的值变的能被修改了,  这显然跟const 不能修改(只读)所冲突。 


解决方法是: 把 指针也变成const 类型,这样 const 类型的数组locked 的地址就能赋给 const类型的指针pnc。


总结: 能把   const 数据(locked[ ])的地址 

 或    非 const数据(rate[ ])的地址 

初始化为 指向const的指针( const double *pnc ) 或为其赋值 (pnc = locked; pnc = &rate[ 3]) 是正确的。 

扫描二维码关注公众号,回复: 931157 查看本文章

反之  非 const数据的地址只能赋给普通的指针 ,如果将const的数据地址赋给普通的(非const)的指针,  那么 这个cost的数据将不在变成"只读"的状态,而是能被修改

猜你喜欢

转载自blog.csdn.net/qq_36324796/article/details/79021258