chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀(guān)看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

有限狀態(tài)機(jī)轉(zhuǎn)與實(shí)現(xiàn)狀態(tài)機(jī)之間的轉(zhuǎn)換狀態(tài)是什么?

lhl545545 ? 來(lái)源:算法與數(shù)據(jù)結(jié)構(gòu) ? 作者:算法與數(shù)據(jù)結(jié)構(gòu) ? 2020-06-09 14:37 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

if.。.else 是所有高級(jí)編程語(yǔ)言都有的必備功能。但現(xiàn)實(shí)中的代碼往往存在著過(guò)多的 if.。.else。雖然 if.。.else 是必須的,但濫用 if.。.else 會(huì)對(duì)代碼的可讀性、可維護(hù)性造成很大傷害,進(jìn)而危害到整個(gè)軟件系統(tǒng)?,F(xiàn)在軟件開(kāi)發(fā)領(lǐng)域出現(xiàn)了很多新技術(shù)、新概念,但 if.。.else 這種基本的程序形式并沒(méi)有發(fā)生太大變化。使用好 if.。.else 不僅對(duì)于現(xiàn)在,而且對(duì)于將來(lái),都是十分有意義的。今天我們就來(lái)看看如何“干掉”代碼中的 if.。.else,還代碼以清爽。

問(wèn)題一:if…else 過(guò)多

問(wèn)題表現(xiàn)

if.。.else 過(guò)多的代碼可以抽象為下面這段代碼。其中只列出5個(gè)邏輯分支,但實(shí)際工作中,能見(jiàn)到一個(gè)方法包含10個(gè)、20個(gè)甚至更多的邏輯分支的情況。另外,if.。.else 過(guò)多通常會(huì)伴隨著另兩個(gè)問(wèn)題:邏輯表達(dá)式復(fù)雜和 if.。.else 嵌套過(guò)深。對(duì)于后兩個(gè)問(wèn)題,本文將在下面兩節(jié)介紹。本節(jié)先來(lái)討論 if.。.else 過(guò)多的情況。

if (condition1) {

} else if (condition2) {

} else if (condition3) {

} else if (condition4) {

} else {

}

通常,if.。.else 過(guò)多的方法,通常可讀性和可擴(kuò)展性都不好。從軟件設(shè)計(jì)角度講,代碼中存在過(guò)多的 if.。.else 往往意味著這段代碼違反了違反單一職責(zé)原則和開(kāi)閉原則。因?yàn)樵趯?shí)際的項(xiàng)目中,需求往往是不斷變化的,新需求也層出不窮。所以,軟件系統(tǒng)的擴(kuò)展性是非常重要的。而解決 if.。.else 過(guò)多問(wèn)題的最大意義,往往就在于提高代碼的可擴(kuò)展性。

如何解決

接下來(lái)我們來(lái)看如何解決 if.。.else 過(guò)多的問(wèn)題。下面我列出了一些解決方法。

表驅(qū)動(dòng)

職責(zé)鏈模式

注解驅(qū)動(dòng)

事件驅(qū)動(dòng)

有限狀態(tài)機(jī)

Optional

Assert

多態(tài)

方法一:表驅(qū)動(dòng)

介紹

對(duì)于邏輯表達(dá)模式固定的 if.。.else 代碼,可以通過(guò)某種映射關(guān)系,將邏輯表達(dá)式用表格的方式表示;再使用表格查找的方式,找到某個(gè)輸入所對(duì)應(yīng)的處理函數(shù),使用這個(gè)處理函數(shù)進(jìn)行運(yùn)算。

適用場(chǎng)景

邏輯表達(dá)模式固定的 if.。.else

實(shí)現(xiàn)與示例

if (param.equals(value1)) {

doAction1(someParams);

} else if (param.equals(value2)) {

doAction2(someParams);

} else if (param.equals(value3)) {

doAction3(someParams);

}

// 。..

可重構(gòu)為

Map《?, Function《?》 action》 actionMappings = new HashMap《》(); // 這里泛型 ? 是為方便演示,實(shí)際可替換為你需要的類(lèi)型

// When init

actionMappings.put(value1, (someParams) -》 { doAction1(someParams)});

actionMappings.put(value2, (someParams) -》 { doAction2(someParams)});

actionMappings.put(value3, (someParams) -》 { doAction3(someParams)});

