文檔驅動式代碼設計器——代碼是設計出來的!

来源:http://www.cnblogs.com/jyk/archive/2016/10/22/5986780.html
-Advertisement-
Play Games

代碼是敲出來的嗎?是批量生成出來的嗎? No no no,代碼是設計出來的! 如果說到代碼生成器,大家可能會想到三層、動軟代碼生成器、資料庫表等等。其一般的思路是,先有資料庫然後根據庫里的表自動生成一系列的代碼,包括實體類、持久化、業務層(空函數)、頁面代碼等,還可以生成資料庫文檔。這個確實很好很強 ...


 

  代碼是敲出來的嗎?是批量生成出來的嗎?

 

  No no no,代碼是設計出來的!

 

  如果說到代碼生成器,大家可能會想到三層、動軟代碼生成器、資料庫表等等。其一般的思路是,先有資料庫然後根據庫里的表自動生成一系列的代碼,包括實體類、持久化、業務層(空函數)、頁面代碼等,還可以生成資料庫文檔。這個確實很好很強大,可以免除程式員的機械式的敲代碼的工作。

 

(“主要實現在對應資料庫中表的基類代碼的自動生成,包括生成屬性、添加、修改、刪除、查詢、存在性、Model類構造等基礎代碼片斷,支持不同3種架構代碼生成,使程式員可以節省大量機械錄入的時間和重覆勞動,而將精力集中於核心業務邏輯的開發。”

——摘自動軟官網的介紹  )

 

  但是我們都知道,表的設計是根據客戶的需求、業務邏輯、設計人員的項目經驗設計的,其中最主要的是要受到關係型資料庫自身的特點(所以nosql嘛)。表並不能完整體現業務需求,否則教會客戶使用企業管理器(資料庫的客戶端軟體)就可以了。直接把表交給客戶用,那是不行的,否則程式員就集體失業了。

 

  總結一下,一般代碼生成器的思路是:資料庫表——代碼——文檔。

 

  而我這裡說的思路是完全相反的:文檔——代碼——資料庫——業務邏輯

 

  一般我們做項目的順序是:調研,設計,編碼,測試,上線。其中設計階段要編寫大量的文檔,比如功能說明,各種流程圖,領域設計,資料庫設計,原型圖等等。還要編製任務計劃,團隊分工合作。然後開始編碼。編碼的時候會發現,上一階段的各種文檔只能看,對於要編寫的代碼完全沒有直接作用,必須要程式員進行“翻譯”。把文檔翻譯成代碼——於是乎苦逼的碼農誕生了!

 

  而實際情況是,項目緊任務重時間還短。怎麼辦呢?文檔可以沒有或者後補,但是代碼是不能沒有的,所以往往文檔就被忽略甚至完全被幹掉了——這是文檔和代碼的矛盾點。

 

  怎麼辦呢?犧牲文檔?下麵要介紹一把雙刃劍:可以讓文檔成為代碼的助力!可以把碼農從簡單、機械、重覆中解脫出來,但是同時也意味著不會再有“碼農”這個崗位!

 

  還要從剛進入的這家公司說起。公司主營各種企業管理的項目,採用ABP架構最為底層,然後又進一步封裝。

   簡單的說,用EF的code frist做實體類,然後生成資料庫,再根據業務需求設計Dto,有很多很多的Dto。頁面用angularjs做總控和表單,kendoui做列表。存儲部分至少定義一個介面,webapi部分也要定義一個介面。總之面向介面編程嘛。還有很多很多,逐步瞭解中。

 

  對於新人來說,最大的問題就是——這都哪跟哪呀。有了code frist,也就沒有了資料庫文檔。有一大堆dto,但是這些dto都是啥功能?點開挨個看吧。

 

  看了兩周還是蒙登。如果有一系列的文檔說明該多好?但是大家都知道,任務緊工期短,哪有時間弄文檔?

   好了又繞回來了,如果我們設計的文檔可以自動生成代碼,是不是一切就都迎刃而解了呢?

 

  資料庫角度:先設計資料庫文檔,然後自動生成ef的code first 的實體類,然後用ef的資料庫遷移功能建立表。然後生成預設的介面定義。這個沒啥難度吧。

 

  業務角度:設計功能模塊、頁面,頁面裡面的數據列表、查詢、分頁、刪除、表單等,然後根據這些設計生成對應的Dto,以及相關的介面,還有頁面需要的代碼。這樣代碼和文檔就都有了。

 

  怎麼樣,一份設計實現兩種功能(文檔和代碼)。這時候基本功能就都出來了。然後在生成的代碼基礎上做一些調整和優化,主要是頁面方面。

 

  最後每個項目總會有些特殊的需求,我們就可以集中精力幹掉它們了,

 

  對了,還可以生成測試用例,還有測試人員使用的測試平臺也可以結合起來。

 

  現在您相信了吧:代碼是設計出來的!


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

