0

我对 std::wstring 内存分配有一个大问题。当我尝试使用此代码时程序崩溃:

size_t size;
mbstowcs_s(&size, NULL, 0, buffer, _TRUNCATE);
wchar_t *buffer2 = (wchar_t*)malloc(size + 1);
mbstowcs_s(&size, buffer, buffer_size, buffer, _TRUNCATE);
buffer2[size] = '\0';

std::wstring data(buffer);

崩溃在最后一行,如果我使用以下行就不会发生:

std::wstring data(L"hello");

错误是内存堆分配失败,结果是程序崩溃。为什么?怎么了?

4

3 回答 3

7
wchar_t *buffer2 = (wchar_t*)malloc((size + 1) * sizeof(wchar_t));
                                               ^^^^^^^^^^^^^^^^^

malloc分配一些字节 - 你wchar_t不想

如果您使用的是 c++,正确的方法是:

wchar_t *buffer2 = new wchar_t[size+1];
于 2011-04-10T13:31:05.570 回答
5

如果您使用 std::wstring 我假设您使用的是 C++,不要使用 malloc,使用 new & delete(只是一个旁注)

于 2011-04-10T13:34:42.353 回答
0

std::vector 似乎是在这里制作缓冲区的好方法。它的构造函数接收元素编号(不是字节),您不必记住删除内存。

于 2011-04-10T14:22:45.773 回答