0

尝试在 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 *(not Buffer(*)[4]),我该如何解决?

4

2 回答 2

2

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

您实际需要知道的:您不能new为数组类型调用表达式。因此,以下两个是不等价的(第一个是不合法的):

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

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

语言就是不那样工作的。第二个版本创建一个动态数组,而第一个版本想创建一个类型为“4 T 数组”的单个动态对象,这是不可能的。相反,new TArr实际上与 相同new T[4],因此结果是四个s.*的动态数组T

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

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

于 2012-02-08T22:48:05.890 回答
1

你的问题在typedef. 尝试以下操作:

int bs = sizeof(new Bucket);

你会看到 的值为bs4 ( INT_PTR);

于 2012-02-08T22:55:03.463 回答