2

谁能向我解释为什么这段代码有效(为什么它返回一个值)?

int main()
{
    int *ptr = new int(113);
    int &rPtr = *ptr;

    delete ptr;

    cout << rPtr << endl;

    return 0;
}

基本上,这是我得到的返回值:

-572662307
4

3 回答 3

3

你正在做的事情会导致未定义的行为,所以你得到这个数字的事实是完全合理的行为。

当您执行此序列时:

int *ptr = new int(113);
int &rPtr = *ptr;

该引用rPtr现在引用您使用 line 创建的整数new int(113)。在下一行,您执行

delete ptr;

这将删除 that int,这意味着该对象不再存在。任何指向它的指针或引用现在都引用一个已释放的对象,这会导致未定义的行为。因此,当您rPtr使用

cout << rPtr << endl; 

任何事情都有可能发生。在这里,您只是获取垃圾数据,但程序很容易崩溃或报告调试错误消息。

有趣的是:您打印的值 (-572662307),被视为 32 位无符号值,是 0xDDDDDDDD。我敢打赌,这是内存分配器将一个值放入已释放的内存中,以帮助您调试像这样的内存错误。

希望这可以帮助!

于 2012-07-06T21:44:39.780 回答
0

您正在调用未定义的行为。删除指针后引用不再有效:

int *ptr = new int(113);
int &rPtr = *ptr;
//rPtr references the memory ptr points to
delete ptr;
//the memory is released
//the reference is no longer valid
cout << rPtr << endl;
//you try to access an invalid reference
//anything can happen at this point
于 2012-07-06T21:43:36.940 回答
0

对象的引用在所有块范围(在这种情况下为函数范围)中都是活动的,所以当你删除指针时,一些垃圾在这个地址并且输出显示它。

于 2012-07-06T21:43:44.280 回答