《NET 設計規範》第 2 章 框架設計基礎

来源:http://www.cnblogs.com/liqingwen/archive/2017/07/10/7147887.html
-Advertisement-
Play Games

《NET 設計規範》第 2 章 框架設計基礎 要設計功能強大又易於使用的框架。 要理解廣大開發人員並有針對性地為他們設計框架。 要理解各種編程語言,併為他們設計框架。 要確保在設計任何包含公用API的特性時,把 API 設計規格書作為它最核心的部分。 要為每個主要的特性域定義一些最常見的使用場景。 ...


《NET 設計規範》第 2 章 框架設計基礎

  要設計功能強大又易於使用的框架。

  要理解廣大開發人員並有針對性地為他們設計框架。

  要理解各種編程語言,併為他們設計框架。  

  要確保在設計任何包含公用API的特性時,把 API 設計規格書作為它最核心的部分。

  要為每個主要的特性域定義一些最常見的使用場景。

  要確保使用場景與適當的抽象層次相對應。場景應該大致與最終用戶的用例相對應。

  要在設計 API 時,先為主要的使用場景編寫樣例代碼,然後在定義對象模型來支持這些樣例代碼。

  要用至少兩種不同風格的編程語言來為主要場景編寫樣例代碼。

  考慮用動態類型語言來為主要場景編寫樣例代碼。

  不要在設計框架的公用 API 時完全依賴於標準的設計方法。

  要安排可用性測試研究來測試用於主要場景的 API。

  要確保每個主要特性域的命名空間只包含那些用於最常見場景的類型。應該把用於更高級場景的類型放在子命名空間中。

  要為構造函數和方法提供簡單的重載函數。一個簡單的重載函數不僅參數的數量非常少,而且所有的參數都是基本類型。

  不要把用於高級場景的成員放在為主要使用場景而設計的類型中。

  不要要求用於在最基本的場景中顯示地實例化一個以上的類型。

  不要要求用戶在為基本使用場景編寫代碼之前就進行大量的初始化。

  要儘可能地(用便利的重載函數)為所有的屬性和參數提供合適的預設值。

  要通過異常來傳達對 API 的誤用。

  要確保 API 是直觀的,無需查閱參考文檔就能用於基本場景。

  要為所有的 API 提供優秀的文檔。

  要在審查規格書的時候投入大量的時間和精力,來討論標識符名稱的選擇。

  不要擔心標識符的名字太冗長。

  考慮在設計過程的早期讓用於教育專家參與。考慮把最好的名字留給常用類型。

  要通過異常消息來告訴開發人員對框架的誤用。

  要儘可能地提供強類型的 API。

  要確保與 .NET 框架以及客戶可能會使用的其它框架保持一致。

  避免在主要場景的 API 中使用太多的抽象。

  考慮對框架進行分層,使高層API能夠提供最佳的開發效率,低層API能提供最強大的功能和最豐富的表現力。

  避免把非常複雜(即包含許多類型)的低層API和高層API混在同一個命名空間中。

  要確保單個特性域中不同的層能很好地集成在一起。開發人員應該能在開始時使用其中一層來進行開發,然後通過修改代碼就可以使用另一層,而且這樣的改動應該無需重寫整個應用程式。

 

 

 


【原文】http://www.cnblogs.com/liqingwen/p/7147887.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 換了四種黑蘋果,最終成功了 步驟: 1、升級vs2017, 2、安裝XCODE 8.3 3、安裝vs2017 for mac 企業版 4、啟動vs2017 for mac ,設置xcode 位置 5、打開遠程登錄與屏幕共用 6、打開WINDOWS中的VS2017,在 選項中設置XCODE位置,使用I... ...
  • 詮釋: 1. 破解VIP登陸限制 2.去後門 (自查) 下載地址 :https://pan.baidu.com/s/1eR2rUOM 查毒地址:http://a.virscan.org/a3983f36d31d08a51486501965d04cb5 Xise_V20.0.exe 更新日誌 生成內頁 ...
  • 一、進程、線程及多線程的概念 什麼是多線程呢?不理解。 那什麼是線程呢?說到線程就不得不說說進程。我在網上搜索也搜索了一些資料,大部分所說的進程其實是很抽象的東西。通俗的來講,進程就是一個應用程式開始運行,那麼這個應用程式就會存在一個屬於這個應用程式的進程。 那麼線程就是進程中的基本執行單元,每個進 ...
  • AWT概述 GUI全稱是Graphical User Interface,即圖形用戶界面,即應用程式提供給用戶操作的圖形界面,包括視窗、菜單、按鈕、工具欄和其它各種圖形界面元素 GUI設計提供了豐富的類庫,這些類分別位於java.awt和javax.swing包中,簡稱為AWT和Swing Swin ...
  • 不得不承認《Python游戲編程入門》這本書翻譯、排版非常之爛,但是裡面的demo還是很好的,之前做了些改編放到這裡。 先是素材: 背景 精靈 所有素材均取自此書 接下來就是精靈類的創建了: 將精靈類“放置”到游戲屏幕上,並加上背景 這樣的話精靈就在畫布上了,我們得讓它能左右移動: 然後實現跳躍及二 ...
  • 前面的話 選項卡Tabs是Web中一種非常常用的功能。用戶點擊對菜單項,能切換出對應的內容。本文將詳細介紹Bootstrap選項卡 基本用法 Bootstrap框架中的選項卡主要有兩部分內容組成: 1、選項卡菜單組件,對應的是 Bootstrap的 nav-tabs 2、可以切換的選項卡面板組件,在 ...
  • 關鍵詞:AngularJS指令與表達式、AngularJS中的MVC中的作用域、AngularJS過濾器、AngularJS中的 http && select && DOM操作、AngularJS中的表單驗證、AngularJS中的動畫、AngularJS中的路由 ...
  • 最近在做信開發時,發現<input type="file" />在IOS中可以拍照或從照片圖庫選擇,而Android系統則顯示資源管理器,無拍照選項,網上查找資料,改為<input type="file" capture="camera">後,Android可顯示相機和文檔,但IOS則只有拍照選項了 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...