ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

c – placement-new address vs raw memory address

2019-09-02 11:08:33  阅读:156  来源: 互联网

标签:placement-new c


放置new的结果似乎与我提供给placement new的内存指针相同.使用GCC,即使对于具有虚函数的类,这似乎也适用,例如……

#include <iostream>
#include <vector>

using namespace std;

class A
{
public:
    int a;
    virtual ~A() {}
};

int main()
{
    void *mem = malloc(sizeof(A));
    A* ptr = new(mem) A();

    cout << "sizeof(T) = " << sizeof(A) << endl;
    cout << "mem = " << mem << endl;
    cout << "ptr = " << ptr << endl;
    cout << "addr a = " << &(ptr->a) << endl;

    ptr->~A();
    free(mem);

    return 0;
}

这个程序的输出是(注意:64位linux)…

sizeof(T) = 16
mem = 0x1a41010
ptr = 0x1a41010
addr a = 0x1a41018

C是否保证mem和ptr相同或者这只是GCC的巧合?在一个更大的便携式程序中,我是否必须保留mem和ptr,或者我可以保留其中一个并在需要时进行转换?

为了澄清这个问题,我知道内存分配器有时会在指向内存块之前将字符串中的已分配块的大小.是否允许C编译器使用这样的技巧,并说在对象指针所指向的内存块之前将VMT指针放在单词中?在这种情况下,mem和ptr会有所不同.

解决方法:

是的,他们是一样的.您可能希望将内存地址视为void指针,将对象地址视为类型指针,但如果您愿意,可以进行转换.在某种意义上,new是将内存地址“转换”为对象的方式(通过构造一个).这是完整的图片(注意没有演员阵容):

void * addr = std::malloc(sizeof(T));  // or ::operator new(sizeof(T))
T * p = ::new (addr) T;                // "new" gives you an object pointer
p->~T();
std::free(addr);

但这仅适用于非阵列版本的新版本. Array-placement-new与essentially unusable不同.

您可能希望查看std :: allocator的实现,以查看placement-new和cast in action.

标签:placement-new,c
来源: https://codeday.me/bug/20190902/1790475.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有