// 省略 null 判斷

actionMappings.get(param).apply(someParams);

上面的示例使用了 Java 8 的 Lambda 和 Functional Interface,這里不做講解。

表的映射關(guān)系,可以采用集中的方式,也可以采用分散的方式,即每個(gè)處理類(lèi)自行注冊(cè)。也可以通過(guò)配置文件的方式表達(dá)。總之,形式有很多。

還有一些問(wèn)題,其中的條件表達(dá)式并不像上例中的那樣簡(jiǎn)單,但稍加變換,同樣可以應(yīng)用表驅(qū)動(dòng)。下面借用《編程珠璣》中的一個(gè)稅金計(jì)算的例子:

if income 《= 2200

tax = 0

else if income 《= 2700

tax = 0.14 * (income - 2200)

else if income 《= 3200

tax = 70 + 0.15 * (income - 2700)

else if income 《= 3700

tax = 145 + 0.16 * (income - 3200)

。..。..

else

tax = 53090 + 0.7 * (income - 102200)

對(duì)于上面的代碼,其實(shí)只需將稅金的計(jì)算公式提取出來(lái),將每一檔的標(biāo)準(zhǔn)提取到一個(gè)表格,在加上一個(gè)循環(huán)即可。具體重構(gòu)之后的代碼不給出,大家自己思考。

方法二:職責(zé)鏈模式

介紹

當(dāng) if.。.else 中的條件表達(dá)式靈活多變,無(wú)法將條件中的數(shù)據(jù)抽象為表格并用統(tǒng)一的方式進(jìn)行判斷時(shí),這時(shí)應(yīng)將對(duì)條件的判斷權(quán)交給每個(gè)功能組件。并用鏈的形式將這些組件串聯(lián)起來(lái),形成完整的功能。

適用場(chǎng)景

條件表達(dá)式靈活多變,沒(méi)有統(tǒng)一的形式。

實(shí)現(xiàn)與示例

職責(zé)鏈的模式在開(kāi)源框架的 Filter、Interceptor 功能的實(shí)現(xiàn)中可以見(jiàn)到很多。下面看一下通用的使用模式:

重構(gòu)前:

public void handle(request) {

if (handlerA.canHandle(request)) {

handlerA.handleRequest(request);

} else if (handlerB.canHandle(request)) {

handlerB.handleRequest(request);

} else if (handlerC.canHandle(request)) {

handlerC.handleRequest(request);

}

}

重構(gòu)后:

public void handle(request) {

handlerA.handleRequest(request);

}

public abstract class Handler {

protected Handler next;

public abstract void handleRequest(Request request);

public void setNext(Handler next) { this.next = next; }

}

public class HandlerA extends Handler {

public void handleRequest(Request request) {

if (canHandle(request)) doHandle(request);

else if (next != null) next.handleRequest(request);

}

}

當(dāng)然,示例中的重構(gòu)前的代碼為了表達(dá)清楚,做了一些類(lèi)和方法的抽取重構(gòu)?,F(xiàn)實(shí)中,更多的是平鋪式的代碼實(shí)現(xiàn)。

注:職責(zé)鏈的控制模式

職責(zé)鏈模式在具體實(shí)現(xiàn)過(guò)程中,會(huì)有一些不同的形式。從鏈的調(diào)用控制角度看,可分為外部控制和內(nèi)部控制兩種。

外部控制不靈活,但是減少了實(shí)現(xiàn)難度。職責(zé)鏈上某一環(huán)上的具體實(shí)現(xiàn)不用考慮對(duì)下一環(huán)的調(diào)用,因?yàn)橥獠拷y(tǒng)一控制了。但是一般的外部控制也不能實(shí)現(xiàn)嵌套調(diào)用。如果有嵌套調(diào)用,并且希望由外部控制職責(zé)鏈的調(diào)用,實(shí)現(xiàn)起來(lái)會(huì)稍微復(fù)雜。具體可以參考 Spring Web Interceptor 機(jī)制的實(shí)現(xiàn)方法。

內(nèi)部控制就比較靈活,可以由具體的實(shí)現(xiàn)來(lái)決定是否需要調(diào)用鏈上的下一環(huán)。但如果調(diào)用控制模式是固定的,那這樣的實(shí)現(xiàn)對(duì)于使用者來(lái)說(shuō)是不便的。

