www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 技術(shù)學(xué)院 > 技術(shù)前線
[導(dǎo)讀]工廠方法模式是一種創(chuàng)建型模式,是簡單工廠模式的一個升級版本,主要解決簡單工廠模式不符合開閉原則的問題。本文會先說一下簡單工廠模式,以及存在的問題,然后再引出工廠模式。

1. 介紹

工廠方法模式是一種創(chuàng)建型模式,是簡單工廠模式的一個升級版本,主要解決簡單工廠模式不符合開閉原則的問題。本文會先說一下簡單工廠模式,以及存在的問題,然后再引出工廠模式。

工廠設(shè)計模式是一種創(chuàng)建對象的設(shè)計模式,它的主要目的是通過定義一個接口來創(chuàng)建對象,使得子類決定實例化哪個類。這篇文章,我們將分析工廠模式是什么,它包含什么類型以及如何工作。

從整體上看,工廠模式可以分為三種主要類型:簡單工廠模式、工廠方法模式和抽象工廠模式。

1.1 簡單工廠模式

簡單工廠模式定義一個創(chuàng)建對象的類(工廠類)來負(fù)責(zé)創(chuàng)建其他對象(產(chǎn)品對象)的實例,這個類(工廠類)中的創(chuàng)建功能根據(jù)參數(shù)不同,創(chuàng)建不同的對象(產(chǎn)品對象)實例。這就存在一個問題,每增加一個產(chǎn)品類,就要修改工廠的創(chuàng)建邏輯,增加一個相應(yīng)的產(chǎn)品對象創(chuàng)建,這違反了程序設(shè)計的開閉原則。

概述

簡單工廠模式并不是一個正式的設(shè)計模式,而是一個創(chuàng)建對象的簡單方法。在簡單工廠模式中,通常會有一個工廠類,它根據(jù)參數(shù)的不同返回不同類型的對象。這個模式的優(yōu)點是簡單明了,但缺點是違背了開閉原則。

角色

工廠類:負(fù)責(zé)創(chuàng)建產(chǎn)品的實例,提供一個靜態(tài)方法供外部調(diào)用。

產(chǎn)品類:所有產(chǎn)品類都需實現(xiàn)相同的接口,用于定義產(chǎn)品的公共行為。

客戶端:通過工廠類來獲取產(chǎn)品實例,并使用這些實例。

