-
C#教程之C# 的关键字详细介绍
用于修饰类,方法,属性和字段的关键字:
首先从最简单的private,protected,internal,public 解释。
public 和internal 修饰类。
public,protected,private 修饰方法。
修饰类的时候:
public 代表公开,也就是所有程序集都可以访问这个类。
internal 代表内部的,也就是只有在同一程序集中才能访问这个类,一般而言同一程序集就是同一个dll。
修饰方法的时候:
public 代表公开,也就是所有的类都可以访问这个方法。
protected 代表受保护的,也就是只有我的子类才能访问这个方法。
private 代表私有的,也就是只有我才能访问这个方法。
接着我们来讨论下const,readonly 的区别:
首先两者都是常量,不同的是const 是编译时常量,readonly是运行时常量。
编译时常量:在编译的时候,值就已经是常量了,任何使用该变量的地方都会被替换成常量值。
运行时常量:在运行的时候,值不能够被修改。
public class Test
{
public const string constStr = "this is a test";
public readonly string readonlyStr = "this can't be modified in runtime time";
public void Method1()
{
string s1 = constStr; // 在编译的时候,这句话就会被替换成 string s1 = "this is a test";
readonlyStr = "error";
//尝试修改readonlyStr,无法通过编译,
//抛出错误:readonly 字段只有在构造函数和初始化的时候才能修改。
}
}
OK,现在我们讨论下abstract, virtual , new , override 关键字:
首先abstract 代表的是抽象,abstract 可以修饰类和方法。
修饰类的时候:
这个时候叫做抽象类,抽象类有下列性质:
抽象类不能实例化。
抽象类可以包含抽象方法和抽象访问器,访问器实际上也是方法。
不能用 sealed修饰符修饰抽象类,因为这两个修饰符的含义是相反的。 采用 sealed 修饰符的类无法继承,而 abstract 修饰符要求对类进行继承。
从抽象类派生的非抽象类必须包括继承的所有抽象方法和抽象访问器的实际实现。
修饰方法的时候:
这个时候叫做抽象方法,性质如下:
抽象方法是隐式的虚方法(用virtual 修饰方法的叫做虚方法)。
只允许在抽象类中使用抽象方法声明,只要使用抽象方法,那么这个就是抽象类。
因为抽象方法声明不提供实际的实现,所以没有方法体;方法声明只是以一个分号结束,并且在签名后没有大括号 ({ })。 例如:
public abstract void MyMethod();
实现由一个重写方法override 提供,此重写方法是非抽象类的一个成员。
在抽象方法声明中使用 static 或 virtual 修饰符是错误的,因为抽象方法需要被重写,所以不能用static修饰,因为抽象方法是隐式的虚方法,所以不能用virtual修饰。
除了在声明和调用语法上不同外,抽象属性的行为与抽象方法一样,属性本质上是方法。
在静态属性上使用 abstract 修饰符是错误的。
在派生类中,通过包括使用 override 修饰符的属性声明,可以重写抽象的继承属性。
virtual 关键字代表虚拟的,虚的,修饰的是方法。
修饰方法的时候:
这个时候叫做虚方法,虚方法代表这个方法是虚的,这个方法可能没有实现,这个方法可以被重写。
关键的一句话是:这个方法可以被重写。
这代表,如果这个方法想要被重写,被override,那么它就必须是一个虚方法,因为abstract修饰的方法是隐式的虚方法,所以abstract和virtual 修饰的方法可以被override。
override 关键字代表重写,修饰的是方法。
override 方法提供从基类继承的成员的新实现。 由 override 声明重写的方法称为重写基方法。 重写的基方法必须与 override 方法具有相同的签名。
修饰方法的时候:
1:不能重写非虚方法或静态方法。 重写的基方法必须是 virtual、abstract 或 override 的。
override 方法和 virtual 方法必须具有相同的访问级别修饰符。
2:您不能使用 new、static 或 virtual 修饰符来修改 override 方法。
3:重写属性声明必须指定与继承属性完全相同的访问修饰符、类型和名称,并且被重写的属性必须
是 virtual、abstract 或 override 的。
new 关键字代表隐藏,修饰的是方法。
new 和override 的区别是,new 是隐藏父类方法,这就好比告诉别人,这个方法和父类的方法是两个不同的方法,只是他们的签名刚好相同罢了,override 则不同,override 告诉别人,以后用我的instance调用的就是我的方法,用父类的instance调用的就是父类的方法。
总结下:abstract,virtual,override,new 的关系。
override 的方法必须是abstract ,virtual, override 的。
abstract 的方法是隐式的virtual 方法。
virtual 的方法代表这个方法可以被重写,当然你也可以不重写它。
abstract的方法代表这个方法是必须被重写的方法。
new 的方法代表这个方法和父类的没关系,是一个新的“new” 方法,只是刚好签名相同罢了。
最后一道题:
class A
{
public virtual void F()
{
Console.WriteLine("A.F");
}
}
class B : A
{
public override void F()
{
Console.WriteLine("B.F");
}
}
class C : B
{
new public virtual void F() { Console.WriteLine("C.F"); }
}
class D : C
{
public override void F() { Console.WriteLine("D.F"); }
}
class Program2
{
static void Main()
{
D d = new D();
A a = d; B b = d;
C c = d; a.F(); b.F();
c.F();
d.F();
}
}
首先从最简单的private,protected,internal,public 解释。
public 和internal 修饰类。
public,protected,private 修饰方法。
修饰类的时候:
public 代表公开,也就是所有程序集都可以访问这个类。
internal 代表内部的,也就是只有在同一程序集中才能访问这个类,一般而言同一程序集就是同一个dll。
修饰方法的时候:
public 代表公开,也就是所有的类都可以访问这个方法。
protected 代表受保护的,也就是只有我的子类才能访问这个方法。
private 代表私有的,也就是只有我才能访问这个方法。
接着我们来讨论下const,readonly 的区别:
首先两者都是常量,不同的是const 是编译时常量,readonly是运行时常量。
编译时常量:在编译的时候,值就已经是常量了,任何使用该变量的地方都会被替换成常量值。
运行时常量:在运行的时候,值不能够被修改。
复制代码 代码如下:
public class Test
{
public const string constStr = "this is a test";
public readonly string readonlyStr = "this can't be modified in runtime time";
public void Method1()
{
string s1 = constStr; // 在编译的时候,这句话就会被替换成 string s1 = "this is a test";
readonlyStr = "error";
//尝试修改readonlyStr,无法通过编译,
//抛出错误:readonly 字段只有在构造函数和初始化的时候才能修改。
}
}
OK,现在我们讨论下abstract, virtual , new , override 关键字:
首先abstract 代表的是抽象,abstract 可以修饰类和方法。
修饰类的时候:
这个时候叫做抽象类,抽象类有下列性质:
抽象类不能实例化。
抽象类可以包含抽象方法和抽象访问器,访问器实际上也是方法。
不能用 sealed修饰符修饰抽象类,因为这两个修饰符的含义是相反的。 采用 sealed 修饰符的类无法继承,而 abstract 修饰符要求对类进行继承。
从抽象类派生的非抽象类必须包括继承的所有抽象方法和抽象访问器的实际实现。
修饰方法的时候:
这个时候叫做抽象方法,性质如下:
抽象方法是隐式的虚方法(用virtual 修饰方法的叫做虚方法)。
只允许在抽象类中使用抽象方法声明,只要使用抽象方法,那么这个就是抽象类。
因为抽象方法声明不提供实际的实现,所以没有方法体;方法声明只是以一个分号结束,并且在签名后没有大括号 ({ })。 例如:
public abstract void MyMethod();
实现由一个重写方法override 提供,此重写方法是非抽象类的一个成员。
在抽象方法声明中使用 static 或 virtual 修饰符是错误的,因为抽象方法需要被重写,所以不能用static修饰,因为抽象方法是隐式的虚方法,所以不能用virtual修饰。
除了在声明和调用语法上不同外,抽象属性的行为与抽象方法一样,属性本质上是方法。
在静态属性上使用 abstract 修饰符是错误的。
在派生类中,通过包括使用 override 修饰符的属性声明,可以重写抽象的继承属性。
virtual 关键字代表虚拟的,虚的,修饰的是方法。
修饰方法的时候:
这个时候叫做虚方法,虚方法代表这个方法是虚的,这个方法可能没有实现,这个方法可以被重写。
关键的一句话是:这个方法可以被重写。
这代表,如果这个方法想要被重写,被override,那么它就必须是一个虚方法,因为abstract修饰的方法是隐式的虚方法,所以abstract和virtual 修饰的方法可以被override。
override 关键字代表重写,修饰的是方法。
override 方法提供从基类继承的成员的新实现。 由 override 声明重写的方法称为重写基方法。 重写的基方法必须与 override 方法具有相同的签名。
修饰方法的时候:
1:不能重写非虚方法或静态方法。 重写的基方法必须是 virtual、abstract 或 override 的。
override 方法和 virtual 方法必须具有相同的访问级别修饰符。
2:您不能使用 new、static 或 virtual 修饰符来修改 override 方法。
3:重写属性声明必须指定与继承属性完全相同的访问修饰符、类型和名称,并且被重写的属性必须
是 virtual、abstract 或 override 的。
new 关键字代表隐藏,修饰的是方法。
new 和override 的区别是,new 是隐藏父类方法,这就好比告诉别人,这个方法和父类的方法是两个不同的方法,只是他们的签名刚好相同罢了,override 则不同,override 告诉别人,以后用我的instance调用的就是我的方法,用父类的instance调用的就是父类的方法。
总结下:abstract,virtual,override,new 的关系。
override 的方法必须是abstract ,virtual, override 的。
abstract 的方法是隐式的virtual 方法。
virtual 的方法代表这个方法可以被重写,当然你也可以不重写它。
abstract的方法代表这个方法是必须被重写的方法。
new 的方法代表这个方法和父类的没关系,是一个新的“new” 方法,只是刚好签名相同罢了。
最后一道题:
复制代码 代码如下:
class A
{
public virtual void F()
{
Console.WriteLine("A.F");
}
}
class B : A
{
public override void F()
{
Console.WriteLine("B.F");
}
}
class C : B
{
new public virtual void F() { Console.WriteLine("C.F"); }
}
class D : C
{
public override void F() { Console.WriteLine("D.F"); }
}
class Program2
{
static void Main()
{
D d = new D();
A a = d; B b = d;
C c = d; a.F(); b.F();
c.F();
d.F();
}
}
最新更新
Objective-C语法之代码块(block)的使用
VB.NET eBook
Add-in and Automation Development In VB.NET 2003 (F
Add-in and Automation Development In VB.NET 2003 (8
Add-in and Automation Development in VB.NET 2003 (6
Add-in and Automation Development In VB.NET 2003 (5
AddIn Automation Development In VB.NET 2003 (4)
AddIn And Automation Development In VB.NET 2003 (2)
Addin and Automation Development In VB.NET 2003 (3)
AddIn And Automation Development In VB.NET 2003 (1)
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
武装你的WEBAPI-OData入门
武装你的WEBAPI-OData便捷查询
武装你的WEBAPI-OData分页查询
武装你的WEBAPI-OData资源更新Delta
5. 武装你的WEBAPI-OData使用Endpoint 05-09
武装你的WEBAPI-OData之API版本管理
武装你的WEBAPI-OData常见问题
武装你的WEBAPI-OData聚合查询
OData WebAPI实践-OData与EDM
OData WebAPI实践-Non-EDM模式