設(shè)計(jì)模式在具體使用中會(huì)有很多變種,大家需要靈活掌握

方法三:注解驅(qū)動(dòng)

介紹

通過(guò) Java 注解(或其它語(yǔ)言的類(lèi)似機(jī)制)定義執(zhí)行某個(gè)方法的條件。在程序執(zhí)行時(shí),通過(guò)對(duì)比入?yún)⑴c注解中定義的條件是否匹配,再?zèng)Q定是否調(diào)用此方法。具體實(shí)現(xiàn)時(shí),可以采用表驅(qū)動(dòng)或職責(zé)鏈的方式實(shí)現(xiàn)。

適用場(chǎng)景

適合條件分支很多多,對(duì)程序擴(kuò)展性和易用性均有較高要求的場(chǎng)景。通常是某個(gè)系統(tǒng)中經(jīng)常遇到新需求的核心功能。

實(shí)現(xiàn)與示例

很多框架中都能看到這種模式的使用,比如常見(jiàn)的 Spring MVC。因?yàn)檫@些框架很常用,demo 隨處可見(jiàn),所以這里不再上具體的演示代碼了。

這個(gè)模式的重點(diǎn)在于實(shí)現(xiàn)。現(xiàn)有的框架都是用于實(shí)現(xiàn)某一特定領(lǐng)域的功能,例如 MVC。故業(yè)務(wù)系統(tǒng)如采用此模式需自行實(shí)現(xiàn)相關(guān)核心功能。主要會(huì)涉及反射、職責(zé)鏈等技術(shù)。具體的實(shí)現(xiàn)這里就不做演示了。

方法四:事件驅(qū)動(dòng)

介紹

通過(guò)關(guān)聯(lián)不同的事件類(lèi)型和對(duì)應(yīng)的處理機(jī)制,來(lái)實(shí)現(xiàn)復(fù)雜的邏輯,同時(shí)達(dá)到解耦的目的。

適用場(chǎng)景

從理論角度講,事件驅(qū)動(dòng)可以看做是表驅(qū)動(dòng)的一種,但從實(shí)踐角度講,事件驅(qū)動(dòng)和前面提到的表驅(qū)動(dòng)有多處不同。具體來(lái)說(shuō):

表驅(qū)動(dòng)通常是一對(duì)一的關(guān)系;事件驅(qū)動(dòng)通常是一對(duì)多;

表驅(qū)動(dòng)中,觸發(fā)和執(zhí)行通常是強(qiáng)依賴(lài);事件驅(qū)動(dòng)中,觸發(fā)和執(zhí)行是弱依賴(lài)

正是上述兩者不同,導(dǎo)致了兩者適用場(chǎng)景的不同。具體來(lái)說(shuō),事件驅(qū)動(dòng)可用于如訂單支付完成觸發(fā)庫(kù)存、物流、積分等功能。

實(shí)現(xiàn)與示例

實(shí)現(xiàn)方式上,單機(jī)的實(shí)踐驅(qū)動(dòng)可以使用 Guava、Spring 等框架實(shí)現(xiàn)。分布式的則一般通過(guò)各種消息隊(duì)列方式實(shí)現(xiàn)。但是因?yàn)檫@里主要討論的是消除 if.。.else,所以主要是面向單機(jī)問(wèn)題域。因?yàn)樯婕熬唧w技術(shù),所以此模式代碼不做演示。

方法五:有限狀態(tài)機(jī)

介紹

有限狀態(tài)機(jī)通常被稱(chēng)為狀態(tài)機(jī)(無(wú)限狀態(tài)機(jī)這個(gè)概念可以忽略)。先引用維基百科上的定義:

有限狀態(tài)機(jī)(英語(yǔ):finite-state machine,縮寫(xiě):FSM),簡(jiǎn)稱(chēng)狀態(tài)機(jī),是表示有限個(gè)狀態(tài)以及在這些狀態(tài)之間的轉(zhuǎn)移和動(dòng)作等行為的數(shù)學(xué)模型。

其實(shí),狀態(tài)機(jī)也可以看做是表驅(qū)動(dòng)的一種,其實(shí)就是當(dāng)前狀態(tài)和事件兩者組合與處理函數(shù)的一種對(duì)應(yīng)關(guān)系。當(dāng)然,處理成功之后還會(huì)有一個(gè)狀態(tài)轉(zhuǎn)移處理。

