根据N4606,4.5 [conv.qual]第3段读取
如果满足以下条件,则
T1
类型的prvalue表达式可以转换为类型T2
,其中cv i j 表示T j 的cv资格签名中的cv限定符:
- ...
- 如果cv 1 i 和cv 2 i 不同,那么const就在每个cv 2 k ,0 <&lt; k&lt;岛
上面的最后一点表明以下转换失败。
T1 : pointer to / pointer to / pointer to / T
T2 : pointer to / pointer to / const pointer to / T
要成功,T2
必须为pointer to / const pointer to / const pointer to / T
。 不仅T2
仅仅因为T1
更符合cv资格吗?为什么转换成功所需的较低维度的cv-qualifiers为何成功?
答案 0 :(得分:23)
请考虑以下代码:
char str[] = "p1 should always point here.";
char* const p1 = str;
char** p2 = nullptr;
char*** p3 = &p2;
char str2[] = "Can we make p1 point to here?"
// p1 = str2; // does not work: const violation
// But:
char*const** p4=p3; // if it were allowed
*p4 = &p1; // no const violation, as *p4 is of type char*const*
**p3 = str2; // oops, changed p1!
因此,如果允许转换,您可以更改常量变量(p1)而不会发生任何正式的const违规。