c#类工厂新手

时间:2012-11-28 09:26:50

标签: c# class factory

这可能是我所寻找的错误标题,但我认为归结为一个班级工厂。

我有三个班级:

   class Horse : Animal
   class Cow :   Animal

我想要创建的是Animal中的一种方法,伪编码可以像这样工作:

   List<Horse or Cow> (Animal horseOrCow)
   {
      if (horseOrCow is of type Horse)
         return a list of 10 Horse objects; 
      else
         return a list of 10 Cow objects;
   }

当然是简化,但是一旦我掌握了如何做到这一点,我应该能够弄清楚其余部分。

(编辑:错字固定)。

6 个答案:

答案 0 :(得分:2)

您可以使用generic method of type

List<T> YourMethod<T>(T horseOrCow) where  T : Mamal
{
   // your code
}

答案 1 :(得分:2)

您可以使用is-operatorEnumerable.OfType + Enumerable.Take

public List<Animal> getMammals(Mammal horseOrCow)
{
    if (horseOrCow is Horse)
        return allAnimals.OfType<Horse>().Take(10).Cast<Animal>().ToList();
    else if (horseOrCow is Cow)
        return allAnimals.OfType<Cow>().Take(10).Cast<Animal>().ToList();
    else
        throw new ArgumentException("Invalid Mammal", "horseOrCow");
}

假设某处有List<Animal> allAnimals

修改Mammal也必须是Animal,由于HorseCowMammals,他们应该从中继承

class Horse : Mammal{ }
class Cow : Mammal { }
class Animal { }
class Mammal : Animal { }

答案 2 :(得分:0)

这应该适合你:

abstract class Animal
abstract class Mammal : Animal  
class Horse : Mammal 
class Cow :   Mammal 

List<T> (T mammal) where  T : Mammal  //mammal is cow or horse
{
   if (horseOrCow is Horse)
      return new List<Horse>(); //add the horses to your list 
   else
      return new List<Cow>(); //add the cows to your list
}

答案 3 :(得分:0)

public class Animal
{
    public List<Mammal> GetMammalList(Mammal mammal)
    {
        List<Mammal> list = new List<Mammal>();
        if (mammal.GetType() == typeof(Horse))
            for (int x = 0; x < 10; x++)
                list.Add(new Horse());
        else if (mammal.GetType() == typeof(Cow))
            for (int x = 0; x < 10; x++)
                list.Add(new Cow());
        else
            throw new ArgumentOutOfRangeException();

        return list;
    }
}

public class Mammal : Animal { }

public class Horse : Mammal { }

public class Cow : Mammal { }

答案 4 :(得分:-1)

我不建议使用is进行类型检查。而是使用dynamic来确定对象的运行时类型。

public void List<T> GetMammals<T>(T mammal) where  T : Mammal
{
   GetMammalsSpecialization(mammal as dynamic);
}

private void List<Horse> GetMammalsSpecialization(Horse horse)
{
    // Specialized code to return list of horses
}

private void List<Cow> GetMammalsSpecialization(Cow cow)
{
    // Specialized code to return list of cows
}

这是double dispatch问题的更好解决方案。

答案 5 :(得分:-2)

public class Animal
{ 
   public enum AnimalType
   {
     CowType,
     HorseType
   }


   ....
   public Animal Create(AnimalType type)
   {
     Animal result = null;
      switch (type)
      {
       case HorseType: result = new Horse();
       case CowType : ....   
      }
     return result;
   }
}