繁体   English   中英

为什么我不能像这样在QMap上调用插入?

[英]Why can't I call insert on a QMap like this?

尝试在Qt SDK 4.7.4 for Desktop-MinGW 4.4下编译以下代码会导致以下编译器错误:

#include <QtCore/QCoreApplication>
#include <QMap>
struct Buffer
{
   char data[4];
};
// A Bucket needs to reserve 16 chars worth of Buffers
typedef Buffer Bucket[(16 * (sizeof (char))) / (sizeof (Buffer))];
typedef QMap<QString, Bucket *> BucketMap;
int main(int argc, char *argv[])
{
   BucketMap bucket;
   bucket.insert(QString("foo"), new Bucket()); //compile error
   return 0;
}
../test/main.cpp: In function 'int main(int, char**)':
../test/main.cpp:13: error: no matching function for call to 'QMap<QString, Buffer (*)[4]>::insert(QString, Buffer*)'
../../../QtSDK/Desktop/Qt/4.7.4/mingw/include/QtCore/qmap.h:556: note: candidates are: QMap<Key, T>::iterator QMap<Key, T>::insert(const Key&, const T&) [with Key = QString, T = Buffer (*)[4]]
mingw32-make.exe[1]: *** [debug/main.o] Error 1
mingw32-make.exe: *** [debug] Error 2

我尝试使用std::stringstd::map将其转换为等效的示例,以达到相同的效果。 我介绍了Qt版本是因为它更紧凑,并且最终是我的项目所需的形式。
我猜想我只是缺少有关如何最终解释typedef一些信息。 为什么第二个参数显然要insert Buffer * (而不是Buffer(*)[4] ),我该如何解决?

简单的答案:类型不匹配。

您实际上需要了解的内容:您不能为数组类型调用new表达式。 因此,以下两个不相等(第一个不合法):

typedef T TArr[4]; TArr * p = new TArr;  // #1

T * q = new T[4];                        // #2

语言只是无法正常工作。 第二个版本创建一个动态数组,而第一个版本则想创建“ 4 T数组”类型的单个动态对象,这是不可能的。 相反, new TArr实际上与new T[4] ,因此结果是四个T的动态数组 。*

您基本上应该只将地图的值类型更改为Buffer *std::array<Buffer, 4> *std::unique_ptr<Buffer[]>std::unique_ptr<std::array<Buffer, 4>> ,无论您喜欢哪个。

*)这正是以下代码非常有问题的原因: template <T> void foo() { T * p = new T; delete p; } template <T> void foo() { T * p = new T; delete p; } template <T> void foo() { T * p = new T; delete p; }假设您说foo<int[4]>(); ...

您的问题出在typedef 请尝试以下操作:

int bs = sizeof(new Bucket);

并且您将看到bs值为4( INT_PTR );

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM