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


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


  共有7908人關(guān)注過本帖樹形打印

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

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


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

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

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

   Card
{
 public  Name;
}

  而非要做個(gè)private字段+public屬性?

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

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

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

  這就是這個(gè)Item試圖要?dú)w納使用屬性理由:

  1.可以對賦值做校驗(yàn)、或者額外處理

  2.可以做線程同步

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

  4.可以將屬性置于erface中

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

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

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

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

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

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

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

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

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

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

  3.是否確信該類型永遠(yuǎn)不可能有子類?

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

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

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

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

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

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

 

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

 


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

返回版面帖子列表

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








簽名
久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
国产激情一区二区三区四区 | 欧美日韩一区在线播放| 成人黄色av网站在线| 国产精品中文字幕一区二区三区| 日韩av中文字幕一区二区| 爽好多水快深点欧美视频| 丝袜美腿成人在线| 乱一区二区av| 国产成人亚洲综合a∨婷婷| 国产成人综合在线| 99精品视频一区二区| 国产精品一区视频| 欧美日韩亚洲一区二区三区在线观看| 色吧亚洲视频| 欧美亚洲一区二区三区四区| 欧美精品视频www在线观看| 欧美v亚洲v综合ⅴ国产v| 国产亚洲精品7777| 一区二区三区国产| 蜜桃精品视频在线| 欧美一区二区三区视频在线 | 国产精品自在在线| 91在线观看高清| 精品一区二区三区自拍图片区| 日本一区二区在线| 欧美性受极品xxxx喷水| 2024国产精品视频| 一区二区欧美国产| 激情综合色播激情啊| av爱爱亚洲一区| 日本亚洲自拍| 777xxx欧美| 国产精品国产自产拍高清av| 亚洲va国产天堂va久久en| 极品瑜伽女神91| 91久久爱成人| 中文视频一区视频二区视频三区| 久久精品国产美女| 亚洲综合欧美日韩| www精品美女久久久tv| 亚洲一区二区三区激情| 国产成人三级在线观看| 麻豆传媒一区二区| 717成人午夜免费福利电影| 亚洲欧洲av色图| 中文成人av在线| 日韩精品五月天| 成人国产电影网| 日韩av电影在线观看| 日韩精品一区二区三区蜜臀| 一级做a爱片久久| 国产白丝精品91爽爽久久| 欧美一进一出视频| 欧美一区二区大片| 亚洲国产成人av网| av在线不卡观看免费观看| 亚洲精品tv久久久久久久久| 欧美大白屁股肥臀xxxxxx| 亚洲国产美女搞黄色| av中文字幕一区| 欧美亚日韩国产aⅴ精品中极品| 国产精品久久三| 成人少妇影院yyyy| 91久久精品午夜一区二区| 国产精品国产a| 国产成人综合在线观看| 中文字幕日韩一区二区三区不卡| 欧美韩国一区二区| 国产成人自拍在线| 在线精品亚洲一区二区不卡| 中文字幕一区日韩精品欧美| 国产成人av一区| 色偷偷成人一区二区三区91| 亚洲免费色视频| 91免费小视频| 日韩欧美国产电影| 久久成人18免费观看| 四虎影视永久免费在线观看一区二区三区| 久久久久国产免费免费 | 成人激情午夜影院| 色天使色偷偷av一区二区| 成人免费在线播放视频| 91免费观看在线| 欧美一区二区免费| 精品一区二区三区免费| 一区二区三区三区在线| 亚洲精选一二三| 欧美精品亚洲精品| 日本一区二区不卡视频| 99久久亚洲一区二区三区青草| 制服丝袜激情欧洲亚洲| 日本一不卡视频| 偷拍视频一区二区| 一区二区三区视频在线看| 精品国产一区二区三区免费| 欧美高清在线精品一区| 91玉足脚交白嫩脚丫在线播放| 欧美日韩国产天堂| 蓝色福利精品导航| 欧美综合一区二区三区| 蜜臀99久久精品久久久久久软件 | 欧美日韩成人一区二区三区| 国产精品久久久久9999吃药| 91原创国产| 国产欧美日韩综合| 91pron在线| 中文字幕不卡在线观看| 国产传媒一区二区| 国产精品免费免费| 久久av免费一区| 成人免费在线观看入口| 麻豆蜜桃91| 亚洲aaa精品| 在线日韩国产精品| 国产麻豆一精品一av一免费| 91精品国产色综合久久ai换脸| 国产精品一二三在| 精品国产乱码久久久久久免费| 99久久精品免费精品国产| 久久久亚洲精华液精华液精华液| 91精品久久香蕉国产线看观看| 国产精品沙发午睡系列990531| 久久99国产精品99久久| 夜夜精品视频一区二区| 一本久久a久久精品vr综合| 日韩国产精品久久久久久亚洲| 欧美色倩网站大全免费| 丰满放荡岳乱妇91ww| 国产精品入口麻豆原神| 欧洲精品在线一区| 久久成人免费网站| 久久天堂av综合合色蜜桃网| 蜜桃狠狠色伊人亚洲综合网站| 午夜久久福利影院| 欧美一区二区精品| 国产女人水真多18毛片18精品| 亚洲午夜电影网| 91精品一区二区三区在线观看| 91小视频免费观看| 亚洲免费观看高清完整版在线观看熊 | 一区二区免费视频| 欧美色网一区二区| 97人摸人人澡人人人超一碰| 亚洲精品成a人| 欧美日韩高清一区二区| caoporen国产精品| 丝袜亚洲另类丝袜在线| 日韩一级二级三级精品视频| 久热这里只精品99re8久| 六月婷婷色综合| 国产欧美日韩另类视频免费观看| 亚洲va韩国va欧美va精四季| 国产福利精品导航| 一区二区三区在线视频免费| 91精品国产综合久久精品性色| 精品视频高清无人区区二区三区| 免费成人在线影院| 国产午夜精品在线观看| 在线一区二区三区做爰视频网站| 91丨九色丨蝌蚪丨老版| 青青草97国产精品免费观看无弹窗版| 久久久久久**毛片大全| 在线国产亚洲欧美| 国产精品乱子乱xxxx| 国产永久精品大片wwwapp| 亚洲欧美激情视频在线观看一区二区三区 | 国产精品免费久久久久| 欧美午夜电影在线播放| 国产精品二区在线观看| 国产真实精品久久二三区| 亚洲人成7777| 日韩女同互慰一区二区| 色婷婷综合五月| 久久66热这里只有精品| 波多野结衣在线aⅴ中文字幕不卡| 日韩激情中文字幕| 国产精品美女一区二区三区 | 91麻豆精品国产综合久久久久久| 激情视频在线观看一区二区三区| 国产传媒一区在线| 日韩电影网1区2区| 国产精品高清亚洲| 欧美成人video| 欧美性色欧美a在线播放| 奇米视频888战线精品播放| 999久久久| 国产精品一品视频| 日韩黄色免费网站| 亚洲嫩草精品久久| 久久精品水蜜桃av综合天堂| 欧美日韩视频在线一区二区| 日韩欧美亚洲v片| 久久综合久久久| 粉嫩av四季av绯色av第一区| 粉嫩绯色av一区二区在线观看| 日本一区中文字幕| 亚洲国产aⅴ天堂久久| 亚洲天堂av老司机| 国产精品卡一卡二卡三| 国产日韩av一区二区|