template<typename T> class MyTemplateClass { public: //MyTemplateClass(const T& data) : QObject(nullptr), m_data(data) { MyTemplateClass(){ qRegisterMetaType<SP104>("SP104"); qRegisterMetaType<DP104>("DP104"); qRegisterMetaType<SP104_T>("SP104_T"); qRegisterMetaType<DP104_T>("DP104_T"); qRegisterMetaType<ME_NA104>("ME_NA104"); qRegisterMetaType<ME_NB104>("ME_NB104"); qRegisterMetaType<ME_NC104>("ME_NC104"); qRegisterMetaType<YK_SP104>("YK_SP104"); qRegisterMetaType<YK_DP104>("YK_DP104"); t_cache.setMaxCost(MAP_MAX); } using CallbackFunc = std::function<void(int, QString)>; void setCallback(const CallbackFunc& func) { m_callbackFunc = func; } QMap<QString,QVector<T>>t_map; QMap<QString,QVector<T>>old_map; QCache<QString,QVector<T>>t_cache; QVector<T>t_vctor; QDateTime start_time; int state_flg; int expect_timedif; }上面定义后t_cache.insert(key,value);报错
时间: 2024-02-24 17:59:22 浏览: 24
根据您提供的代码和报错信息,问题可能在于以下几点:
1. `key` 的类型不正确,应该是 `QString` 类型。
2. `value` 的类型不正确,应该是 `QVector<T>` 类型。
3. `value` 参数应该是一个指针类型,即 `QCache::insert()` 函数的第二个参数应该是 `QVector<T>*` 类型。
因此,正确的插入方式应该是:
```c++
t_cache.insert(key, &value);
```
或者,如果您将 `value` 定义为 `QVector<T>` 类型的局部变量,可以直接插入该变量的地址:
```c++
QVector<T> value;
t_cache.insert(key, &value);
```
请注意,如果您插入的是一个局部变量的地址,该变量可能会在离开作用域时被销毁,导致缓存数据不正确。因此,建议您仅缓存动态分配的变量或全局变量。
希望以上信息能够帮助您解决问题。如果您仍然遇到困难,请提供更详细的报错信息或完整的代码。
相关问题
#include <QDebug> #include <type_traits> struct MyStruct1 { int x; int y; }; struct MyStruct2 { int x; QString y; }; template<typename T> class MyTemplateClass { public: MyTemplateClass(T t) : m_t(t) {} T value() const { return m_t; } private: T m_t; QMap<QString, QVector<T>> t_map; QMap<QString, QVector<T>> old_map; QCache<QString, QVector<T>> t_cache; QVector<T> t_vctor; };模板类初始化不赋值
您的模板类 `MyTemplateClass` 是可以不赋值初始化的,例如:
```
MyTemplateClass<MyStruct1> obj1{}; // 使用默认构造函数初始化
MyTemplateClass<MyStruct2> obj2{MyStruct2{1, "hello"}}; // 使用自定义构造函数初始化
```
如果您想在构造函数中对成员变量进行初始化,那么可以在成员变量后面跟上初始化列表,例如:
```
template<typename T>
class MyTemplateClass {
public:
MyTemplateClass(T t) : m_t(t), t_map{}, old_map{}, t_cache{}, t_vctor{} {}
// ...
private:
T m_t;
QMap<QString, QVector<T>> t_map;
QMap<QString, QVector<T>> old_map;
QCache<QString, QVector<T>> t_cache;
QVector<T> t_vctor;
};
```
在上述代码中,`t_map{}`、`old_map{}`、`t_cache{}`、`t_vctor{}` 都表示对应的成员变量使用默认构造函数进行初始化。
template<typename T> struct has_get_data { template<typename U> static std::true_type f(decltype(&U::get_data)); template<typename U> static std::false_type f(...); typedef decltype(f<T>(0)) type; };
这是一个 C++ 模板结构体 `has_get_data` 的定义,用于检查某个类型是否具有 `get_data` 方法。和之前的定义相比,增加了一个模板参数 `typename T`,表示需要检查的类型。
同样,该结构体包含两个静态成员函数 `f`,一个是接受一个指向成员函数 `get_data` 的指针,一个是接受一个可变参数列表。不同的是,这里 `f` 函数的模板参数是 `typename U`,表示需要检查的类型,而不是之前的 `T`。
然后,结构体中定义了一个 `type` 类型,用于表示是否具有 `get_data` 方法。和之前的定义相同,如果某个类型 `T` 中包含成员函数 `get_data`,则调用 `f<decltype(&T::get_data)>(0)` 会返回 `std::true_type` 类型,否则调用 `f<T>(0)` 会返回 `std::false_type` 类型。
这种方式可以在编译期间检查某个特定类型是否具有某个方法,从而避免在运行时出现错误。由于是模板实现,可以适用于不同类型的检查。