適用場(chǎng)景

雖然現(xiàn)在互聯(lián)網(wǎng)后端服務(wù)都在強(qiáng)調(diào)無(wú)狀態(tài),但這并不意味著不能使用狀態(tài)機(jī)這種設(shè)計(jì)。其實(shí),在很多場(chǎng)景中,如協(xié)議棧、訂單處理等功能中,狀態(tài)機(jī)有這其天然的優(yōu)勢(shì)。因?yàn)檫@些場(chǎng)景中天然存在著狀態(tài)和狀態(tài)的流轉(zhuǎn)。

實(shí)現(xiàn)與示例

實(shí)現(xiàn)狀態(tài)機(jī)設(shè)計(jì)首先需要有相應(yīng)的框架,這個(gè)框架需要實(shí)現(xiàn)至少一種狀態(tài)機(jī)定義功能,以及對(duì)于的調(diào)用路由功能。狀態(tài)機(jī)定義可以使用 DSL 或者注解的方式。原理不復(fù)雜,掌握了注解、反射等功能的同學(xué)應(yīng)該可以很容易實(shí)現(xiàn)。

參考技術(shù):

Apache Mina State Machine

Apache Mina 框架,雖然在 IO 框架領(lǐng)域不及 Netty,但它卻提供了一個(gè)狀態(tài)機(jī)的功能。https://mina.apache.org/mina-project/userguide/ch14-state-machine/ch14-state-machine.html。有自己實(shí)現(xiàn)狀態(tài)機(jī)功能的同學(xué)可以參考其源碼。

Spring State Machine

Spring 子項(xiàng)目眾多,其中有個(gè)不顯山不露水的狀態(tài)機(jī)框架 —— Spring State Machine https://projects.spring.io/spring-statemachine/??梢酝ㄟ^(guò) DSL 和注解兩種方式定義。

上述框架只是起到一個(gè)參考的作用,如果涉及到具體項(xiàng)目,需要根據(jù)業(yè)務(wù)特點(diǎn)自行實(shí)現(xiàn)狀態(tài)機(jī)的核心功能。

方法六:Optional

介紹

Java 代碼中的一部分 if.。.else 是由非空檢查導(dǎo)致的。因此,降低這部分帶來(lái)的 if.。.else 也就能降低整體的 if.。.else 的個(gè)數(shù)。

Java 從 8 開(kāi)始引入了 Optional 類(lèi),用于表示可能為空的對(duì)象。這個(gè)類(lèi)提供了很多方法,用于相關(guān)的操作,可以用于消除 if.。.else。開(kāi)源框架 Guava 和 Scala 語(yǔ)言也提供了類(lèi)似的功能。

使用場(chǎng)景

有較多用于非空判斷的 if.。.else。

實(shí)現(xiàn)與示例

傳統(tǒng)寫(xiě)法:

String str = “Hello World!”;

if (str != null) {

System.out.println(str);

} else {

System.out.println(“Null”);

}

使用 Optional 之后:

1 Optional《String》 strOptional = Optional.of(“Hello World!”);

2 strOptional.ifPresentOrElse(System.out::println, () -》 System.out.println(“Null”));

Optional 還有很多方法,這里不一一介紹了。但請(qǐng)注意,不要使用 get() 和 isPresent() 方法,否則和傳統(tǒng)的 if.。.else 無(wú)異。

擴(kuò)展:Kotlin Null Safety

Kotlin 帶有一個(gè)被稱(chēng)為 Null Safety 的特性:

bob?.department?.head?.name

對(duì)于一個(gè)鏈?zhǔn)秸{(diào)用,在 Kotlin 語(yǔ)言中可以通過(guò) ?。 避免空指針異常。如果某一環(huán)為 null,那整個(gè)鏈?zhǔn)奖磉_(dá)式的值便為 null。

方法七:Assert 模式

介紹

上一個(gè)方法適用于解決非空檢查場(chǎng)景所導(dǎo)致的 if.。.else,類(lèi)似的場(chǎng)景還有各種參數(shù)驗(yàn)證,比如還有字符串不為空等等。很多框架類(lèi)庫(kù),例如 Spring、Apache Commons 都提供了工具里,用于實(shí)現(xiàn)這種通用的功能。這樣大家就不必自行編寫(xiě) if.。.else 了。

