Symbian编程总结-基础篇-集合与缓冲区(2)-验证RArray::Append是否保存对象副本

本文章由杨芹勍原创,如需转载请注明出处。谢谢!

一、验证栈对象会自动销毁

我们知道,在C++中,在函数中创建了栈对象,函数退出时,该栈对象会自动销毁(栈指针后移了,栈内存会被覆盖)。如何验证这一点?我们需要在函数外定义一个整形变量,在函数内将该函数内获取了变量的地址,在函数调用完毕后,将地址还原成对象:

TInt iAddr;

/**
* 将地址还原成描述符对象并显示出来
* @param aAddr 地址
*/
LOCAL_C void PrintString(TInt aAddr)
    {
    const TBufC<50>& str = *((TBuf<50>*)aAddr);
    console->Write(str);
    }

LOCAL_C void DoTest()
    {
    _LIT(KString, "Test String");
    TBufC<50> str(KString);
    // 获取栈对象str的地址:
    iAddr = (TInt)&str;
    PrintString(iAddr);    // 此处可以正常显示出“Test String”
    }

LOCAL_C void MainL()
    {
    DoTest();   
    PrintString(iAddr);    // 此处显示乱码,证明栈对象会自动销毁
    }

 

二、试验:RArray::Append方法会保存对象的副本

typedef TBufC<20> TFixedBufC;
RArray<TFixedBufC> iArr;

LOCAL_C void DoInsert()
    {
    TFixedBufC text1(_L("test1"));
    iArr.Append(text1);
    }

LOCAL_C void MainL()
    {
    DoInsert();
    TFixedBufC& desc = iArr[0];
    console->Write(desc);
    }

输出结果:

image

按照第一点分析,DoInsert函数内的栈对象text1会在DoInsert函数返回的时候被自动销毁,如果RArray::Append方法只是简单的保存了text1的引用的话,程序不可能能够正确的输出test1。所以,我们通过此试验证明Append方法中构建了一个text1的副本。

 

三、证明:RArray::Append方法会保存对象的副本

typedef TBufC<20> TFixedBufC;
RArray<TFixedBufC> iArr;

LOCAL_C void DoInsert()
    {
    TFixedBufC text1(_L("test1"));
    TBuf<50> addrStr;


    // 获取text1的地址
    addrStr.AppendNum((TInt)&text1);
    iArr.Append(addrStr);
    console->Write(addrStr);
    console->Write(_L("\n"));
    }

LOCAL_C void MainL()
    {
    DoInsert();
    TFixedBufC& desc = iArr[0];
    TBuf<50> addrStr;


    // 获取desc的地址
    addrStr.AppendNum((TInt)&desc);
    console->Write(addrStr);
    }

image

我在函数DoInsert内获取了描述符text1的地址并显示,并将描述符text1使用RArray::Append方法添加到了集合内,在MainL方法内获取了集合第一个元素的引用并将该引用的地址输出。大家可以看到,输出的两个地址并不相同,从而证明了RArray::Append方法创建了对象的副本并保存。

转载于:https://www.cnblogs.com/felixYeou/archive/2008/11/20/1337780.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值