C++ 关闭函数的隐式转换
在开发中遇到的一个问题,如何关闭C++函数的隐式转换
C++只提供了关闭类的隐式转换,但是想要关闭某个函数的隐式转换没有提供直接的方法,我们可以借助宏和模板的方法实现,实现如下图
代码中,宏 EXPLICIT 是关闭函数的隐式转换
EXPLICIT 参数1:函数名,参数2:函数的参数个数
可以看到加了EXPLICIT的函数,必须显式转换才能不被编译器报错
代码如下↓
#define TEMPLATE_ARG_1(T, N) T##N
#define TEMPLATE_ARG_2(T) TEMPLATE_ARG_1(T, 1), TEMPLATE_ARG_1(T, 2)
#define TEMPLATE_ARG_3(T) TEMPLATE_ARG_2(T), TEMPLATE_ARG_1(T, 3)
#define TEMPLATE_ARG_4(T) TEMPLATE_ARG_3(T), TEMPLATE_ARG_1(T, 4)
#define TEMPLATE_ARG_5(T) TEMPLATE_ARG_4(T), TEMPLATE_ARG_1(T, 5)
#define TEMPLATE_ARG_6(T) TEMPLATE_ARG_5(T), TEMPLATE_ARG_1(T, 6)
#define TEMPLATE_ARG_7(T) TEMPLATE_ARG_6(T), TEMPLATE_ARG_1(T, 7)
#define TEMPLATE_ARG_8(T) TEMPLATE_ARG_7(T), TEMPLATE_ARG_1(T, 8)
#define TEMPLATE_ARG_9(T) TEMPLATE_ARG_8(T), TEMPLATE_ARG_1(T, 9)
#define TEMPLATE_ARG(ARGT, ARGN) TEMPLATE_ARG_##ARGN(ARGT)
#define EXPLICIT(FUNCTION, ARGN) template<TEMPLATE_ARG(class T, ARGN)> void FUNCTION(TEMPLATE_ARG(T, ARGN)) = delete;
class Class {
public:
explicit Class(int num) {}
EXPLICIT(Func1, 1) void Func1(string str) {}
EXPLICIT(Func2, 3) void Func2(string str1, int num, string str2) {}
void func3(string str1, string str2) {}
};
void main() {
Class a = 1; // false: 不存在从int转换到Class的适当构造函数
a.Func1("abc"); // false: 无法引用函数Class::Func1, 它是已删除的函数
a.Func2("abc", 1, "def"); // false: 无法引用函数Class::Func1, 它是已删除的函数
a.Func1(string("abc")); // true
a.Func2(string("abc"), 1, string("def")); // true
a.func3("", ""); // true: 隐式转换
}