Apache Commons Lang 中的 Validate 類(lèi):https://commons.apache.org/proper/commons-lang/javadocs/api-3.1/org/apache/commons/lang3/Validate.html

Spring 的 Assert 類(lèi):https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/util/Assert.html

使用場(chǎng)景

通常用于各種參數(shù)校驗(yàn)

擴(kuò)展:Bean Validation

類(lèi)似上一個(gè)方法,介紹 Assert 模式順便介紹一個(gè)有類(lèi)似作用的技術(shù) —— Bean Validation。Bean Validation 是 Java EE 規(guī)范中的一個(gè)。Bean Validation 通過(guò)在 Java Bean 上用注解的方式定義驗(yàn)證標(biāo)準(zhǔn),然后通過(guò)框架統(tǒng)一進(jìn)行驗(yàn)證。也可以起到了減少 if.。.else 的作用。

方法八:多態(tài)

介紹

使用面向?qū)ο蟮亩鄳B(tài),也可以起到消除 if.。.else 的作用。在代碼重構(gòu)這本書(shū)中,對(duì)此也有介紹:

https://refactoring.com/catalog/replaceConditionalWithPolymorphism.html

使用場(chǎng)景

鏈接中給出的示例比較簡(jiǎn)單,無(wú)法體現(xiàn)適合使用多態(tài)消除 if.。.else 的具體場(chǎng)景。一般來(lái)說(shuō),當(dāng)一個(gè)類(lèi)中的多個(gè)方法都有類(lèi)似于示例中的 if.。.else 判斷,且條件相同,那就可以考慮使用多態(tài)的方式消除 if.。.else。

同時(shí),使用多態(tài)也不是徹底消除 if.。.else。而是將 if.。.else 合并轉(zhuǎn)移到了對(duì)象的創(chuàng)建階段。在創(chuàng)建階段的 if.。,我們可以使用前面介紹的方法處理。

小結(jié)

上面這節(jié)介紹了 if.。.else 過(guò)多所帶來(lái)的問(wèn)題,以及相應(yīng)的解決方法。除了本節(jié)介紹的方法,還有一些其它的方法。比如,在《重構(gòu)與模式》一書(shū)中就介紹了“用 Strategy 替換條件邏輯”、“用 State 替換狀態(tài)改變條件語(yǔ)句”和“用 Command 替換條件調(diào)度程序”這三個(gè)方法。其中的“Command 模式”,其思想同本文的“表驅(qū)動(dòng)”方法大體一致。另兩種方法,因?yàn)樵凇吨貥?gòu)與模式》一書(shū)中已做詳細(xì)講解,這里就不再重復(fù)。

何時(shí)使用何種方法,取決于面對(duì)的問(wèn)題的類(lèi)型。上面介紹的一些適用場(chǎng)景,只是一些建議,更多的需要開(kāi)發(fā)人員自己的思考。

問(wèn)題二:if…else 嵌套過(guò)深

問(wèn)題表現(xiàn)

if.。.else 多通常并不是最嚴(yán)重的的問(wèn)題。有的代碼 if.。.else 不僅個(gè)數(shù)多,而且 if.。.else 之間嵌套的很深,也很復(fù)雜,導(dǎo)致代碼可讀性很差,自然也就難以維護(hù)。

if (condition1) {

action1();

if (condition2) {

action2();

if (condition3) {

action3();

if (condition4) {

action4();

}

}

}

}

if.。.else 嵌套過(guò)深會(huì)嚴(yán)重地影響代碼的可讀性。當(dāng)然,也會(huì)有上一節(jié)提到的兩個(gè)問(wèn)題。

如何解決

上一節(jié)介紹的方法也可用用來(lái)解決本節(jié)的問(wèn)題,所以對(duì)于上面的方法,此節(jié)不做重復(fù)介紹。這一節(jié)重點(diǎn)一些方法,這些方法并不會(huì)降低 if.。.else 的個(gè)數(shù),但是會(huì)提高代碼的可讀性:

抽取方法

衛(wèi)語(yǔ)句

方法一:抽取方法

介紹

抽取方法是代碼重構(gòu)的一種手段。定義很容易理解,就是將一段代碼抽取出來(lái),放入另一個(gè)單獨(dú)定義的方法。借

