gpt4 book ai didi

c++ - 让函数返回 C++ 类中的任何类型

转载 作者:搜寻专家 更新时间:2023-10-31 00:13:15 25 4
gpt4 key购买 nike

我有这门课:

#define TYPE_INVALID 0x00
#define TYPE_BYTE 0x01
#define TYPE_SHORT 0x02
#define TYPE_INT 0x03
#define TYPE_LONG 0x04
#define TYPE_FLOAT 0x05
#define TYPE_DOUBLE 0x06

class BASIC_TYPE
{
private:
int8_t type;
int8_t byteValue;
int16_t shortValue;
int32_t intValue;
int64_t longValue;
float floatValue;
double doubleValue;

public:
BASIC_TYPE();
template<typename T> BASIC_TYPE(int8_t, T);

template<typename T> void set(T);
template<typename T> T get();
};

BASIC_TYPE::BASIC_TYPE()
{
type = TYPE_INVALID;
}

template<typename T> BASIC_TYPE::BASIC_TYPE(int8_t newType, T value)
{
type = newType;
set(value);
}

template<typename T> void BASIC_TYPE::set(T value)
{
switch(type)
{
case TYPE_BYTE : byteValue = value; break;
case TYPE_SHORT : shortValue = value; break;
case TYPE_INT : intValue = value; break;
case TYPE_LONG : longValue = value; break;
case TYPE_FLOAT : floatValue = value; break;
case TYPE_DOUBLE : doubleValue = value; break;
}
}

template<typename T> T BASIC_TYPE::get()
{
switch(type)
{
case TYPE_BYTE : return byteValue;
case TYPE_SHORT : return shortValue;
case TYPE_INT : return intValue;
case TYPE_LONG : return longValue;
case TYPE_FLOAT : return floatValue;
case TYPE_DOUBLE : return doubleValue;
}
}

现在我想使用 get() 函数来输出存储的数字,如下所示:

BASIC_TYPE val1(TYPE_INT, 1234);
BASIC_TYPE val2(TYPE_DOUBLE, 3.1415926535);

val1.set(5678);
val2.set(2.7182818284);
printf("%d\n%f\n", val1.get(), val2.get());

但是 g++ 表示 printf 函数中没有对 'BASIC_TYPE::get() 的匹配函数调用,并且 template argument deduction/替换失败(无法推断模板参数“T”)。

必须更改什么才能让代码正确编译?

最佳答案

"What has to be changed to let the code compile properly?"

在这种情况下你需要明确。随便写

printf("%d\n%f\n", val1.get<int>(), val2.get<double>());
// ^^^^^ ^^^^^^^^

C++ 无法仅通过返回类型来区分各种 get() 函数实例化(其他情况下可以使用 set() ,其中 T 出现作为参数类型)。
在这种情况下,您需要指定类型以显式实例化模板函数(如上所示)。


另请注意:我更愿意使用 enum 而不是那些 #define TYPE_xxx 语句:

enum MySupportedTypes {
TYPE_INVALID ,
TYPE_BYTE ,
TYPE_SHORT ,
TYPE_INT ,
TYPE_LONG ,
TYPE_FLOAT ,
TYPE_DOUBLE ,
};

对于 get() 模板函数的实现,您应该考虑像这样的1,以避免 get() 函数正在为不合适的请求类型调用。

template<typename T> T BASIC_TYPE::get() {
switch(type) {
case TYPE_BYTE:
std::is_same<T,int8_t> ? return byteValue : throw std::bad_typeid;
case TYPE_SHORT:
std::is_same<T,int16_t> ? return shortValue : throw std::bad_typeid;
// analogous ...
}
}

或者更好的是提供一种在编译时捕获类型不匹配的机制。


1) 请参阅 std::is_same 的文档引用

关于c++ - 让函数返回 C++ 类中的任何类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27582408/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com