例如,当您在源代码中引入静态类时,csc编译器将其转换为密封的抽象类(如果我错了,请纠正我)。
但接口怎么样; CLR知道接口是什么吗?或编译器将其转换为某种类型声明?
答案 0 :(得分:10)
<击> 撞击>
<击>例如,当您在源代码中引入抽象类时, csc编译器把它变成一个密封的静态类(如果我是,请纠正我 错了,请)。
我正在纠正你。
抽象类,例如:
public abstract class Foo
{
}
在IL中看起来像这样:
.class public abstract auto ansi beforefieldinit Foo
extends [mscorlib]System.Object
{
.method family hidebysig specialname rtspecialname instance void .ctor() cil managed
{
}
}
击> <击> 撞击>
但接口怎么样; CLR知道接口是什么吗?
是的,它知道。例如:
public interface IFoo
{
}
转换为:
.class public interface abstract auto ansi IFoo
{
}
答案 1 :(得分:7)
你错了,static class
转换为等效的sealed abstract class
。
接口是.NET的完整成员,具有与其他任何类型不同的不同元数据和行为(例如,多重继承)。
答案 2 :(得分:3)
这是ILSpy为以下代码显示的内容。
C#:
interface A
{
void M();
}
IL:
.class interface nested private auto ansi abstract A
{
// Methods
.method public hidebysig newslot abstract virtual
instance void M () cil managed
{
} // end of method A::M
} // end of class A
所以,是的,它确实知道。
答案 3 :(得分:1)
这是CLR的界面:
.class public interface abstract auto ansi IDisposable
{
.custom instance void System.Runtime.InteropServices.ComVisibleAttribute::.ctor(bool) = { bool(true) }
.method public hidebysig newslot abstract virtual instance void Dispose() cil managed
{
}
}
以IDisposable为例。