本篇內(nèi)容主要講解“CLR Via C#調(diào)用靜態(tài)構(gòu)造函數(shù)是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“CLR Via C#調(diào)用靜態(tài)構(gòu)造函數(shù)是什么”吧!
創(chuàng)新互聯(lián)擁有十載的建站服務(wù)經(jīng)驗(yàn),在此期間,我們發(fā)現(xiàn)較多的客戶在挑選建站服務(wù)商前都非常的猶豫。主要問題集中:在無法預(yù)知自己的網(wǎng)站呈現(xiàn)的效果是什么樣的?也無法判斷選擇的服務(wù)商設(shè)計(jì)出來的網(wǎng)頁效果自己是否會(huì)滿意?創(chuàng)新互聯(lián)業(yè)務(wù)涵蓋了互聯(lián)網(wǎng)平臺(tái)網(wǎng)站建設(shè)、移動(dòng)平臺(tái)網(wǎng)站制作、網(wǎng)絡(luò)推廣、專業(yè)公司等服務(wù)。創(chuàng)新互聯(lián)網(wǎng)站開發(fā)公司本著不拘一格的網(wǎng)站視覺設(shè)計(jì)和網(wǎng)站開發(fā)技術(shù)相結(jié)合,為企業(yè)做網(wǎng)站提供成熟的網(wǎng)站設(shè)計(jì)方案。
CLR Via C#總結(jié):
1 靜態(tài)構(gòu)造函數(shù)是私有的(private) ,而且不能人為去修改訪問修飾符。
2 靜態(tài)構(gòu)造函數(shù)不應(yīng)該去調(diào)用基類的靜態(tài)構(gòu)造函數(shù),因?yàn)殪o態(tài)字段不會(huì)被繼承到子類。
3 靜態(tài)構(gòu)造函數(shù)在一個(gè)類型中有且僅有一個(gè),并且是無參的。
4 靜態(tài)構(gòu)造函數(shù)中只能初始化靜態(tài)字段。
從上面的4點(diǎn)可以知道靜態(tài)構(gòu)造函數(shù)都是private的,所以不能顯示區(qū)進(jìn)行調(diào)用,關(guān)于JIT何時(shí)會(huì)去生成調(diào)用靜態(tài)構(gòu)造函數(shù)的代碼。存在著兩種說法。通常被稱為Precise和BeforeFieldInit。Precise方式JIT編譯器生成調(diào)用的時(shí)機(jī):***創(chuàng)建類型的代碼之前;訪問類的非繼承字段或成員代碼之前。BeforeFieldInit方式JIT編譯器生成調(diào)用的時(shí)機(jī):在訪問費(fèi)繼承靜態(tài)字段代碼之前。
這兩種方式的主要區(qū)別就是選擇調(diào)用靜態(tài)構(gòu)造函數(shù)的時(shí)機(jī)是否是確定的,Precise方式CLR會(huì)在確定的時(shí)刻調(diào)用靜態(tài)構(gòu)造函數(shù),而BeforeFieldInit方式CLR可以自由選擇調(diào)用靜態(tài)構(gòu)造函數(shù)的時(shí)機(jī),利用這一點(diǎn),CLR可以根據(jù)類型是否在程序域中加載來選擇靜態(tài)構(gòu)造函數(shù)的調(diào)用次數(shù),以便能生成執(zhí)行更快的代碼。
下面來看來個(gè)類分別展現(xiàn)了這兩種方式
public class UserPrecise { public static string _name = "內(nèi)聯(lián)賦值:oec2003"; static UserPrecise() { _name = "構(gòu)造函數(shù)賦值:oec2003"; } } public class UserBeforeFieldInit { public static string _name = "內(nèi)聯(lián)賦值:oec2003"; }
通過IL代碼可以看出在UserBeforeFieldInit 的元數(shù)據(jù)上有BeforeFieldInit的標(biāo)記,如下圖:
既然上面提到BeforeFieldInit方式CLR可以選擇調(diào)用構(gòu)造函數(shù)的次數(shù)從而來生成執(zhí)行更快的代碼,下面就寫一段測(cè)試代碼來看看究竟怎樣。
public sealed class Program { static void Main(string[] args) { const Int32 iterations = 1000 * 1000 * 1000; Test1(iterations); Test2(iterations); } private static void Test1(Int32 iterations) { Stopwatch sw = Stopwatch.StartNew(); for (Int32 i = 0; i < iterations; i++) { UserBeforeFieldInit._name = "oec2003"; } Console.WriteLine("Test1-UserBeforeFieldInit 用時(shí):" + sw.Elapsed); sw = Stopwatch.StartNew(); for (Int32 j = 0; j < iterations; j++) { UserPrecise._name = "oec2003"; } Console.WriteLine("Test1-UserPrecise 用時(shí):" + sw.Elapsed); } private static void Test2(Int32 iterations) { Stopwatch sw = Stopwatch.StartNew(); for (Int32 i = 0; i < iterations; i++) { UserBeforeFieldInit._name = "oec2003"; } Console.WriteLine("Test2-UserBeforeFieldInit 用時(shí):" + sw.Elapsed); sw = Stopwatch.StartNew(); for (Int32 j = 0; j < iterations; j++) { UserPrecise._name = "oec2003"; } Console.WriteLine("Test2-UserPrecise 用時(shí):" + sw.Elapsed); } } public class UserBeforeFieldInit { public static string _name; } public class UserPrecise { public static string _name ; static UserPrecise() { _name = "oec2003"; } }
CLR Via C#調(diào)用靜態(tài)構(gòu)造函數(shù)測(cè)試結(jié)果如下:
從上面CLR Via C#調(diào)用靜態(tài)構(gòu)造函數(shù)結(jié)果來看,BeforeFieldInit方式的執(zhí)行速度還是要快很多,但為什么第二次執(zhí)行時(shí),兩種方式的速度差不多呢?因?yàn)榻?jīng)過***次執(zhí)行后JIT編譯器知道類型的構(gòu)造器已經(jīng)被調(diào)用了,所以第二次執(zhí)行時(shí)不會(huì)顯示對(duì)構(gòu)造函數(shù)進(jìn)行調(diào)用。
到此,相信大家對(duì)“CLR Via C#調(diào)用靜態(tài)構(gòu)造函數(shù)是什么”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
分享標(biāo)題:CLRViaC#調(diào)用靜態(tài)構(gòu)造函數(shù)是什么
分享路徑:http://aaarwkj.com/article24/gghgje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、搜索引擎優(yōu)化、網(wǎng)站改版、定制開發(fā)、App開發(fā)、微信公眾號(hào)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)