用 https://refactoring.com/catalog/extractMethod.html 中的定義:

適用場(chǎng)景

if.。.else 嵌套嚴(yán)重的代碼,通常可讀性很差。故在進(jìn)行大型重構(gòu)前,需先進(jìn)行小幅調(diào)整,提高其代碼可讀性。抽取方法便是最常用的一種調(diào)整手段。

實(shí)現(xiàn)與示例

重構(gòu)前:

public void add(Object element) {

if (!readOnly) {

int newSize = size + 1;

if (newSize 》 elements.length) {

Object[] newElements = new Object[elements.length + 10];

for (int i = 0; i 《 size; i++) {

newElements[i] = elements[i];

}

elements = newElements

}

elements[size++] = element;

}

}

重構(gòu)后:

public void add(Object element) {

if (readOnly) {

return;

}

if (overCapacity()) {

grow();

}

addElement(element);

}

方法二:衛(wèi)語(yǔ)句

介紹

在代碼重構(gòu)中,有一個(gè)方法被稱(chēng)為“使用衛(wèi)語(yǔ)句替代嵌套條件語(yǔ)句”https://refactoring.com/catalog/replaceNestedConditionalWithGuardClauses.html。直接看代碼:

double getPayAmount() {

double result;

if (_isDead) result = deadAmount();

else {

if (_isSeparated) result = separatedAmount();

else {

if (_isRetired) result = retiredAmount();

else result = normalPayAmount();

};

}

return result;

}

重構(gòu)之后

double getPayAmount() {

if (_isDead) return deadAmount();

if (_isSeparated) return separatedAmount();

if (_isRetired) return retiredAmount();

return normalPayAmount();

}

使用場(chǎng)景

當(dāng)看到一個(gè)方法中,某一層代碼塊都被一個(gè) if.。.else 完整控制時(shí),通常可以采用衛(wèi)語(yǔ)句。

問(wèn)題三:if…else 表達(dá)式過(guò)于復(fù)雜

問(wèn)題表現(xiàn)

if.。.else 所導(dǎo)致的第三個(gè)問(wèn)題來(lái)自過(guò)于復(fù)雜的條件表達(dá)式。下面給個(gè)簡(jiǎn)單的例子,當(dāng) condition 1、2、3、4 分別為 true、false,請(qǐng)大家排列組合一下下面表達(dá)式的結(jié)果。

1 if ((condition1 && condition2 ) || ((condition2 || condition3) && condition4)) {

2

3 }

我想沒(méi)人愿意干上面的事情。關(guān)鍵是,這一大坨表達(dá)式的含義是什么?關(guān)鍵便在于,當(dāng)不知道表達(dá)式的含義時(shí),沒(méi)人愿意推斷它的結(jié)果。

所以,表達(dá)式復(fù)雜,并不一定是錯(cuò)。但是表達(dá)式難以讓人理解就不好了。

如何解決

對(duì)于 if.。.else 表達(dá)式復(fù)雜的問(wèn)題,主要用代碼重構(gòu)中的抽取方法、移動(dòng)方法等手段解決。因?yàn)檫@些方法在《代碼重構(gòu)》一書(shū)中都有介紹,所以這里不再重復(fù)。

總結(jié)

本文一個(gè)介紹了10種(算上擴(kuò)展有12種)用于消除、簡(jiǎn)化 if.。.else 的方法。還有一些方法,如通過(guò)策略模式、狀態(tài)模式等手段消除 if.。.else 在《重構(gòu)與模式》一書(shū)中也有介紹。

正如前言所說(shuō),if.。.else 是代碼中的重要組成部分,但是過(guò)度、不必要地使用 if.。.else,會(huì)對(duì)代碼的可讀性、可擴(kuò)展性造成負(fù)面影響,進(jìn)而影響到整個(gè)軟件系統(tǒng)。

