正在查找新的内存地址?C++
Finding new memory address? C++
(我测试了地址,因为我收到错误,我发现地址在被删除之前发生了变化,当删除被称为时,titlePTR
已经更改了它的地址,它给了我一个错误说"BLOCK TYPE IS VALID
"我听说这是当你尝试删除一个不是由new制作的指针时(所以这让我想到了地址)
顺便说一句,我知道我不必制作动态数组,但我正在读一本书,它说要练习在程序不需要运行代码的时候节省内存。我在其他几个地方发帖,人们总是唠叨"不要使用新的等等等等"
以下是尝试删除titlePTR
或bodyPTR
时所说的:http://postimg.org/image/gt0f8kufn/
if (test == "MapleStory")
{
wchar_t *titlePTR = new wchar_t[30]; <-- Example Address: 051
cout << titlePTR;
wchar_t *bodyPTR = new wchar_t[20];
titlePTR = L"MapleStory";
bodyPTR = L"Launching MapleStory...";
MessageBox(NULL, bodyPTR, titlePTR, MB_OK | MB_ICONINFORMATION);
ShellExecute(NULL, L"open", L"GameLauncher.exe", NULL, L"C:\Nexon\MapleStory", 1);
cout << endl << titlePTR; <-- Example Address: 0601
delete[] titlePTR;
delete[] bodyPTR;
}
wchar_t *titlePTR = new wchar_t[30]; // (1)
titlePTR = L"MapleStory"; // (2)
delete[] titlePTR; // (3)
这将分配内存并将内存的地址存储在变量 (1) 中。然后用新地址 (2) 覆盖它。然后删除新地址 (3),而不是分配的内存。因此,您的问题是步骤 (2) 中的分配不使用您准备的缓冲区,而是创建一个新的缓冲区。
要修复,只需执行以下操作:
const wchar_t *titlePTR = L"MapleStory";
当然不要删除,因为您没有使用 new
分配任何内存。
相关文章:
- 将数组的地址分配给变量并删除
- 空基优化子对象的地址
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 如何在c++程序中找到函数的地址
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 被解释为低级别const的const对象的地址
- 将地址分配给本地指针后,公共对象的变量将消失
- 为什么我在leetcode上收到AddressSanitizer:地址0x602000000058上的堆缓冲区溢出错误
- 内联程序集printf将整数解释为地址
- 为什么指针不写入类的地址?
- 如何在C++中获取该对象的类声明中对象的地址?
- 通过按地址访问变量
- 当一个新对象被分配到它的地址时,对象是否必须被销毁
- 函数名是c中该函数的第一条指令的地址吗
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- ReadProcessMemory() 不适用于像 0x2840C6C68D8 这样的长地址
- CUDA:统一内存和指针地址的更改
- 当我们从/tp地址中添加/减去一个整数时会发生什么
- 如何使用 Boost Asio 在 Android 上获取我的本地 udp IP 地址?