我正在尝试在C#中为我已经拥有的Java代码创建一个等效的代码。 Java代码如下。
class Test
{
public static void main (String args[])
{
C1 o1 = new C1();
C2 o2 = new C2();
System.out.println(o1.m1() + " " + o1.m2() + " " + o2.m1() + " " + o2.m2());
}
}
class C1
{
void C1() {}
int m1() { return 1; }
int m2() { return m1(); }
}
class C2 extends C1
{
void C2() {}
int m1() { return 2; }
}
这给出了输出1 1 2 2.现在,我已经为C#编写了这段代码。
class Program
{
static void Main(string[] args)
{
C1 o1 = new C1();
C2 o2 = new C2();
Console.WriteLine(o1.M1()+ " "+ o1.M2()+ " "+ o2.M1()+ " "+ ((C2)o2).M2()+ "\n");
Console.ReadKey();
}
}
public class C1
{
public C1()
{
}
public int M1()
{
return 1;
}
public int M2()
{
return M1();
}
}
public class C2:C1
{
public C2()
{
}
public int M1()
{
return 2;
}
}
然而,这打印1 1 2 1 ,因为C2中的继承M2调用C1中的M1而不是C2中的M1。如何在C2中调用M1进行微小修改?
答案 0 :(得分:2)
注意:在C#中,您需要使用virtual
和override
关键字来覆盖。
MSDN:
virtual关键字用于修改方法,属性,索引器或事件声明,并允许在派生类中重写。
(我的粗体)
class Program
{
static void Main(string[] args)
{
C1 o1 = new C1();
C2 o2 = new C2();
Console.WriteLine(o1.M1() + " " + o1.M2() + " " + o2.M1() + " " + ((C2)o2).M2() + "\n");
Console.ReadKey();
}
}
public class C1
{
public C1()
{
}
public virtual int M1()
{
return 1;
}
public int M2()
{
return M1();
}
}
public class C2 : C1
{
public C2()
{
}
public override int M1()
{
return 2;
}
}