打破C++ Const的规则
作者:网络转载 发布时间:[ 2016/1/29 10:24:15 ] 推荐标签:.NET 测试开发技术
从一个C++菜鸟改函数开始
1 CString MyClass::GetStringValue() const
2 {
3 return m_strValue;
4 }
这个值可能还没有赋值,好吧,那么我先判断是不是为空,为空赋值了
CString MyClass::GetStringValue() const
{
if(m_strValue.IsEmpty())
SetStringValue();
return m_strValue;
}
结果,编译不过,因为有个规则:const函数里面不能调用非const函数。
看到下面的编译错误:
error C2662: “MyClass::SetStringValue”: 不能将“this”指针从“const MyClass”转换为“MyClass &”
嘿嘿原来是这样:当我们定义了一个类的成员函数会默认传进来一个this指针,但是如果是一个const 函数那么是不是传竟来一个const的指针呢?所以我想编译器看到是这样的:
CString MyClass::GetStringValue(const MyClass* this)
{
if(this->m_strValue.IsEmpty())
this->SetStringValue();
return this->GetStringValue();
}
后来验证一下,创建了一个static函数模拟一下:
CString MyClass::GetStringValueS(const MyClass* mcp)
{
if(mcp->m_strValue.IsEmpty())
mcp->SetStringValue();
return mcp->GetStringValue();
}
编译真的得到一个同样的错误:
error C2662: “MyClass::SetStringValue”: 不能将“this”指针从“const MyClass”转换为“MyClass &”
所以我试着去打破const规则:
CString MyClass::GetStringValue()const
{
MyClass * nonconstthis = (MyClass *)this;
if(m_strValue.IsEmpty())
nonconstthis->SetStringValue();
return m_strValue;
}
结果编译通过,执行也没有问题。
所以有一个转换const_cast<>专门来做这样的事情:
CString MyClass::GetStringValue()const
{
if(m_strValue.IsEmpty())
const_cast<MyClass *>(this)->SetStringValue();
return m_strValue;
}
后,我认为,这样违背了const设计的初衷,这样对于调用者是一种欺骗(违背契约:我保证不改你),所以不推荐这样使用。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11