当前位置导航:炫浪网>>网络学院>>编程开发>>C++教程>>C++进阶与实例

实例解析C++/CLI的“克隆”

      C++/CLI不但支持基于堆栈的对象,同时也支持基于堆的对象;然而,如果想与其他基于CLI的语言(如C#、J#、Visual Basic)进行互操作的话,必须要清楚地知道,这些语言只支持基于堆的对象;当处于基于堆的对象环境中时,你与对象之间,永远只有"一臂之遥",比方说,两个给定的句柄h1与h2,只有在为这种句柄类型定义了相应的赋值操作符时,*h1 = *h2才会工作正常,而对C++/CLI之外的其他语言中的类型来说,情况可能就不是这样了。同样地,一个遵从CLS的机制需要创建对象的一份副本,这种机制被称为"克隆"。

      使用CLI库中的Clone函数

      请看例1中的代码,其使用了类似于矢量的一个System::ArrayList类,插1是程序的输出。

      例1:

    using namespace System;
    using namespace System::Collections;

    void PrintEntries(String^ s, ArrayList^ aList);

    int main()
    {
     ArrayList^ al1 = gcnew ArrayList;
     /*1*/ al1->Add("Red");
     al1->Add("Blue");
     al1->Add("Green");
     al1->Add("Yellow");
     /*2*/ PrintEntries("al1", al1);
     /*3*/ ArrayList^ al2 = static_cast<ArrayList^>(al1->Clone());
     /*4*/ PrintEntries("al2", al2);
     /*5*/ al1->Remove("Blue");
     al1->Add("Black");
     al1->RemoveAt(0);
     al1->Insert(0, "Brown");

     /*6*/ PrintEntries("al1", al1);
     /*7*/ PrintEntries("al2", al2);
    }
    void PrintEntries(String^ s, ArrayList^ aList)
    {
     Console::Write("{0}: ", s);
     for each(Object^ o in aList)
     {
      Console::Write("\t{0}", o);
     }
     Console::WriteLine();
    }
      插1:程序输出

    al1: Red Blue Green Yellow
    al2: Red Blue Green Yellow
    al1: Brown Green Yellow Black
    al2: Red Blue Green Yellow
      ArrayList al1由4个代表不同颜色的字符串组成,通过在标记3中调用ArrayList::Clone函数,可以对此对象作一个完整的复制,所以,标记2与4表示的输出完全相同。

      接下来,从al1中移除了第二个元素,在末尾加入了一个新的元素,并修改了第一个元素的值。当把标记6与7表示的输出进行一个对比时,你会发现,对al1所作的修改,完全不会影响到al2。在此需要说明的是,al2内部的引用,指向其自身元素的私有副本,而不是al1中的元素,这就是通常提到的"深拷贝",反之,只是简单地把两个ArrayList内部引用指向同一个值集(如al2=al1的赋值操作),这称为"浅拷贝"。

      也就是说,如果你希望复制所拥有的对象,应该参照库函数Clone机制中的复制过程。

      在类型中添加克隆

      克隆的关键是实现System::ICloneable标准接口,其需要你定义一个调用Clone、不接受任何参数、并带有一个System::Object^返回类型的函数,返回的句柄指向一个新的对象,这个对象是被调用对象的一个副本。请看例2:

  

共4页 首页 上一页 1 2 3 4 下一页 尾页 跳转到
相关内容
赞助商链接