【问题标题】:Does LoadString allocate memory for the string it writes to?LoadString 是否为它写入的字符串分配内存?
【发布时间】:2016-12-21 07:50:17
【问题描述】:

我是 C++ 新手,需要一些帮助。 我创建了一个包含字符串的纯资源 dll,我需要在不同的项目中使用这个 dll 来读取存储的字符串。

我编写了以下函数来读取字符串:

LPTSTR GetResourceStr(HMODULE resContainer,int resourceID)
{
    //The stings that are stored in the dll are:
    //
    //ID            |Value|Caption
    //__________________________________________
    //IDS_STRING101 |101  |stringggg
    //IDS_STRING102 |102  |string 102
    //IDS_STRING103 |103  |string 103

    LPTSTR strBuffer = NULL;//is a (non-const) TCHAR string
    if(0!=resContainer){
      int copied=LoadString(resContainer,resourceID ,(LPTSTR)&strBuffer,0); 
    }
    return strBuffer;
}

int _tmain(int argc, _TCHAR* argv[])
{
    HMODULE resContainer=LoadLibraryEx(L"ResourceDll.dll",NULL, LOAD_LIBRARY_AS_DATAFILE);

    LPTSTR msg = GetResourceStr(resContainer,101);
    std::wcout<<msg<<std::endl;
    //Expected output: stringggg
    //The output that i get: stringgggstring 102 string 103
    int i = 0;
    std::cin>>i;
    return 0;
}

为了获得预期的输出 - stringggg,我应该在我的代码中进行哪些更改? 为什么会这样? LoadString 是否为它从资源中读取的字符串分配了内存,或者我只是获得了指向该字符串已经存储在内存中的位置的指针? 谢谢你的帮助!!

【问题讨论】:

  • 您需要一个 LPTSTR[] 以便它可以将字符串复制到您的缓冲区中。最后一个参数必须是该数组的大小,0 永远不正确。返回该数组将是一个悬空指针错误。考虑返回一个 std::wstring。

标签: c++ resources stringreader resourcestring


【解决方案1】:

LoadString documentation 说:

nBufferMax [in]

类型:整数

缓冲区的大小,以字符为单位。如果字符串长于指定的字符数,则字符串将被截断并以空字符结尾。如果此参数为 0,则 lpBuffer 接收到一个指向资源本身的只读指针。

因此,要直接回答您的问题,您只需获得一个指向存储资源的内存的指针。

但是字符串资源不是以空值结尾的(有关更多信息,请参阅here),这就是您获得该输出的原因。 LoadString 的返回值告诉您单个字符串资源的长度。如果您需要字符串以空值结尾,则必须将字符串复制到单独的缓冲区,如下所示:

WCHAR* pszString;
int iLength = ::LoadString(
    resContainer,
    resourceID,
    reinterpret_cast<LPWSTR>(&pszString),
    0
    );

WCHAR* pszString2 = new WCHAR[iLength + 1];
::StringCchCopyN(pszString2, iLength + 1, pszString, iLength);

或者,您可以使用指向缓冲区的指针(而不是指向指针的指针)作为第三个参数调用 LoadString,并将缓冲区的长度作为第四个参数,这会将字符串资源复制到缓冲区并以空值终止它。缺点是如果传递的长度不够大,字符串会被截断,而且无法事先查询资源的长度。

【讨论】:

  • 非常感谢,它真的帮助我理解了我的错误!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-03-22
  • 2021-07-27
  • 2016-03-25
  • 2018-06-16
  • 2016-07-01
  • 2012-07-10
相关资源
最近更新 更多