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对象

posted on 2024-08-21 00:00  norsd  阅读(4)  评论(0编辑  收藏  举报  来源

导航