C++11中,当我们定义一个类的成员函数时,如果后面使用"=delete"去修饰,那么就表示这个函数被定义为deleted,也就意味着这个成员函数不能再被调用,否则就会出错。
#include <iostream>
class TestClass
{
public:
int func(int data) = delete;
};
int TestClass::func(int data)
{
return 0;
}
int main()
{
TestClass obj;
obj.func(100);
return 0;
}
编译时直接报错,如下,
在C++11之前,当我们希望一个类不能被拷贝,就会把构造函数定义为private,但是在C++11里就不需要这样做了,只需要在构造函数后面加上=delete来修饰下就可以了。
巧妙用法
这里说个=delete的巧妙用法,在C++里会有很多隐式类型转换,如下代码,
#include <iostream>
class TestClass
{
public:
int func(int data);
int func(float data) = delete;
};
int TestClass::func(int data)
{
printf("data: %d\n", data);
return 0;
}
int main()
{
TestClass obj;
obj.func(100);
obj.func(100.0);
return 0;
}
我们把参数类型是double的重载函数加上=delete进行修饰,表示这个函数被删除,那么用户就不能使用这个函数了,这样再编译就会出错,