这是一个非常简单的问题。考虑以下代码:
#include <iostream>
#include <memory>
typedef std::unique_ptr<void> UniqueVoidPtr;
int main() {
UniqueVoidPtr p(new int);
return 0;
}
在cygwin(g++ 4.5.3)下使用以下命令进行编译g++ -std=c++0x -o prog file.cpp
完全没有问题。然而,在微软编译器(无论是VS 2010还是2013)下编译时,我会得到以下错误:
C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\INCLUDE\memory(2067) : error C2070: 'void': illegal sizeof operand
C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\INCLUDE\memory(2066) : while compiling class template member function 'void std::default_delete<_Ty>::operator ()(_Ty *) const'
with
[
_Ty=void
]
C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\INCLUDE\type_traits(650) : see reference to class template instantiation 'std::default_delete<_Ty>' being compiled
with
[
_Ty=void
]
C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\INCLUDE\memory(2193) : see reference to class template instantiation 'std::tr1::is_empty<_Ty>' being compiled
with
[
_Ty=std::default_delete<void>
]
foo1.cpp(7) : see reference to class template instantiation 'std::unique_ptr<_Ty>' being compiled
with
[
_Ty=void
]
这是正常的吗?我正在编写一个类,希望在类中使用唯一指针。在尝试为该类编写移动构造函数语义时,我遇到了问题(我猜测这是因为我最终正确编码了我的移动构造函数:即其他错误已经被修复)。
std::unique_ptr
中,默认的删除器会在指针上调用delete
,如果你在void*
上调用delete
,你期望会发生什么? - David Rodríguez - dribeasdefault_delete
不应该在void*
上调用delete
(请参见 ixSci 的答案)。此外,如果它确实在void*
上调用了 delete,那么这将是未定义行为(请参见 Nevin 的答案),在这种情况下,可以期望任何结果(不一定是错误)。 - Cassio Neri