关闭

const char* const 问题

557人阅读 评论(0) 收藏 举报

这是很经典的问题,很多C语言的初级面试都会碰到。今天在这里重提是因为我以前一直没有真正理解,我是死记得:

const char* p: p指向的内容是常量,但是p是常量指针
char* const p: p指向的内容是变量,但是p是指针常量

因为我没有真正理解,所以稍微一变化我就傻了:
template <class T>
void getStrT(const T& val)   {…}   //

void getStr(const char*& val){…}  //

const char* p="This is Arrowpig!";
getStr(strdup(p));     //1.
getStrT(strdup(p));   //2.

结果getStrT是成功编译的,但是 getStr碰到编译错:
error: invalid initialization of non-const reference of type ‘const char*&’ from a temporary of type ‘char*’

我诈一看,getStr和getStrT一样的啊,T不就是char* 吗,那const T& 不就是const char* &吗!李楠倒是一针见血的就指出来区别const T& => const (char*)& 。后来我跟徐晨再过了一遍,变量定义的方式是和将来使用变量的方式一样的

例子:
const char*& p: 把该定义看成表达式求值,*,&都是单元运算符,右结合–>(const char)(*(&p))。p是一个引用,引用的对象是指针,对指针解引用后得到的类型是const char,所以指针指向的内容是const。

const T& p: 把定义看成表达式求值–> (const T)(&p), p是引用,引用的类型是const T,当T=char *的时候等价const (char*),指针本身是const。–>引用的类型是指针常量。

好,回过头来看,strdup返回char*, 但是由于我直接把strdup放在参数中,char* 是个临时变量,C++编译器会自动给临时变量赋于const属性,所以gcc报的错误中a temporary of type ‘char*’的意思就是 const (char*)= char * const。当我们调用getStr的时候,我们试图把 指针常量 转成 常量指针的引用,所以就出错了 。但是当调用getStrT时,我们试图把 指针常量 转成 指针常量的引用,当然是可以的

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:78512次
    • 积分:1439
    • 等级:
    • 排名:千里之外
    • 原创:60篇
    • 转载:0篇
    • 译文:8篇
    • 评论:16条
    最新评论