浅拷贝与深拷贝

浅拷贝与深拷贝

  在某些状况下,类内成员变量需要动态开辟堆内存,如果实行位拷贝,也就是把对象里的值完全复制给另一个对象,如A=B。这时,如果B中有一个成员变量指针已经申请了内存,那A中的那个成员变量也指向同一块内存。这就出现了问题:当B把内存释放了(如:析构),这时A内的指针就是野指针了,出现运行错误。

  深拷贝和浅拷贝可以简单理解为:如果一个类拥有资源,当这个类的对象发生复制过程的时候,资源重新分配,这个过程就是深拷贝,反之,没有重新分配资源,就是浅拷贝。

  • 下面举个深拷贝的例子
class Base
{
private:
    char* name;
public:
    Base(const char* className)
    {
        name = new char[strlen(className) + 1];
        strcpy(name, className);
    }
    ~Base()    { delete name; }
    const char *copyName()
    {
        char newname[256];   //栈内存
        //char* newname = (char*)malloc(256*sizeof(char));
        memset(newname, 0, 256);
        strcpy(newname, name);
        return newname;
    }

    char* getName(){ return name; }

    //static void print(Base* base)
    static void print(const Base base)  // 发生值拷贝,浅拷贝
    {
        printf("name: %s\n", base.name);
    }
};

class Subclass : public Base
{
public:
    Subclass(const char* className) : Base(className)
    {
    }
};

int main_mem()
{
    Base *pBase = new Subclass("test");

    Base::print(*pBase);                    // 用后内部对象会被释放掉,下面的指向将为空指针 
    printf("name: %s\n", pBase->getName());// 指针指向的内存不存在,出错

    char *temp = pBase->copyName();        // 返回局部变量
    printf("new name: %s\n", temp);        // 局部变量生命周期早已结束,出错

    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值