設(shè)計模式之簡單工廠模式(C#語言描述)

嚴(yán)格意義上來說,簡單工廠模式并不屬于GoF的23種設(shè)計模式,但是它是學(xué)習(xí)其他工廠模式的基礎(chǔ)和前提條件。理解了簡單工廠模式,學(xué)習(xí)工廠方法模式和抽象工廠模式會比較容易一些。

簡單工廠模式的定義

定義一個工廠類,他可以根據(jù)不同的參數(shù)返回不同類的實例。通常情況下,被創(chuàng)建的類的實例通常都具有共同的父類。

簡單工廠模式又可以稱之為靜態(tài)工廠方法模式,因為創(chuàng)建對象實例的方法通常都是靜態(tài)方法。

在簡單工廠模式中,只需要記住一點。一個簡單的參數(shù)可以即可獲得所需的對象實例。

簡單工廠模式的UML圖如下:

簡單工廠模式包含三個角色:

1、工廠角色(Factory):該類是簡單工廠的核心,我們所需要的對象實例就是這個類幫我們創(chuàng)建的,它里面有一個靜態(tài)方法GetProduct(string productType),我們通過傳入產(chǎn)品類型(productType)來得到我們想要的產(chǎn)品。

2、抽象產(chǎn)品角色(AbstractProduct):該類是所有產(chǎn)品的父類。它可以是接口或者抽象類。只有這樣我們才能給工廠的GetProduct(string productType)方法定義返回值。

3、實體產(chǎn)品(ConcreteProductA,ConcreteProductB,ConcreteProductC):這些類是簡單工廠最終要創(chuàng)建的目標(biāo),也是客戶端最終想要的對象實例。

現(xiàn)在來假設(shè)一種場景,我們開發(fā)過程中,肯定會用到按鈕,圓形按鈕、正方形按鈕、矩形按鈕等等,在程序的很多地方我們都可能會復(fù)用這些按鈕。我們可以通過一個簡單工廠來幫助我們創(chuàng)建這些按鈕。

簡單工廠模式的類圖

SimpleFactory是個工廠類,負(fù)責(zé)創(chuàng)建對象(具體的工廠)。Product是要創(chuàng)建產(chǎn)品的抽象類,負(fù)責(zé)定義統(tǒng)一的接口。ProductA和ProductB是具體的產(chǎn)品類型,是Product的實現(xiàn)。我們看一下簡單工廠模式的優(yōu)缺點。

簡單工廠模式優(yōu)點:

實現(xiàn)簡單、結(jié)構(gòu)清晰。抽象出一個專門的工廠類來負(fù)責(zé)某類工廠對象的創(chuàng)建。使用者可以不關(guān)注具體工廠對象的類名,只要傳入相應(yīng)的參數(shù)就能創(chuàng)建對應(yīng)的工廠對象。簡單工廠模式的缺點:

不易擴展,一旦新增產(chǎn)品類型,就得修改工廠的創(chuàng)建邏輯,不符合開閉原則。當(dāng)產(chǎn)品類型較多的時候,工廠創(chuàng)建邏輯會過于復(fù)雜,不利于維護。簡單工廠模式的應(yīng)用場景:

產(chǎn)品具有明顯的繼承關(guān)系,并且產(chǎn)品的類型不多或有限。所有的產(chǎn)品具體有相同的方法和類似的屬性,使用者不關(guān)心具體的類型,只希望傳入合適的參數(shù),然后返回合適的工廠對象。1.2 工廠方法模式

為了解決簡單工廠存在的,新增產(chǎn)品類型,就修改工廠的創(chuàng)建邏輯的問題。提出了工廠方法模式。工廠方法模式定義了一個創(chuàng)建對象(產(chǎn)品對象)的接口,讓子類(工廠類)來決定創(chuàng)建哪個類(產(chǎn)品類)的實例。它是一個類(工廠類)的實例化,延遲到其子類。

Product是要創(chuàng)建產(chǎn)品的抽象類,ProductA和ProductB是具體的產(chǎn)品類型。Factory是所有工廠的抽象類,負(fù)責(zé)定義統(tǒng)一的接口。ProductAFactory和ProductBFactory是具體的工廠類,分別負(fù)責(zé)產(chǎn)品ProductA和ProductB的創(chuàng)建。工廠方法類利用依賴倒置原則,高層模塊不依賴于底層的模塊,它們應(yīng)該依賴于抽象,面向接口編程,從而解決了簡單工廠模式違反軟件設(shè)計的開閉原則的問題。工廠方法模式也有一些優(yōu)缺點,接下來我們看一下。

工廠方法模式的優(yōu)點:

解決了簡單工廠模式違反開閉原則的問題,使程序擴展性增強。工廠方法模式的缺點:

對于由多種分類(存在不同的分類方式組合)的產(chǎn)品,或者具有二級分類的產(chǎn)品,工廠方法模式不適用。工廠方法模式的應(yīng)用場景:

客戶端不知道它所需要的對象的類。工廠類希望通過其子類來決定創(chuàng)建哪個具體類的對象。2, 舉例

一般主程序只關(guān)注業(yè)務(wù)邏輯(抽象類接口),不關(guān)心具體的業(yè)務(wù)細(xì)節(jié)(抽象類接口的具體實現(xiàn))。這些業(yè)務(wù)細(xì)節(jié)就可以放在創(chuàng)建對象的邏輯(工廠創(chuàng)建邏輯)中,主程序只要設(shè)置指定的參數(shù),就能通過創(chuàng)建對象的邏輯獲取相應(yīng)對象(工廠對象)。

接下來會分別舉例說明簡單工廠模式、工廠方法模式的C語言實現(xiàn)。

2.1 簡單工廠模式舉例

#include

#include

enum {

PRODUCTA = 1,

PRODUCTB,

PRODUCTC,

};

// define product interface

typedef struct Product {

void (*show)(struct Product*);

} Product;

// define specific productA class

typedef struct ProductA {

Product product;

} ProductA;

// define productA show function

void ProductA_show(Product* product) {

printf("This is ProductA\n");

}

// define specific productB class

typedef struct ProductB {

Product product;

} ProductB;

// define productB show function

void ProductB_show(Product* product) {

printf("This is ProductB\n");

}

// define factory class

typedef struct Factory {

Product* (*create_product)(int);

} Factory;

// define factory create product logic

Product* factory_create_product(int type) {

Product* product = NULL;

switch (type) {

case 1:

product = (Product*)malloc(sizeof(ProductA));

product->show = ProductA_show;

break;

case 2:

product = (Product*)malloc(sizeof(ProductB));

product->show = ProductB_show;

break;

default:

printf("Invalid product type\n");

break;

}

return product;

}

int main() {

// implement factory instance

Factory simple_factory = { factory_create_product };

// use factory instance to create specific productA

Product* productA = simple_factory.create_product(PRODUCTA);

productA->show(productA);

free(productA);

// use factory instance to create specific productB

Product* productB = simple_factory.create_product(PRODUCTB);

productB->show(productB);

free(productB);

// use factory instance to create specific productC

Product* productC = simple_factory.create_product(PRODUCTC);

if (productC != NULL) {

free(productC);

}

return 0;

}

在這個例子中,定義了一個產(chǎn)品接口(Product)和兩個具體產(chǎn)品類(ProductA 和 ProductB),這兩個具體的產(chǎn)品類都實現(xiàn)了產(chǎn)品接口。此外,還定義了一個工廠類(Factory),它有一個 create_product 方法,通過該方法可以根據(jù)傳入的參數(shù)創(chuàng)建不同類型的產(chǎn)品對象。

在 main 函數(shù)中,使用工廠類實例化了一個工廠對象,然后用這個工廠對象創(chuàng)建了具體產(chǎn)品對象ProductA 和ProductB,并調(diào)用它們的 show 方法打印出相應(yīng)的信息。當(dāng)傳入一個無效的參數(shù)時,工廠類會打印出錯誤信息。

2.2 工廠方法模式舉例

#include

#include

// define product interface

typedef struct Product {

void (*show)(struct Product*);

} Product;

// define specific productA class

typedef struct ProductA {

Product product;

} ProductA;

// define productA show function

void ProductA_show(Product* product) {

printf("This is ProductA\n");

}

// define specific productB class

typedef struct ProductB {

Product product;

} ProductB;

// define productB show function

void ProductB_show(Product* product) {

printf("This is ProductB\n");

}

// define factory interface

typedef struct Factory {

Product* (*create_product)(struct Factory*);

} Factory;

// define specific factoryA class

typedef struct FactoryA {

Factory factory;

} FactoryA;

// inplement factoryA create_product function

Product* factoryA_create_product(Factory* factory) {

Product* product = (Product*)malloc(sizeof(Product));

product->show = ProductA_show;

return product;

}

// define specific factoryB class

typedef struct FactoryB {

Factory factory;

} FactoryB;

// inplement factoryB create_product function

Product* factoryB_create_product(Factory* factory) {

Product* product = (Product*)malloc(sizeof(Product));

product->show = ProductB_show;

return product;

}

int main() {

// create specific factoryA instance

FactoryA FactoryA;

FactoryA.factory.create_product = factoryA_create_product;

// create specific factoryB instance

FactoryB FactoryB;

FactoryB.factory.create_product = factoryB_create_product;

// use specific factory instance create specific product

Product* productA = FactoryA.factory.create_product(&FactoryA.factory);

productA->show(productA);

free(productA);

// use specific factory instance create specific product

Product* productB = FactoryB.factory.create_product(&FactoryB.factory);

productB->show(productB);

free(productB);

return 0;

}

在這個例子中,定義了一個產(chǎn)品接口(Product)和兩個具體產(chǎn)品類(ProductA 和 ProductB),這兩個具體的產(chǎn)品類都實現(xiàn)了產(chǎn)品接口。另外,還定義了一個工廠接口(Factory)和兩個具體工廠類(FactoryA 和 FactoryB),它們都實現(xiàn)了工廠接口。每個具體工廠類都有一個創(chuàng)建產(chǎn)品的方法,通過該方法可以創(chuàng)建相應(yīng)的產(chǎn)品對象。

在 main 函數(shù)中,首先創(chuàng)建了具體工廠對象FactoryA 和 FactoryB,然后通過它們的create_product方法分別創(chuàng)建了具體產(chǎn)品對象ProductA 和ProductB。最后,使用 free 函數(shù)釋放了創(chuàng)建的產(chǎn)品對象。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

鏈表作為一種基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu),在程序設(shè)計中扮演著重要角色。掌握鏈表的高效操作技巧,特別是逆序、合并和循環(huán)檢測,對于提升算法性能和解決復(fù)雜問題至關(guān)重要。本文將詳細(xì)介紹這些操作的C語言實現(xiàn),并分析其時間復(fù)雜度。

