簡體   English   中英

為什么我的克隆代碼無法編譯?

[英]Why doesn't my clone code compile?

我有一個想要使用的簡單克隆界面。 看起來它應該編譯,但不是。 我收到一條消息,說我的BObject類未實現DeepClone() 我不明白這一點,因為我有一個DeepClone()方法,而我的BObject實現了 IObject

interface IDeepCloneable<T>
{
    T DeepClone();
}

interface IObject : IDeepCloneable<IObject>
{
    string Name { get; }
    double Sales { get; }
}

//'BObject' does not implement interface member
//  'IDeepCloneable<IObject>.DeepClone()'
class BObject : IObject
{
    public string Name { get; set; }
    public double Sales { get; set; }

    public BObject DeepClone()
    {
        return new BObject() { Name = this.Name, Sales = this.Sales };
    }
}

我在聲明接口錯誤嗎?


還是DeepClone實現? 我可以使用以下代碼:

public IObject DeepClone() //returns an IObject instead of a BObject
{
    return new BObject() { Name = this.Name, Sales = this.Sales };
}

我的問題是沒有檢查BObject.DeepClone()方法是否返回BObject作為結果。 我可以有一個看起來像這樣的課:

class BObjectImposter : IObject
{
    public string Name { get; set; }
    public double Sales { get; set; }

    public IObject DeepClone()
    {
        //returns a BObject instead of a BObjectImposter
        return new BObject() { Name = this.Name, Sales = this.Sales };
    }
}

使用此類,我可以這樣寫:

BObjectImposter objImp = new BObjectImposter();
IObject copy = objImp.DeepClone();

我可能希望該copyBObjectImposter的實現,但實際上是不相關的類BObject的實現,而該類恰好也實現了IObject 我知道接口的意義在於我使用哪種實現都無關緊要,但這對我來說似乎不是好的代碼。 也許在我的BObjectImposter實現中的某個地方,我希望DeepClone()返回一個BObjectImposter對象。 同樣,IObject的一種實現不應依賴於IObject的另一種實現。


也許我可以將IObject DeepClone()抽象類,然后在其中聲明DeepClone() 如果我有一個實現(稱為ObjectA ),需要在構造函數中設置Sales之前先設置Name ,而另一個實現(稱為ObjectB ),則需要在其中設置Name之前設置Sales ,這似乎可能會破壞我的設計。構造函數。

正如您在問題中所暗示的那樣, IObject實現了IDeepClonable < IObject >,因此其DeepClone()方法必須返回IObject

您需要完全使用CRTP

interface IObject<T> : IDeepCloneable<T> where T : IObject<T>
class BObject : IObject<BObject>

(你也應當添加where T : IDeepCloneable<T>IDeepCloneable

這是因為IObject繼承了IDeepCloneable<IObject>所以DeepClone將返回IObject 以下應該工作:

    interface IDeepCloneable<T>
{
    T DeepClone();
}

interface IObject<T> : IDeepCloneable<T>
{
    string Name { get; }
    double Sales { get; }
}

//'BObject' does not implement interface member
//  'IDeepCloneable<IObject>.DeepClone()'
class BObject : IObject<BObject>
{
    public string Name { get; set; }
    public double Sales { get; set; }

    public BObject DeepClone()
    {
        return new BObject() { Name = this.Name, Sales = this.Sales };
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM