跳到主要內容


程式語言概念-設計模式

程式語言概念

設計模式

設計模式是用在軟體開發的時候的工具,目的是要增加程式碼的利用率、維護性、可讀性,而這個概念是在類別的基礎上的加強跟應用,是很強大的工具,個人認為在五千行以上的程式,沒有使用,就很難好好掌控該轉體的開發。

設計原則

在設計類別的時候,有幾個大原則
  • 單一職責原則
  • 里氏替換原則
  • 依賴倒置原則
  • 介面隔離原則
單一職責元則
顧名思義就是只做一件事情,從類別、介面、方法、每一行,在設計的時候都要盡量只讓其做一件事情,比如說類別在設計的時候,定義了鳥這種概念,所以這個類別只能做鳥的事情,不能多做其他類別的事情,再來去解析他的方法,每個方法也只能處理一件事情,不能下不同參數就做不一樣的事情,如果這些方法是有辦法歸類的,原則上必須分開,如跟改類別參數的跟該類別的特定動作,在介面上就應該分開設計,後面再一一繼承,雖然原則如次,但在實際上執行的時候,會遇到很多問題使得誤法做到。

里氏替換原則
子類別需要完全實作父類別的方法,子類別可以自定義自己的屬性、方法,而在複寫父類別方法時,輸入參數可以被放大範圍,輸出參數可以被縮小範圍。

依賴倒置原則
高級模組不應該依賴低級模組,而是兩者都依賴抽象模組,抽象內容不應依賴細節,細節應該依賴抽象,需要抽象畫的建議都放在介面上。

介面隔離原則
在設計介面的時候,介面的功能盡可能小,不要讓使用者太清楚知道定義方法相係內容,把使用率高或是佔資源的設備的介面隔離開來,另外不要隔離過頭。

設計模式的分類,大致分成幾類,最常討論的就是Gof的23個模式,並常用的執行緒跟圖形界面開發會用到的MVC。
  • Creational 模式
  • Structural 模式
  • Behavioral 模式
  • 執行緒模式
  • MVC模式

Creational 模式:

此模式就是歸類出常見的用來產生物件的類別的設計方法,主要是針對物件生成,一般類別在使用內部的會分成旨在類別內部使用的資料跟函數以及對外開放的資料跟函數,而在這在這些類別中,所生成的物件可能會有以下這些特性。

  • 同類型的物件生成管理:不同地方的Pizza、不同口味的Pizza
  • 同類型的物件但內容組成差異大:迷宮
  • 整個軟體執行過程只能生成一次:工作管理員
  • 該物件在被生成的時候,都會用同樣的初始狀態被執行
以下是常見種類:
  • 簡單工廠模式、工廠方法模式、抽象工廠模式-連結
  • 建造者模式-連結
  • 原型模式-連結
  • 單例模式-連結
Creational 模式-雜談

Structural 模式


此類型討論物件或類別之間的相互關係,主要是針對生成之後方法的使用去設計關係,如繼承、互叫其他類別函式、實現其他類別物件,使其介面、撰寫方法統一,所生成的物件可能會有以下這些特性。


  • 外部開發函式使用
  • 同樣類別在不同環境下使用
  • 不同類別組合在同意環境中
  • 類別功能擴增
  • 統一對外介面
  • 對於常用類別先行是做物件,讓軟體後續使用
  • 代理原本使用者進行軟體控制
以下常見種類:

structural 模式-雜談

Behavioral 模式

對於軟體內部的運作行為,主要是針對方法,進行模組化的設計,所生成的物件可能會有以下這些特性。


  • 對於多條件確認,確認完成之後執行特定行為
  • 下達指令,對於指令執行特定動作
  • 對於清單中,進行迭代的動作,不透露底層運作
  • 將演算法把包裝起來,讓軟體使用
  • 對軟體特定物件,進行紀錄的行為
  • 對於軟體特定物件,進行特定的初始化過程
  • 提供物件檢測介面
  • 對於各物件溝通過程提供一個中間介面進行構通
  • 對於特定資料轉換成特定行為
  • 對於物件的狀態進行儲存,當需要的時候可以進行回復


以下常見種類:


Behavioral 模式-雜談

執行緒模式

對於軟體使用運算資源進行管理,享元模式的應用。
  • 多執行緒池
  • 異步同步執行

MVC模式

對圖形介面軟體進行有效率的個設計,分成三個部分View、Controller、Model。
  • Model
  • Controller
  • View

Model

Model模式主要是放置自訂的資料類型型態、資料庫連結儲存功能、其他類型檔案的資料獲得、被controller呼叫的介面、互叫controller的介面、資料處理運算過程(商業過程)。
Controller

呼叫model的介面以獲取資料內容、傳輸資料到model進行運算、對於View的動作或命令解析動作。
View

跟使用者互動,根據使用者個動作,轉換成動作或指令傳送到控制器進行運作。

Client_server模式

需要更新內容

 投影片-slideshare:程式語言概念_變數
 影片-youtube:程式語言蓋面_變數
 程式碼-Github:程式語言概念_變數
下一單元:程式語言學習大綱

留言

這個網誌中的熱門文章

Python-資料庫-mongodb-pymongo

Python 資料庫 mongodb-pymongo 安裝: linux、mac:pip3 install pymongo windows: import pymongo client = pymongo.MongoClient("mongodb://localhost:27017/") db = client['demo_db'] col = db['demo_col'] dict1 = { "name": "ab123ab456g", "day": "1890-04-05" } result = col.insert_one(dict1)  dict2 = [   { "name": "ki", "day": "1666-1-1"},   { "name": "aa", "day": "1222-11-11"},   { "name": "gg-gg", "day": "1333-02-22"},   { "name": "T-T", "day": "1444-03-02"},   { "name": "f-f", "day": "1555-01-01"} ] result = col.insert_many(dict2) result = col.find_one() print(result) results = col.find() for result in col.find(): print(result) results = col.find() query = {'

程式語言概念-條件敘述

程式語言概念 條件敘述 上一篇的比較運算就是用來描述條件的,如變數a跟變數b,範例如下。 a>b a=>b a==b a<=b a<b a!=b 上一篇的邏輯運算可以連接不同條件,如:a>b and c>b。 在寫程式的時候,可以使用條件式加上需要的條件敘述,進行流程控制,達到程式結構化的目的,常見的條件式if-else、if-else if- else、switch。 條件式可以進行選擇流程,選擇流程種類如下。 單一選擇 雙向選擇 多向選擇 單一選擇: 用於當某些條件達成之後,就執行,如:下雨了嗎?沒有,沒事,有,帶傘。 流程圖 雙向選擇: 用於當某些條件達成之後,執行A,不然執行B,如:請問數字是奇數嗎?是,奇數,不是,偶數。 流程圖 多向選擇: 用於判斷某變數是否為A、B、C、...、其他,如:請問現在是什麼季節?春天、夏天、秋天、冬天。 流程圖  投影片-slideshare:程式語言概念_變數  影片-youtube:程式語言蓋面_變數  程式碼-Github:程式語言概念_變數 下一單元:程式語言概念_ 迴圈

程式語言概念-資料結構

程式語言資料結構 資料結構 在討論資料結構時,必須先暸解記憶體的運作過程,首先作業系統會將記憶體(RAM)分頁,切割成特定大小的區塊,來給運作的程式使用,在程式啟動後,會先將編譯過後的程式碼載入到記憶中,並運行,而這些程式碼有些只運行一次,有些則運行多次,如程式的初始化指運行一次,如程式操作運行多次。 而在運行程式時,會運行到有變數的段落,此時就會定義一段記憶體給該變數,而其大小會隨其資料型態改變,當有相同資料型態的資料需要儲存時,通常會用陣列,把需要的資料大小告知後,把相同類型的資放在一起,而陣列是一種資料結構,其一旦宣告後,其記憶體大小就不再改變,因此有靜態的特性,所以相對的,在操作資料結構時會改變其記憶體大小的就是動態的,所以動態的資料結構,會有如何建立、如何搜尋、如何更新、如何刪除的問題,這也衍生到資料庫的CRUD(Create、Read、Update、Delete)這概念,因此在討論的時候會把時間複雜度跟空間複雜度做介紹,這樣是比較全面的做法。 而在儲存資料的時候,會有需要自訂義資料的時候,這也會影響到資料的基本大小,而自定義的型態,通常會使用struct跟class來定義,在各種語言通常struct為value type,class為refference type,兩者在意在,struct 在定義完之後可以像一般的資料型態使用,定義的變數的資料內容是存值,所以不會相互干涉,而class則會,所以class 都會使用new的宣告新的物件,不過這些東西的細部定義需要參考該官方網站的內容,此外還有point type。 常見的資料型態 陣列 array 堆疊 stack 佇列 queue 連結串列 linked list 樹 tree 圖 graph 堆 heap 雜湊表 hash 串列 list 字典 dict 其他 陣列 為靜態的,其記憶體大小在初始化之後,便不能在變動。 連結串列 為動態的資料結構的基本型,由struct、指標跟變數組成,用來構成其它的資料結構。 堆疊 與 佇 列為相似的結構,由多個連結串列組成,目的是用來儲存資料,並後存放資料先被使用,想像疊書,疊十層高,然後從上面開始拿。 佇 列 由多個連結串列組成,目的是用來儲存資料,並先存放資料先被使用,排隊的概