C#基礎(chǔ)知識(shí)系列八const和readonly關(guān)鍵字詳細(xì)介紹
前言
不知道大家對(duì)const和readonly這兩個(gè)關(guān)鍵字的區(qū)別有什么了解,原來(lái)自己之前還真不清楚它們到底是怎么回事,那么如果你也不是很清楚的話,可以一起來(lái)探討一下。在了解這兩個(gè)關(guān)鍵字的時(shí)候我們先來(lái)了解一下靜態(tài)常量和動(dòng)態(tài)常量。
靜態(tài)常量:是指編譯器在編譯時(shí)候會(huì)對(duì)常量進(jìn)行解析,并將常量的值替換成初始化的那個(gè)值。
而動(dòng)態(tài)常量的值則是在運(yùn)行的那一刻才獲得的,編譯器編譯期間將其標(biāo)示為只讀常量,而不用常量的值代替,這樣動(dòng)態(tài)常量不必在聲明的時(shí)候就初始化,而可以延遲到構(gòu)造函數(shù)中初始化?,F(xiàn)在再來(lái)說(shuō)明const與readonly吧。
readonly和const
const修飾的常量是上述中的第一種,即靜態(tài)常量;而readonly則是第二種,即動(dòng)態(tài)常量。那么區(qū)別可以通過(guò)靜態(tài)常量與動(dòng)態(tài)常量的特性來(lái)說(shuō)明:
1、const修飾的常量在聲明的時(shí)候必須初始化;readonly修飾的常量則可以延遲到構(gòu)造函數(shù)初始化
2、const修飾的常量在編譯期間就被解析,即常量值被替換成初始化的值;readonly修飾的常量則延遲到運(yùn)行的時(shí)候
3、const修飾的常量注重的是效率;readonly修飾的常量注重靈活
4、const修飾的常量沒(méi)有內(nèi)存消耗;readonly因?yàn)樾枰4娉A浚杂袃?nèi)存消耗
5、const只能修飾基元類型、枚舉類、或者字符串類型;readonly卻沒(méi)有這個(gè)限制
第一個(gè)例子:
如果在const前面加了一個(gè)static的話,那顯然是錯(cuò)誤的,因?yàn)閏onst編譯之后就已經(jīng)是static靜態(tài)字段了
在編譯之后const 變量就會(huì)被替換成變量的值了,這也就是為什么說(shuō)它是高效了。
const double pi = 3.1415926;
static void Main(string[] args)
{
Console.WriteLine(pi);
Console.ReadLine();
}
打印變量的代碼編譯之后就已經(jīng)是
Console.WriteLine((double) 3.1415926);
第二個(gè)例子:
接下來(lái)看一下readonly的小例子
class Person
{
public readonly string Name;
public Person(string name)
{
this.Name = name;
}
}
class Program
{
static void Main(string[] args)
{
Person person = new Person("aehyok");
person.Name = "Leo";
Console.ReadLine();
}
}
Person實(shí)例 name 在構(gòu)造函數(shù)中被賦值后就不可變,下面的代碼在編譯后會(huì)報(bào)錯(cuò)
接下來(lái)我們看一下另外一種情況
class Person
{
public string Name;
public Person(string name)
{
this.Name = name;
}
}
class Worker
{
public readonly Person Person;
public Worker(Person person)
{
this.Person = person;
}
}
class Program
{
static void Main(string[] args)
{
Worker worker = new Worker(new Person("aehyok"));
worker.Person = new Person("Leo");
worker.Person.Name = "Leo";
Console.ReadLine();
}
}
來(lái)看編譯后的效果
這一點(diǎn)不知是否可以說(shuō)是readonly的靈活呢
第三個(gè)例子:
class Program
{
static readonly int A = B * 10;
static readonly int B = 10;
public static void Main(string[] args)
{
Console.WriteLine("A is {0},B is {1} ", A, B);
Console.ReadLine();
}
}
結(jié)果很簡(jiǎn)單
道理也比較簡(jiǎn)單,就是static readonly是動(dòng)態(tài)常量,變量的值在編譯期間不予以解析,所以開(kāi)始都是默認(rèn)值,像A與B都是int類型,故都是0。而在程序執(zhí)行到A=B*10;所以A=0*10=0,程序接著執(zhí)行到B=10這句時(shí)候,才會(huì)真正的B的初值10賦給B。
總結(jié)
對(duì)于const和readonly這兩個(gè)關(guān)鍵字目前來(lái)說(shuō),也算是有所了解了,還是學(xué)了不少東西,如果看完本文還有疑問(wèn)的話,你可以通過(guò)微軟提供的ILDASM工具。
打開(kāi)cmd命令之后,輸入ILDASM。
打開(kāi)exe文件進(jìn)行查看IL執(zhí)行過(guò)程,慢慢研究吧。
相關(guān)文章
C#使用async和await實(shí)現(xiàn)異步編程
本文詳細(xì)講解了C#使用async和await實(shí)現(xiàn)異步編程的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07淺析C# 使用Process調(diào)用外部程序中所遇到的參數(shù)問(wèn)題
這篇文章主要介紹了C# 使用Process調(diào)用外部程序中所遇到的參數(shù)問(wèn)題,需要的朋友可以參考下2017-03-03C#中ftp檢測(cè)目錄是否存在和創(chuàng)建文件夾的實(shí)現(xiàn)
本文主要介紹了C#中ftp檢測(cè)目錄是否存在和創(chuàng)建文件夾的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07c# 以類名為參創(chuàng)建父類相同的類的實(shí)例代碼
下面小編就為大家?guī)?lái)一篇c# 以類名為參創(chuàng)建父類相同的類的實(shí)例代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-01-01如何用C#獲取計(jì)算機(jī)詳細(xì)的軟件和硬件信息
我們應(yīng)該都知道System.Management提供的類可以用于讀取本地計(jì)算機(jī)設(shè)備的各種數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于如何用C#獲取計(jì)算機(jī)詳細(xì)的軟件和硬件信息的相關(guān)資料,需要的朋友可以參考下2022-12-12詳解C# ConcurrentBag的實(shí)現(xiàn)原理
ConcurrentBag<T>實(shí)現(xiàn)了IProducerConsumerCollection<T>接口,該接口主要用于生產(chǎn)者消費(fèi)者模式下,可見(jiàn)該類基本就是為生產(chǎn)消費(fèi)者模式定制的。然后還實(shí)現(xiàn)了常規(guī)的IReadOnlyCollection<T>類,實(shí)現(xiàn)了該類就需要實(shí)現(xiàn)IEnumerable<T>、IEnumerable、 ICollection類2021-06-06C#打包部署并把.net framework框架打到安裝包的方法步驟
打包c(diǎn)#程序時(shí),有時(shí)需要添加.net framework組件到安裝包,本文就來(lái)介紹一下C#打包部署并把.net framework框架打到安裝包的方法步驟,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10