c++ 显式转换中的问题
显式转换中的问题
auto test = (PCSTR)(String::Format("regex_match failed: \"%s\"", a_strAddress.c_str()));
String::Format 返回一个String类型临时变量,我们把他称为 “t”
他被要求显示转化为PCSTR, 内部实现为 return this._str.c_str()
最后赋值到 test
实际结果是, test 指向了一片空白,当然这片区域本来是有内容的, 但是 t 已经被编译器析构了
我们看下asm
auto test = (PCSTR)(String::Format("regex_match failed: \"%s\"", a_strAddress.c_str()));
00007FF650F33F5D mov rcx,qword ptr [a_strAddress]
00007FF650F33F64 call std::basic_string<char,std::char_traits<char>,std::allocator<char> >::c_str (07FF650F0C1EEh)
00007FF650F33F69 mov r8,rax
00007FF650F33F6C lea rdx,[string "regex_match failed: "%s"" (07FF650F72638h)]
00007FF650F33F73 lea rcx,[rbp+358h]
00007FF650F33F7A call norlib::String::Format<char const * __ptr64> (07FF650F0B0E6h)
00007FF650F33F7F mov qword ptr [rbp+458h],rax
00007FF650F33F86 mov rax,qword ptr [rbp+458h]
00007FF650F33F8D mov qword ptr [rbp+460h],rax
00007FF650F33F94 mov rcx,qword ptr [rbp+460h]
00007FF650F33F9B call norlib::String::operator char const * __ptr64 (07FF650F0D058h)
00007FF650F33FA0 mov qword ptr [rbp+1B8h],rax
00007FF650F33FA7 lea rcx,[rbp+358h]
00007FF650F33FAE call norlib::String::~String (07FF650F0CDD3h)
throw std::exception("");
注意最后的 throw 语句我们是为了标记前一句语句结束用的
我们看到t 这个String对象被析构了
所以String对象在显示转换返回的内部_str.c_str() 的内容也失效了
如果把语句改成
auto test2 = String::Format("regex_match failed: \"%s\"", a_strAddress.c_str()).ToLower();
ToLower 内部实现如下:
string String::ToLower()
{
auto strLower = string(_str);
std::transform(_str.begin(), _str.end(), strLower.begin(), ::tolower);
return strLower;
}
此时 t这个String对象仍然会被析构, 但是 test2 这个 string 仍然有效, 因为我们返回的不再是一个内部指针,而是一个string对象