久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区

以文本方式查看主題

-  曙海教育集團論壇  (http://www.rfoamep.cn/bbs/index.asp)
--  Brew手機開發  (http://www.rfoamep.cn/bbs/list.asp?boardid=49)
----  深入brew開發:C#開發的兩個原則的深入討論  (http://www.rfoamep.cn/bbs/dispbbs.asp?boardid=49&id=2133)

--  作者:wangxinxin
--  發布時間:2010-12-6 10:23:28
--  深入brew開發:C#開發的兩個原則的深入討論

使用屬性避免將數據成員直接暴露給外界

  學習研究.NET早期經常碰到些學習C#/.NET朋友問要屬性這種華而不實東西做什么?后來做項目時也時常接到team里人抱怨反饋為什么不直接放個public字段?如:

   Card
{
 public  Name;
}

  而非要做個private字段+public屬性?

   Card
{
 private  name;
 public  Name
 {
  get {  this.name;}
   { this.name=value;}
 }
}

  我記得在早期個項目里team中個朋友甚至厭煩了寫private字段+public屬性尤其是碰到大堆臃腫data object 時候索性自己寫了個小工具來提供個類字段名和類型然后自動為該類生成相應private字段+public屬性

  我在編程時候是個徹底實用主義者用稍微高雅點話說叫“不喜歡過度設計”如果真像上面那樣寫Card而且在將來沒有什么改變需求我也不喜歡像上面第2段那樣把事情故意搞得復雜但如果從component角度來講總有些是要供外部長久地使用也潛在地在將來有被改變需求這時候提供屬性就很有必要了

  這就是這個Item試圖要歸納使用屬性理由:

  1.可以對賦值做校驗、或者額外處理

  2.可以做線程同步

  3.可以使用虛屬性、或者抽象屬性

  4.可以將屬性置于erface中

  5.可以提供get-only或者-only版本甚至可以給讀、寫以區別訪問權限(C# 2.0支持)

  個人感覺3、4條是屬性最大優點可以填補沒有“虛字段”或“抽象字段”缺憾在設計組件時候非常有用也體現了C#這樣component-oriented語言精神內涵

  但如果沒有上述理由而且日后對做大改動可能性比較小時我想也大可不必非要把每個public字段都要變成屬性比如在設計些輕型struct用于互操作時候直接使用public字段沒什么不好所以感覺本條目Bill Wagner先生使用“Always Use Properties Instead of Accessible Data Members”顯得太過強硬

  其實這里討論也表明閱讀Effective C#書時需要注意地方即Effective原則并不是放的 4海而皆準區別項目(組件化、復用程度較高項目?還是“次編寫、N年都run”項目)區別角色(類庫/組件開發人員?還是應用開發人員?)有著區別Effective準則事實上書中很多Items都是從類庫/組件開發人員角度來考慮

  有關屬性性能問題需要談點如果僅僅是簡單地以存取模式來使用屬性在相當程度上是沒有性能損失在JIT編譯過程中已經做了inline處理不過inline處理還是有些基本條件有些情況下JIT編譯器不會inline比如虛思路方法IL代碼長度過長(目前CLR規定是超過32s為代碼長度過長)有復雜控制流邏輯有異常處理等這些條件都是要么根本不能使用inline(比如虛屬性)要么inline代價太大容易導致代碼bloat要么是inline起來很費時間——已經喪失了inline意義.NETinline機制發生在JIT過程中使用屬性有個別讓人感覺不舒服地方比如它影響開發人員開發效率但對代碼運行效率不產生影響

  明辨值類型和引用類型使用場合

  這個條款討論是類型設計時候tradeoff——是將類型設計為結構還是類Bill Wagner先生給出了個原則“值類型用于存儲數據引用類型用于定義行為(value types store values and reference types  behavior)”

  如何判斷這個原則適用性Bill Wagner也給出了個思路方法那就是首先回答下面幾個問題:

  1.該類型主要職責是否用于數據存儲?

  2.該類型公有接口是否都是些存取屬性?

  3.是否確信該類型永遠不可能有子類?

  4.是否確信該類型永遠不可能具有多態行為?

  如果所有問題答案都是yes那么就應該采用值類型這樣判斷確實有很好理由支撐但是我個人認為“將這4個問題回答為yes”還不足以構成采用值類型全部理由在很多項目實戰中我發現值類型帶來性能問題不可小視值類型帶來性能問題主要有兩個:

  1.由于值類型例子在棧和托管堆的間轉換而導致box/unbox以及由此帶來托管堆上垃圾

  2.值類型默認情況下采用是值拷貝語義如果是比較大值類型在傳遞參數和返回值時同樣會帶來性能問題

  有關第1條Bill Wagner在本條款中提到了“引用類型會給垃圾收集器帶來負擔”這個表面看似正確判斷但是由于box/unbox效應有些情況下反倒是值類型給垃圾收集器帶來了更多負擔比如將些值類型放到個集合中然后又頻繁地對其進行讀寫操作如果碰到這種情況我想“放棄結構而采用類”未嘗不是種更好做法事實上將個用作數據存儲值類型(比如.Drawing.Po)添加到個集合(.Collections.ArrayList)中是個太常見不過操作不過C# 2.0中新引入泛型技術對box/unbox問題有極大改善

  有關第2條Scott Meyers先生在Effective C第22條“盡量使用pass-by-reference(傳址)少用pass-by-value(傳值)”中講比較清楚雖然由于C#中結構類型具有默認深拷貝語義沒有拷貝構造器而且結構類型也沒有子類因此在某種程度上來講不具有多態性也就沒有C對象傳值時可能出現切割(slicing)效應但是值拷貝成本仍然不小尤其是在這個值類型比較大情況下問題就比較嚴重實際上在.NET框架Design Guidelines for Class Library Developers文檔中在介紹說明什么時候應該使用結構類型時候其中提到了項原則(還有其他些并行原則)——類型例子數據大小要小于16個字節該文檔主要是從類型運行效率層面來考慮而Bill Wagner先生這里條款主要是從類型設計層面來考慮

 

  從上述兩條討論來看我個人傾向于對結構類型采取更為保守設計策略而對于類則可以積極大膽地使用“將結構類型不適當地設計為類”帶來不良后果要遠遠小于“將類不適當地設計為結構類型”所帶來不良后果就目前經驗來看我甚至認為只有和非托管互操作打交道情況才是使用結構類型最充足理由其他情況都要“ 3思而后行”當然在C# 2.0中引入泛型技術的后box/unbox將不再是個沉重負擔應付些非常輕量級場合結構類型依然有自己席的地

 


久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
成人永久免费视频| 粉嫩av一区二区三区粉嫩| 欧美日韩一区综合| 成人开心网精品视频| 婷婷久久综合九色综合绿巨人| 日韩欧美一区二区三区在线| 亚洲一区在线免费| 九色视频成人porny| 91成人免费在线观看| 国产一区二区三区免费观看| 午夜精品成人在线视频| 日韩高清不卡一区| 亚洲综合色成人| 国产精品视频线看| 国产校园另类小说区| 4438x亚洲最大成人网| 色天使久久综合网天天| 日韩精品资源| 先锋影音网一区| 精品中文字幕一区| 999国产视频| 激情综合色丁香一区二区| 秋霞国产午夜精品免费视频| 午夜精品福利在线| 狠狠色综合播放一区二区| 成人一区二区三区视频在线观看| 91久色国产| 亚洲砖区区免费| 日韩视频一区在线观看| 精品国产成人系列| 久久久久国产一区二区三区四区 | 国产精品色哟哟| 天堂成人国产精品一区| 天堂久久久久va久久久久| 国内成人自拍视频| 激情小说综合网| 欧美日精品一区视频| 91精品国产色综合久久不卡电影| 欧美久久久久久久久久| 91精品国产一区二区人妖| 国产精品久久久爽爽爽麻豆色哟哟| 国产精品久99| 国产精品自拍在线| 处破女av一区二区| 欧美日本韩国国产| 欧美videos中文字幕| 日本一区二区三区四区在线视频| 国产精品国产三级国产普通话三级 | 免费日本视频一区| 国产精品高清一区二区三区| 国产成人精品日本亚洲11 | 中文字幕一区二区三区5566| 在线观看视频一区| 成人免费高清视频| 少妇精品久久久久久久久久| 久久久亚洲高清| 国产一区视频网站| 日韩少妇中文字幕| 国产欧美一二三区| 亚洲.国产.中文慕字在线| 国产在线一区观看| 欧美人与物videos另类| 久久综合色之久久综合| 一级中文字幕一区二区| 国产一区二区三区久久悠悠色av| 欧美一级二级三级| 91精品国产综合久久精品性色| 3751色影院一区二区三区| 亚洲一区二区av在线| 免费观看在线综合| 欧美日韩免费观看一区| 久久免费电影网| 国产高清不卡二三区| 成人3d动漫一区二区三区91| 91精品欧美久久久久久动漫| 六月丁香婷婷久久| 久久久久久久免费| 国产精品国产精品国产专区不片| 91丨porny丨在线| 一本大道久久a久久综合婷婷| 亚洲精品一线二线三线| 成人高清免费观看| 日韩精品一区二区三区视频播放| 国产精品综合二区| 日韩区在线观看| 成人福利在线看| 久久综合九色综合欧美就去吻| 不卡一区在线观看| 久久午夜免费电影| 97超级碰碰| 国产精品美女久久久久av爽李琼| 91理论电影在线观看| 欧美国产精品劲爆| 精品欧美国产| 伊人婷婷欧美激情| 一区二区三区四区五区视频| 天天亚洲美女在线视频| 日本电影欧美片| 麻豆免费精品视频| 日产精品高清视频免费| 亚洲综合在线第一页| 欧美资源一区| 午夜久久福利影院| 一区二区三区视频| 免费欧美在线视频| 欧美日韩一级视频| 国产视频一区在线观看| 国产精品日韩二区| 久久精品人人做人人爽97| 91超碰rencao97精品| 欧美精品一区二区三区蜜桃 | 亚洲va韩国va欧美va精品| 欧美精品欧美精品系列c| 夜夜亚洲天天久久| 欧美日韩一区在线播放| 亚洲精品v日韩精品| 婷婷成人激情在线网| 亚洲高清视频一区二区| 欧美影院精品一区| 亚洲综合小说图片| 免费日韩av电影| 亚洲色图第一区| 麻豆高清免费国产一区| 在线码字幕一区| 日本aⅴ亚洲精品中文乱码| 在线观看日韩毛片| 三级亚洲高清视频| 欧美一区二区免费观在线| 国产91在线看| 亚洲美女区一区| 亚洲一区二区在线观| 蜜乳av一区二区三区| 欧美日韩国产不卡| 国产精品沙发午睡系列990531| 国产欧美丝袜| 中文文精品字幕一区二区| 国产a一区二区| 亚洲美女淫视频| 午夜精品视频在线观看一区二区| 婷婷亚洲久悠悠色悠在线播放| 在线视频观看一区| 国产91亚洲精品一区二区三区| 日韩一区欧美一区| 亚洲制服中文| 国产精品一二一区| 国产午夜精品理论片a级大结局 | 欧美日本高清视频在线观看| 99久久综合狠狠综合久久| 欧美猛男gaygay网站| 丰满亚洲少妇av| 国产精品美女视频| 在线观看日韩片| 成人性生交大片免费看视频在线| 亚洲精品国产精品乱码不99| 色综合久久88色综合天天6| 黄页视频在线91| 国产喷白浆一区二区三区| 少妇特黄a一区二区三区| 天天色 色综合| 国产精品丝袜91| 欧洲精品一区二区| 2014国产精品| 午夜国产精品一区| 欧美日韩aaaaaa| 自拍偷拍亚洲色图欧美| 成人妖精视频yjsp地址| 亚洲精品视频在线观看免费| 欧美午夜电影网| 国产欧美韩日| 91丨porny丨国产入口| 香蕉久久一区二区不卡无毒影院 | 91麻豆精品国产91久久久使用方法 | 亚洲欧美怡红院| 欧美日韩亚洲丝袜制服| 成人三级在线| 久久99久久精品欧美| 欧美亚洲高清一区| 北条麻妃高清一区| caoporm超碰国产精品| 亚洲午夜三级在线| 精品乱码亚洲一区二区不卡| 日韩高清三级| 99久久免费精品高清特色大片| 日日夜夜免费精品| 国产欧美日韩精品a在线观看| 日本道精品一区二区三区 | 亚洲成人免费视频| 国产精品成人免费在线| 欧美精品在线观看一区二区| 久久久久久久久一区| 成人污视频在线观看| 日本aⅴ免费视频一区二区三区| 亚洲在线免费播放| 国产亚洲精品资源在线26u| 日本高清视频一区二区| 美国av一区二区三区| 波多野结衣中文字幕一区二区三区| 天天综合色天天综合色h| 日韩毛片视频在线看| 久久久美女艺术照精彩视频福利播放|