“干掉”if.。.else 的能力高低反映的是程序員對(duì)軟件重構(gòu)、設(shè)計(jì)模式、面向?qū)ο笤O(shè)計(jì)、架構(gòu)模式、數(shù)據(jù)結(jié)構(gòu)等多方面技術(shù)的綜合運(yùn)用能力,反映的是程序員的內(nèi)功。要合理使用 if.。.else,不能沒(méi)有設(shè)計(jì),也不能過(guò)度設(shè)計(jì)。這些對(duì)技術(shù)的綜合、合理地運(yùn)用都需要程序員在工作中不斷的摸索總結(jié)。
責(zé)任編輯:pj

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀(guān)點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 程序
    +關(guān)注

    關(guān)注

    117

    文章

    3846

    瀏覽量

    85212
  • 高級(jí)編程
    +關(guān)注

    關(guān)注

    0

    文章

    11

    瀏覽量

    8123
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    為什么在FPGA設(shè)計(jì)中使用MicroBlaze V處理器

    在各類(lèi)行業(yè)與應(yīng)用中,經(jīng)常能看到許多 FPGA 設(shè)計(jì)。一個(gè)非常常見(jiàn)的現(xiàn)象是:設(shè)計(jì)者常常用復(fù)雜的有限狀態(tài)機(jī)(FSM)來(lái)實(shí)現(xiàn) I2C、SPI、GPIO 時(shí)序控制等功能。
    的頭像 發(fā)表于 12-19 15:29 ?8297次閱讀
    為什么在FPGA設(shè)計(jì)中使用MicroBlaze V處理器

    RDMA設(shè)計(jì)8:狀態(tài)管理單元設(shè)計(jì)

    狀態(tài)管理單元負(fù)責(zé)讀取系統(tǒng)工作狀態(tài),包括物理鏈路連接狀態(tài)和隊(duì)列連接狀態(tài),并反饋給上位機(jī)。
    的頭像 發(fā)表于 12-16 16:55 ?1341次閱讀
    RDMA設(shè)計(jì)8:<b class='flag-5'>狀態(tài)</b>管理單元設(shè)計(jì)

    條件判斷法來(lái)實(shí)現(xiàn)狀態(tài)機(jī)

    S0 只需要考慮事件 E1 的處理就行了。 既然是兩個(gè) switch—case 之間的嵌套, 那么就有一個(gè)誰(shuí)嵌套誰(shuí)的問(wèn)題, 所以說(shuō) switch—case法有兩種寫(xiě)法:狀態(tài)嵌套事件和事件嵌套狀態(tài)
    發(fā)表于 12-09 08:18

    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(十一):ISDU狀態(tài)機(jī)與EVENT事件

    上篇我們介紹了ISDU的典型編碼格式和應(yīng)用案例,本篇我們就來(lái)詳細(xì)介紹下,ISDU的狀態(tài)機(jī),并把EVENT事件的邏輯,給大家好好解析下。 1主站ISDU狀態(tài)機(jī) 如上圖所示,ISDU的狀態(tài)機(jī)的核心
    的頭像 發(fā)表于 11-29 18:28 ?4711次閱讀
    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(十一):ISDU<b class='flag-5'>狀態(tài)機(jī)</b>與EVENT事件

    什么是狀態(tài)機(jī)

    的switch—case語(yǔ)句里要有400個(gè)case,這樣的程序還有法兒寫(xiě)么?! 同樣的功能改動(dòng),如果用g_stFSM這個(gè)結(jié)構(gòu)體來(lái)實(shí)現(xiàn)狀態(tài)機(jī)的話(huà),函數(shù)fsm_active()只需要
    發(fā)表于 11-27 08:15

    嵌入式開(kāi)發(fā)為何經(jīng)常用到狀態(tài)機(jī)架構(gòu)

    相悖。 狀態(tài)機(jī)就能解決邏輯完備性的問(wèn)題。 狀態(tài)機(jī)是一種以系統(tǒng)狀態(tài)為中心,以事件為變量的設(shè)計(jì)方法,它專(zhuān)注于各個(gè)狀態(tài)的特點(diǎn)以及狀態(tài)
    發(fā)表于 11-25 07:08

    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(八):M-Sequence Type 與消息處理狀態(tài)機(jī)

    丟棄,減少后端工作量。 那么今天我們就來(lái)深入研究下,消息處理模塊中提到的各類(lèi)M-Sequence,以及主從站的消息處理狀態(tài)機(jī)! ? 1 M-Sequence Type 上回講到主站發(fā)出來(lái)的MC和CKT
    的頭像 發(fā)表于 11-07 16:18 ?6281次閱讀
    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(八):M-Sequence Type 與消息處理<b class='flag-5'>狀態(tài)機(jī)</b>

    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(六):主從站狀態(tài)機(jī)解析

    前言 書(shū)接上文,今天我們就來(lái)好好聊聊主從站的DL-Mode狀態(tài)機(jī),還請(qǐng)各位童鞋前排坐好! 1主站狀態(tài)機(jī)解析 主站的DL-Mode狀態(tài)機(jī)有5個(gè)大狀態(tài),也是我們很熟悉的 建立通信、開(kāi)始、預(yù)
    的頭像 發(fā)表于 10-28 17:34 ?6193次閱讀
    睿遠(yuǎn)研究院丨IO-Link規(guī)范解讀(六):主從站<b class='flag-5'>狀態(tài)機(jī)</b>解析

    JTAG標(biāo)準(zhǔn)的狀態(tài)機(jī)實(shí)現(xiàn)

    JTAG作為一項(xiàng)國(guó)際標(biāo)準(zhǔn)測(cè)試協(xié)議(IEEE1149.1兼容),主要用于芯片內(nèi)部測(cè)試和調(diào)試。目前的主流芯片均支持JTAG協(xié)議,如DSP、FPGA、ARM、部分單片機(jī)等。標(biāo)準(zhǔn)的JTAG接口是20Pin,但JTAG實(shí)際使用的只有4根信號(hào)線(xiàn),再配合電源、地。
    的頭像 發(fā)表于 08-21 15:12 ?2697次閱讀
    JTAG標(biāo)準(zhǔn)的<b class='flag-5'>狀態(tài)機(jī)</b><b class='flag-5'>實(shí)現(xiàn)</b>

    請(qǐng)問(wèn)如何在FX10上使用GPIF III狀態(tài)機(jī) *.h 文件?

    LVCMOS 2 位 SlaveFIFO GPIF III 狀態(tài)機(jī)的演示中有一個(gè) cy_gpif_header_lvcmos.h 文件。 我想知道如何使用.h文件,只需放入.h文件放入 FX10 項(xiàng)目? 您有它的用戶(hù)指南文檔嗎?
    發(fā)表于 07-16 08:17

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)之十:NVMe初始化狀態(tài)機(jī)設(shè)計(jì)

    1為NVMe配置初始化狀態(tài)機(jī)狀態(tài)轉(zhuǎn)移圖。各狀態(tài)的說(shuō)明如下: 圖1NVMe初始化狀態(tài)轉(zhuǎn)移圖 IDLE:空閑狀態(tài),復(fù)位后的初始
    發(fā)表于 07-05 22:03

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)之八:PCIe初始化狀態(tài)機(jī)設(shè)計(jì)

    PCIe配置初始化狀態(tài)機(jī)實(shí)現(xiàn)PCIe設(shè)備枚舉和配置空間初始化過(guò)程,在完成鏈路訓(xùn)練后,使用DFS(深度優(yōu)先搜索)算法枚舉PCIe總線(xiàn)上的設(shè)備,完成PCIe總線(xiàn)域的地址分配和設(shè)備的初始化。PCIe配置
    發(fā)表于 07-05 22:00

    有可能在 FX3 GPIF2 中創(chuàng)建兩個(gè)獨(dú)立的狀態(tài)機(jī)嗎?

    我想,如果我想通過(guò) FX3 GPIF2 創(chuàng)建兩個(gè)獨(dú)立的傳輸流接口,我需要在 GPIF2 設(shè)計(jì)器中創(chuàng)建兩個(gè)獨(dú)立的狀態(tài)機(jī),我是否有可能在 GPIF2 設(shè)計(jì)器中創(chuàng)建兩個(gè)獨(dú)立的狀態(tài)機(jī)?
    發(fā)表于 05-20 06:14

    cypress3014視頻格式改變的話(huà),GPIF狀態(tài)機(jī)需不需要重新配置?

    你好,請(qǐng)問(wèn)視頻格式改變的話(huà),GPIF狀態(tài)機(jī)需不需要重新配置
    發(fā)表于 05-14 07:28

    求助,關(guān)于srammaster.cydsn中狀態(tài)機(jī)的問(wèn)題求解

    晚上好。 我目前正在學(xué)習(xí) GPIF II。 查看..EZ-USB FX3 SDK1.3firmwaregpif_examplescyfxsrammastersrammaster.cydsn中的狀態(tài)機(jī),有狀態(tài)START和START1。 這意味著什么?
    發(fā)表于 05-12 06:20