-Advertisement-
Play Games
更多相關文章
  • 官方說5.5開始就廢棄mysql_query()這塊東西很多,當然常用的就幾個還是看手冊吧。 這裡簡單記錄一下。在我失憶之後可以找回一點記憶。最近一直用框架原生的都快忘了。 1.打開mysql連接 $resource1 = mysql_connect('localhost', 'root', 'ro ...
  • 字元串截斷函數是指:Stuff 和 SubString,字元串查找函數是:CharIndex 和 PatIndex 一,SubString 截取子串 最常用的字元串函數,用於截取特定長度的子串。 參數說明: start 參數:整數,表示開始位置;字元的序號(index)從1開始,即第一個字元的序號是 ...
  • 今天遇到了一個問題,要查詢今天添加到一個表中的數據,後來解決了,嗯,記錄一下: SELECT * FROM 表1 WHERE convert(varchar(10),表1.創建時間,120)=CONVERT(VARCHAR(10),GETDATE(),120) 如果是本月的話: SELECT * F ...
  • Centos6.5之ssh免密碼登錄配置 centos ssh 免密碼登錄 0.說明 這裡為了方便說明問題,假設有A和B兩台安裝了centos6.5的主機。目標是實現A、B兩台主機分別能夠通過ssh免密碼登錄到對方主機。不同主機的配置過程一樣,這裡介紹A主機的配置過程。 事先在AB主機分別創建好要免 ...
  • 一、說明 安裝環境 centos6.6 (64位) python2.7.10 (升級系統預設python版本的方法參見 "在CentOS 6.5上安裝python2.7" ) 約定 工作目錄假定為當前用戶的HOME目錄 安裝的各軟體版本以文檔編寫時的最新版為基準,請結合實際情況參考。 尖括弧""包括 ...
  • 簡介 ABP提供了一個緩存介面,它內部使用了這個緩存介面。雖然介面的預設實現是MemoryCache,但可以用任何其它實現的緩存供應器。Abp.RedisCache包用Redis實現了緩存(查看下方的“Redis 緩存集成”)。 ICacheManager 緩存的主要介面是ICacheManager ...
  • MySqlSugar 3.X API 作為支持.NET CORE 為數不多的ORM之一,除了具有優越的性能外,還擁有強大的功能,不只是滿足你的增,刪,查和改。實質上擁有更多你想像不到的功能,當你需要實現某個功能時會發現有這個功能太棒了。 所有版本 ASP.NET 4.0+ MSSQL https:/ ...
  • 作為物聯網通訊框架,肯定要支持多種通訊鏈路,在多種通訊鏈路的基礎上完成多種通訊協議的交互,例如:Modbus、自定義協議等等。但是,有一個問題:針對同一臺硬體設備或感測器,完成串口和網路兩種通訊方式的數據採集和控制,是否要分別寫代碼?如果從現實角度分析,同一硬體,它要完成的業務邏輯肯定是相同的,所以... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...