注冊(cè) | 登錄讀書好,好讀書,讀好書!
讀書網(wǎng)-DuShu.com
當(dāng)前位置: 首頁(yè)出版圖書科學(xué)技術(shù)計(jì)算機(jī)/網(wǎng)絡(luò)軟件與程序設(shè)計(jì)C/C++及其相關(guān)編寫高質(zhì)量代碼:改善C#程序的157個(gè)建議

編寫高質(zhì)量代碼:改善C#程序的157個(gè)建議

編寫高質(zhì)量代碼:改善C#程序的157個(gè)建議

定 價(jià):¥59.00

作 者: 陸敏技 著
出版社: 機(jī)械工業(yè)出版社
叢編項(xiàng):
標(biāo) 簽: VC++

ISBN: 9787111356493 出版時(shí)間: 2011-10-01 包裝: 平裝
開本: ` 頁(yè)數(shù): 247 字?jǐn)?shù):  

內(nèi)容簡(jiǎn)介

  《編寫高質(zhì)量代碼:改善C#程序的157個(gè)建議》是C#程序員進(jìn)階修煉的必讀之作,包含的全部都是C#編碼的最佳實(shí)踐,從語(yǔ)言本身、程序的設(shè)計(jì)和架構(gòu)、編碼規(guī)范和編程習(xí)慣等三大方面對(duì)C#程序員遇到的經(jīng)典問(wèn)題給出了經(jīng)驗(yàn)性的解決方案,為C#程序員如何編寫更高質(zhì)量的C#代碼提供了157條極為寶貴的建議。對(duì)于每一個(gè)問(wèn)題,不僅以建議的方式給出了被實(shí)踐證明為十分優(yōu)秀的解決方案,而且還給出了經(jīng)常被誤用或被錯(cuò)誤理解的不好的解決方案,從正反兩個(gè)方面進(jìn)行了分析和對(duì)比。全書一共三個(gè)部分,第一部分專注于C#語(yǔ)言本身,一共89條建議,涵蓋了C#語(yǔ)言基本要素、集合、LINQ、泛型、委托、事件、資源管理、序列化、異常處理、異步、多線程、任務(wù)和并行編程等與C#語(yǔ)法相關(guān)的核心內(nèi)容;第二部分重點(diǎn)講解了C#程序的設(shè)計(jì)和架構(gòu),一共32條建議,涉及成員設(shè)計(jì)、面向?qū)ο蟮念愋驮O(shè)計(jì)、安全性設(shè)計(jì)等重要方面的內(nèi)容;第三部分探討了C#的編碼規(guī)范及編程習(xí)慣,一共36條建議,包含C#命名規(guī)范、如何使代碼更整潔以及如何規(guī)范開發(fā)行為等方面的內(nèi)容?!毒帉懜哔|(zhì)量代碼:改善C#程序的157個(gè)建議》是一本關(guān)于如何編寫高質(zhì)量C#代碼的工具書,列舉的問(wèn)題非常典型,給出的建議也非常實(shí)用,其中的每一條建議都有可能在我們編寫下一行代碼的時(shí)候被用到。你可以將此書擱置在案頭,以便有需要的時(shí)候隨時(shí)查閱。

作者簡(jiǎn)介

  陸敏技,資深軟件工程師、項(xiàng)目經(jīng)理和架構(gòu)師,從事軟件開發(fā)工作近10年。尤其精通微軟技術(shù),對(duì)C#、WPF、WCF、ASP.NET和.NET技術(shù)有十分深入的研究,曾參與和主導(dǎo)了大量的相關(guān)項(xiàng)目的架構(gòu)和開發(fā)工作,積累了豐富的經(jīng)驗(yàn)。此外,他還非常擅長(zhǎng)于分布式開發(fā)技術(shù),而且有豐富的培訓(xùn)和授課經(jīng)驗(yàn)。活躍于博客園等技術(shù)社區(qū),樂(lè)于分享,有較高的知名度和社區(qū)影響力。

圖書目錄

前言
第一部分 語(yǔ)言篇
第1章 基本語(yǔ)言要素 / 2
建議1:正確操作字符串 / 2
建議2:使用默認(rèn)轉(zhuǎn)型方法 / 6
建議3:區(qū)別對(duì)待強(qiáng)制轉(zhuǎn)型與as和is / 9
建議4:TryParse比Parse好 / 12
建議5:使用int?來(lái)確保值類型也可以為null / 15
建議6:區(qū)別readonly和const的使用方法 / 16
建議7:將0值作為枚舉的默認(rèn)值 / 19
建議8:避免給枚舉類型的元素提供顯式的值 / 20
建議9:習(xí)慣重載運(yùn)算符 / 22
建議10:創(chuàng)建對(duì)象時(shí)需要考慮是否實(shí)現(xiàn)比較器 / 23
建議11:區(qū)別對(duì)待==和Equals / 27
建議12:重寫Equals時(shí)也要重寫GetHashCode / 29
建議13:為類型輸出格式化字符串 / 32
建議14:正確實(shí)現(xiàn)淺拷貝和深拷貝 / 36
建議15:使用dynamic來(lái)簡(jiǎn)化反射實(shí)現(xiàn) / 40
第2章 集合和LINQ / 43
建議16:元素?cái)?shù)量可變的情況下不應(yīng)使用數(shù)組 / 43
建議17:多數(shù)情況下使用foreach進(jìn)行循環(huán)遍歷 / 45
建議18:foreach不能代替for / 51
建議19:使用更有效的對(duì)象和集合初始化 / 53
建議20:使用泛型集合代替非泛型集合 / 54
建議21:選擇正確的集合 / 57
建議22:確保集合的線程安全 / 61
建議23:避免將List<T>作為自定義集合類的基類 / 64
建議24:迭代器應(yīng)該是只讀的 / 67
建議25:謹(jǐn)慎集合屬性的可寫操作 / 68
建議26:使用匿名類型存儲(chǔ)LINQ查詢結(jié)果 / 70
建議27:在查詢中使用Lambda表達(dá)式 / 73
建議28:理解延遲求值和主動(dòng)求值之間的區(qū)別 / 75
建議29:區(qū)別LINQ查詢中的IEnumerable<T>和IQueryable<T> / 78
建議30:使用LINQ取代集合中的比較器和迭代器 / 80
建議31:在LINQ查詢中避免不必要的迭代 / 83
第3章 泛型、委托和事件 / 86
建議32:總是優(yōu)先考慮泛型 / 86
建議33:避免在泛型類型中聲明靜態(tài)成員 / 88
建議34:為泛型參數(shù)設(shè)定約束 / 90
建議35:使用default為泛型類型變量指定初始值 / 92
建議36:使用FCL中的委托聲明 / 94
建議37:使用Lambda表達(dá)式代替方法和匿名方法 / 96
建議38:小心閉包中的陷阱 / 99
建議39:了解委托的實(shí)質(zhì) / 103
建議40:使用event關(guān)鍵字為委托施加保護(hù) / 106
建議41:實(shí)現(xiàn)標(biāo)準(zhǔn)的事件模型 / 108
建議42:使用泛型參數(shù)兼容泛型接口的不可變性 / 109
建議43:讓接口中的泛型參數(shù)支持協(xié)變 / 111
建議44:理解委托中的協(xié)變 / 112
建議45:為泛型類型參數(shù)指定逆變 / 114
第4章 資源管理和序列化 / 116
建議46:顯式釋放資源需繼承接口IDisposable / 116
建議47:即使提供了顯式釋放方法,也應(yīng)該在終結(jié)器中提供隱式清理 / 119
建議48:Dispose方法應(yīng)允許被多次調(diào)用 / 120
建議49:在Dispose模式中應(yīng)提取一個(gè)受保護(hù)的虛方法 / 121
建議50:在Dispose模式中應(yīng)區(qū)別對(duì)待托管資源和非托管資源 / 123
建議51:具有可釋放字段的類型或擁有本機(jī)資源的類型應(yīng)該是可釋放的 / 124
建議52:及時(shí)釋放資源 / 125
建議53:必要時(shí)應(yīng)將不再使用的對(duì)象引用賦值為null / 127
建議54:為無(wú)用字段標(biāo)注不可序列化 / 131
建議55:利用定制特性減少可序列化的字段 / 136
建議56:使用繼承ISerializable接口更靈活地控制序列化過(guò)程 / 137
建議57:實(shí)現(xiàn)ISerializable的子類型應(yīng)負(fù)責(zé)父類的序列化 / 140
第5章 異常與自定義異常 / 144
建議58:用拋出異常代替返回錯(cuò)誤代碼 / 144
建議59:不要在不恰當(dāng)?shù)膱?chǎng)合下引發(fā)異常 / 147
建議60:重新引發(fā)異常時(shí)使用Inner Exception  / 150
建議61:避免在finally內(nèi)撰寫無(wú)效代碼 / 151
建議62:避免嵌套異常 / 157
建議63:避免“吃掉”異常 / 160
建議64:為循環(huán)增加Tester-Doer模式而不是將try-catch置于循環(huán)內(nèi) / 161
建議65:總是處理未捕獲的異常 / 162
建議66:正確捕獲多線程中的異常 / 166
建議67:慎用自定義異常 / 168
建議68:從System.Exception或其他常見的基本異常中派生異常 / 170
建議69:應(yīng)使用finally避免資源泄漏 / 172
建議70:避免在調(diào)用棧較低的位置記錄異常 / 175
第6章 異步、多線程、任務(wù)和并行 / 177
建議71:區(qū)分異步和多線程應(yīng)用場(chǎng)景 / 177
建議72:在線程同步中使用信號(hào)量 / 180
建議73:避免鎖定不恰當(dāng)?shù)耐綄?duì)象 / 184
建議74:警惕線程的IsBackground / 188
建議75:警惕線程不會(huì)立即啟動(dòng) / 189
建議76:警惕線程的優(yōu)先級(jí) / 191
建議77:正確停止線程 / 193
建議78:應(yīng)避免線程數(shù)量過(guò)多 / 194
建議79:使用ThreadPool或BackgroundWorker代替Thread / 196
建議80:用Task代替ThreadPool / 198
建議81:使用Parallel簡(jiǎn)化同步狀態(tài)下Task的使用 / 202
建議82:Parallel簡(jiǎn)化但不等同于Task默認(rèn)行為 / 204
建議83:小心Parallel中的陷阱 / 205
建議84:使用PLINQ / 208
建議85:Task中的異常處理 / 209
建議86:Parallel中的異常處理 / 214
建議87:區(qū)分WPF和WinForm的線程模型 / 216
建議88:并行并不總是速度更快 / 220
建議89:在并行方法體中謹(jǐn)慎使用鎖 / 222
第二部分 架構(gòu)篇
第7章 成員設(shè)計(jì) / 226
建議90:不要為抽象類提供公開的構(gòu)造方法 / 226
建議91:可見字段應(yīng)該重構(gòu)為屬性 / 226
建議92:謹(jǐn)慎將數(shù)組或集合作為屬性 / 227
建議93:構(gòu)造方法應(yīng)初始化主要屬性和字段 / 228
建議94:區(qū)別對(duì)待override和new / 229
建議95:避免在構(gòu)造方法中調(diào)用虛成員 / 235
建議96:成員應(yīng)優(yōu)先考慮公開基類型或接口 / 236
建議97:優(yōu)先考慮將基類型或接口作為參數(shù)傳遞 / 237
建議98:用params減少重復(fù)參數(shù) / 237
建議99:重寫時(shí)不應(yīng)使用子類參數(shù) / 238
建議100:靜態(tài)方法和實(shí)例方法沒(méi)有區(qū)別 / 239
建議101:使用擴(kuò)展方法,向現(xiàn)有類型“添加”方法 / 240
第8章 類型設(shè)計(jì) / 243
建議102:區(qū)分接口和抽象類的應(yīng)用場(chǎng)合 / 243
建議103:區(qū)分組合和繼承的應(yīng)用場(chǎng)合 / 245
建議104:用多態(tài)代替條件語(yǔ)句 / 248
建議105:使用私有構(gòu)造函數(shù)強(qiáng)化單例 / 251
建議106:為靜態(tài)類添加靜態(tài)構(gòu)造函數(shù) / 253
建議107:區(qū)分靜態(tài)類和單例 / 255
建議108:將類型標(biāo)識(shí)為sealed / 255
建議109:謹(jǐn)慎使用嵌套類 / 256
建議110:用類來(lái)代替enum / 257
建議111:避免雙向耦合 / 260
建議112:將現(xiàn)實(shí)世界中的對(duì)象抽象為類,將可復(fù)用對(duì)象圈起來(lái)就是命名空間 / 262
第9章 安全性設(shè)計(jì) / 264
建議113:聲明變量前考慮最大值 / 264
建議114:MD5不再安全 / 265
建議115:通過(guò)HASH來(lái)驗(yàn)證文件是否被篡改 / 268
建議116:避免用非對(duì)稱算法加密文件 / 269
建議117:使用SSL確保通信中的數(shù)據(jù)安全 / 273
建議118:使用SecureString保存密鑰等機(jī)密字符串 / 284
建議119:不要使用自己的加密算法 / 289
建議120:為程序集指定強(qiáng)名稱 / 289
建議121:為應(yīng)用程序設(shè)定運(yùn)行權(quán)限 / 291
第三部分 編碼規(guī)范及習(xí)慣
第10章 命名規(guī)范 / 296
建議122:以<Company>.<Component>為命名空間命名 / 296
建議123:程序集不必與命名空間同名 / 296
建議124:考慮在命名空間中使用復(fù)數(shù) / 297
建議125:避免用FCL的類型名稱命名自己的類型 /  / 297
建議126:用名詞和名詞組給類型命名 / 298
建議127:用形容詞組給接口命名 / 299
建議128:考慮讓派生類的名字以基類名字作為后綴 / 300
建議129:泛型類型參數(shù)要以T作為前綴 / 300
建議130:以復(fù)數(shù)命名枚舉類型,以單數(shù)命名枚舉元素 / 301
建議131:用PascalCasing命名公開元素 / 302
建議132:考慮用類名作為屬性名 / 302
建議133:用camelCasing命名私有字段和局部變量  / 303
建議134:有條件地使用前綴  / 304
建議135: 考慮使用肯定性的短語(yǔ)命名布爾屬性 / 305
建議136:優(yōu)先使用后綴表示已有類型的新版本 / 306
建議137:委托和事件類型應(yīng)添加上級(jí)后綴 / 307
建議138:事件和委托變量使用動(dòng)詞或形容詞短語(yǔ)命名 / 308
建議139:事件處理器命名采用組合方式 / 309
第11章 代碼整潔 / 311
建議140:使用默認(rèn)的訪問(wèn)修飾符 / 311
建議141:不知道該不該用大括號(hào)時(shí),就用 / 312
建議142:總是提供有意義的命名 / 314
建議143:方法抽象級(jí)別應(yīng)在同一層次 / 315
建議144:一個(gè)方法只做一件事 / 316
建議145:避免過(guò)長(zhǎng)的方法和過(guò)長(zhǎng)的類 / 317
建議146:只對(duì)外公布必要的操作 / 318
建議147:重構(gòu)多個(gè)相關(guān)屬性為一個(gè)類 / 319
建議148:不重復(fù)代碼 / 320
建議149:使用表驅(qū)動(dòng)法避免過(guò)長(zhǎng)的if和switch分支 / 321
建議150:使用匿名方法、Lambda表達(dá)式代替方法 / 324
建議151:使用事件訪問(wèn)器替換公開的事件成員變量  / 325
建議152:最少,甚至是不要注釋 / 326
建議153:若拋出異常,則必須要注釋 / 326
第12章 規(guī)范開發(fā)行為 / 327
建議154:不要過(guò)度設(shè)計(jì),在敏捷中體會(huì)重構(gòu)的樂(lè)趣 / 327
建議155:隨生產(chǎn)代碼一起提交單元測(cè)試代碼 / 336
建議156:利用特性為應(yīng)用程序提供多個(gè)版本 / 342
建議157:從寫第一個(gè)界面開始,就進(jìn)行自動(dòng)化測(cè)試  / 344

本目錄推薦

掃描二維碼
Copyright ? 讀書網(wǎng) ranfinancial.com 2005-2020, All Rights Reserved.
鄂ICP備15019699號(hào) 鄂公網(wǎng)安備 42010302001612號(hào)