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; }上面定义后 void insert(const QDateTime endtime ,const QString &key, const QVector<T> &value) { t_cache.insert(key,value); } t_cache.insert(key,value); 报错
时间: 2024-02-24 15:59:47 浏览: 59
根据您提供的信息,错误可能是由于 `T` 类型未知导致的。您需要在调用 `MyTemplateClass` 时,指定 `T` 的具体类型,例如:
```
MyTemplateClass<int> myObj;
```
这样可以将 `T` 指定为 `int` 类型。然后您可以调用 `myObj.insert(endtime, key, value)` 函数来向 `t_cache` 中插入数据。
如果您希望在不指定 `T` 类型的情况下使用 `MyTemplateClass`,您可以考虑将 `insert` 函数定义为模板函数,并在函数中使用 `QVariant` 类型来存储 `value`,例如:
```
template<typename U>
void insert(const QDateTime endtime ,const QString &key, const QVector<U> &value)
{
QVector<QVariant> qvValue;
for (const auto& v : value) {
qvValue.append(QVariant::fromValue(v));
}
t_cache.insert(key, qvValue);
}
```
这样可以将 `value` 中的元素转换为 `QVariant` 类型,并将其作为一个 `QVector<QVariant>` 存储到 `t_cache` 中。在需要使用 `value` 时,您可以通过 `QVariant::value<U>()` 函数来将其转换为原始类型。
阅读全文