關(guān)鍵字: 鏈表 C語言

在C/C++多文件編程中,靜態(tài)變量(static)與全局變量的作用域規(guī)則看似簡單,實則暗藏諸多陷阱。開發(fā)者若未能準(zhǔn)確理解其鏈接屬性與生命周期,極易引發(fā)難以調(diào)試的內(nèi)存錯誤、競態(tài)條件以及維護災(zāi)難。本文將深入剖析這兩類變量的作...

關(guān)鍵字: 靜態(tài)變量 全局變量 C語言

在嵌入式系統(tǒng)和服務(wù)器開發(fā)中,日志系統(tǒng)是故障排查和運行監(jiān)控的核心組件。本文基于Linux環(huán)境實現(xiàn)一個輕量級C語言日志庫,支持DEBUG/INFO/WARN/ERROR四級日志分級,并實現(xiàn)按大小滾動的文件輪轉(zhuǎn)機制。該設(shè)計在某...

關(guān)鍵字: C語言 嵌入式系統(tǒng)

在嵌入式系統(tǒng)和底層驅(qū)動開發(fā)中,C語言因其高效性和可控性成為主流選擇,但缺乏原生單元測試支持成為開發(fā)痛點。本文提出一種基于宏定義和測試用例管理的輕量級單元測試框架方案,通過自定義斷言宏和測試注冊機制,實現(xiàn)無需外部依賴的嵌入...

