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


曙海教育集團論壇3G手機技術專區(qū)Brew手機開發(fā) → 深入brew開發(fā):C#開發(fā)的兩個原則的深入討論


  共有7892人關注過本帖樹形打印

主題:深入brew開發(fā):C#開發(fā)的兩個原則的深入討論

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個性首頁 | 博客 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發(fā)短信
等級:青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊:2010-11-12 11:08:23
深入brew開發(fā):C#開發(fā)的兩個原則的深入討論  發(fā)帖心情 Post By:2010-12-6 10:23:28

使用屬性避免將數(shù)據(jù)成員直接暴露給外界

  學習研究.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版本甚至可以給讀、寫以區(qū)別訪問權限(C# 2.0支持)

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

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

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

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

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

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

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

  1.該類型主要職責是否用于數(shù)據(jù)存儲?

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

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

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

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

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

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

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

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

 

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

 


支持(0中立(0反對(0單帖管理 | 引用 | 回復 回到頂部

返回版面帖子列表

深入brew開發(fā):C#開發(fā)的兩個原則的深入討論








簽名
久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
福利视频一区二区三区| 麻豆91免费看| 欧美夫妻性生活| 色综合激情久久| 久久久久天天天天| 国产经典一区二区三区| 99久久久精品免费观看国产蜜| 精品在线观看免费| 一区二区三区日韩欧美精品| 国产精品久久二区二区| 国产亚洲人成网站| 久久综合久久综合亚洲| 日韩一级视频免费观看在线| 欧美视频中文字幕| 欧美日韩国产乱码电影| 亚洲精品国产系列| 自拍偷拍亚洲色图欧美| 一区二区三区在线视频111| 在线日韩av永久免费观看| 伊人天天久久大香线蕉av色| 色先锋aa成人| 欧美日韩国产片| 欧美二区在线观看| 精品久久久久一区二区国产| 久久久亚洲欧洲日产国码αv| 久久亚洲欧美国产精品乐播| 中文字幕不卡在线| 亚洲男人的天堂一区二区| 午夜伦理一区二区| 国产在线不卡一区| av资源网一区| 久久久久久欧美精品色一二三四| 日本一区二区三区四区在线观看| 在线成人性视频| 欧美军同video69gay| 欧美一级淫片007| 欧美激情一区二区| 亚洲制服丝袜一区| 黄色成人免费在线| 97aⅴ精品视频一二三区| 国产乱码一区| 在线视频一区观看| 日韩精品一区二区三区在线观看| 国产人妖乱国产精品人妖| 亚洲男女一区二区三区| 裸体健美xxxx欧美裸体表演| 波多野洁衣一区| 玛丽玛丽电影原版免费观看1977 | 日韩一二三四区| 国产精品萝li| 美国十次了思思久久精品导航| 成人一二三区视频| 免费精品视频一区| 欧美二区在线观看| 亚洲你懂的在线视频| 精品一区二区成人精品| 国产精品一区免费观看| 一区二区三区在线视频111| 欧美va亚洲va香蕉在线| 一区在线观看免费| 国产一区二区三区香蕉| 精品国产免费久久久久久尖叫 | 久久成人久久爱| 日本一区视频在线观看| 国产精品人成在线观看免费| 岛国av在线一区| 欧美日韩国产首页| 免费看精品久久片| 一区二区在线不卡| 亚洲午夜影视影院在线观看| 操人视频欧美| 久久久久久**毛片大全| 成人美女在线观看| 日韩欧美成人激情| 国产激情视频一区二区三区欧美| 欧美三级韩国三级日本一级| 日本vs亚洲vs韩国一区三区 | 免费观看日韩电影| 色综合色综合色综合| 亚洲国产aⅴ天堂久久| 欧美日韩一区二区视频在线观看| 国产精品天干天干在线综合| av综合在线播放| 亚洲精品在线观| 成人av网站在线观看免费| 日韩女同互慰一区二区| 丁香啪啪综合成人亚洲小说 | 天天色综合成人网| 欧美视频小说| 亚洲综合偷拍欧美一区色| 免费看污久久久| 一区二区三区在线播| 久久99精品久久久久久青青日本 | 一区二区三区中文字幕在线观看| 久久99久久精品国产| 18涩涩午夜精品.www| 欧美凹凸一区二区三区视频 | 亚洲国产视频直播| 一区二区在线观看网站| 免费人成在线不卡| 欧美美女激情18p| 国产91精品免费| 久久色视频免费观看| 国产乱码一区| 亚洲在线观看免费视频| 一区二区在线不卡| 国产酒店精品激情| 久久久久久久久久看片| 国产精品亚洲综合| 亚洲综合色自拍一区| 欧美在线影院一区二区| 国产a区久久久| 国产蜜臀97一区二区三区| 麻豆亚洲一区| 毛片基地黄久久久久久天堂| 日韩视频永久免费| 精品视频第一区| 免费成人av资源网| 精品成a人在线观看| 精品婷婷色一区二区三区蜜桃| 亚洲成人7777| 日韩免费一区二区| 久久综合一区二区三区| 麻豆一区二区三| 国产日韩精品久久久| 亚洲视频欧美在线| 国产精品一区二区不卡| 国产精品久久久久影院色老大| 亚洲高清视频一区二区| 国产福利一区在线| 1024成人网色www| 欧美日韩免费观看一区二区三区| 99国产欧美另类久久久精品 | 免费观看30秒视频久久| 欧美mv日韩mv| 日本一区网站| 粉嫩aⅴ一区二区三区四区五区| 亚洲欧洲一区二区在线播放| 欧美在线观看一区二区| 91中文字精品一区二区| 日韩国产精品久久久| 久久久久久久久岛国免费| 亚洲高清不卡一区| 99久久国产综合精品女不卡| 亚洲电影第三页| 精品福利二区三区| 综合国产精品久久久| 97se视频在线观看| 麻豆一区二区99久久久久| 国产欧美日韩一区二区三区在线观看 | 国产精品久久二区二区| 欧美性色aⅴ视频一区日韩精品| 成人免费看片网址| 久久电影网电视剧免费观看| 国产精品久久久久久亚洲毛片| 欧美午夜视频网站| 久久久久久九九九九| 成人黄色软件下载| 日韩精品一区第一页| 国产欧美日韩亚州综合| 欧美日韩精品三区| 三区精品视频观看| 豆国产97在线| 国产一区二区看久久| 亚洲综合在线电影| 欧美韩日一区二区三区| 欧美日韩国产经典色站一区二区三区 | 亚洲午夜久久久久久久久电影网 | 五月天综合网| 99国精产品一二二线| 一区二区免费视频| 久久久91精品国产一区二区精品| 在线观看免费成人| 日本福利一区二区三区| 成人动漫视频在线观看完整版| 国产精品一卡二卡在线观看| 日韩国产成人精品| 亚洲国产毛片aaaaa无费看| 国产精品久久久久久久久免费相片 | 不卡的电影网站| 久久se精品一区二区| 五月天激情综合网| 樱花影视一区二区| 亚洲视频资源在线| 中文字幕欧美三区| 精品国产1区2区3区| 欧美va在线播放| 日韩午夜在线播放| 337p亚洲精品色噜噜| 欧美三级视频在线观看| 91国偷自产一区二区三区成为亚洲经典| 九九久久99| 欧美日韩最好看的视频| 精品综合在线| 国语精品中文字幕| 久久久久久国产精品免费免费| 国产欧美亚洲日本| 国产午夜精品在线| 久久国产精品99久久久久久丝袜 | 高清国产一区二区三区|