關(guān)鍵字: C語言 嵌入式系統(tǒng) 驅(qū)動開發(fā)

在嵌入式系統(tǒng)開發(fā)中,實時操作系統(tǒng)(RTOS)的任務(wù)調(diào)度算法直接影響系統(tǒng)的響應(yīng)速度和資源利用率。時間片輪轉(zhuǎn)(Round-Robin, RR)作為一種經(jīng)典的公平調(diào)度算法,通過為每個任務(wù)分配固定時間片實現(xiàn)多任務(wù)并發(fā)執(zhí)行。本文將...

關(guān)鍵字: 實時操作系統(tǒng) RTOS C語言

在Linux設(shè)備驅(qū)動開發(fā)中,等待隊列(Wait Queue)是實現(xiàn)進程睡眠與喚醒的核心機制,它允許進程在資源不可用時主動放棄CPU,進入可中斷睡眠狀態(tài),待資源就緒后再被喚醒。本文通過C語言模型解析等待隊列的實現(xiàn)原理,結(jié)合...

關(guān)鍵字: 驅(qū)動開發(fā) C語言 Linux

在嵌入式系統(tǒng)開發(fā)中,C語言與匯編的混合編程是優(yōu)化性能、訪問特殊指令或硬件寄存器的關(guān)鍵技術(shù)。然而,內(nèi)聯(lián)匯編的語法差異和寄存器使用規(guī)則常導(dǎo)致難以調(diào)試的問題。本文以ARM Cortex-M和x86架構(gòu)為例,系統(tǒng)梳理內(nèi)聯(lián)匯編的核...

關(guān)鍵字: C語言 匯編混合編程

在計算機安全領(lǐng)域,緩沖區(qū)溢出攻擊長期占據(jù)漏洞利用榜首。這種攻擊通過向程序緩沖區(qū)寫入超出其容量的數(shù)據(jù),覆蓋相鄰內(nèi)存區(qū)域(如返回地址),進而實現(xiàn)任意代碼執(zhí)行。本文將深入探討棧保護機制與安全函數(shù)(如snprintf)的集成防御...

關(guān)鍵字: 棧保護 安全函數(shù) C語言

在嵌入式系統(tǒng)和大規(guī)模數(shù)值計算等性能敏感場景中,程序優(yōu)化是提升效率的關(guān)鍵環(huán)節(jié)。gprof作為GNU工具鏈中的性能分析工具,能夠精準(zhǔn)定位CPU時間消耗熱點。本文通過實際案例演示gprof的三個核心使用步驟,幫助開發(fā)者快速識別...

關(guān)鍵字: C語言 gprof 熱點函數(shù)

哈希表作為高效數(shù)據(jù)檢索的核心結(jié)構(gòu),其性能高度依賴沖突解決策略。本文通過C語言實現(xiàn)對比鏈地址法與開放尋址法,揭示兩種方法在內(nèi)存占用、查詢效率及實現(xiàn)復(fù)雜度上的差異,為工程實踐提供量化參考。

關(guān)鍵字: 哈希表 鏈地址法 開放尋址法 C語言
關(guān)閉