<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          為什么 MyBatis 源碼中,沒有我那種 if···else

          共 5571字,需瀏覽 12分鐘

           ·

          2023-10-27 12:25

          關(guān)注我們,設(shè)為星標(biāo),每天7:40不見不散,架構(gòu)路上與您共享

          回復(fù)架構(gòu)師獲取資源


          大家好,我是你們的朋友架構(gòu)君,一個(gè)會(huì)寫代碼吟詩的架構(gòu)師。

          在MyBatis的兩萬多行的框架源碼中,使用了大量的設(shè)計(jì)模式對(duì)工程架構(gòu)中的復(fù)雜場(chǎng)景進(jìn)行解耦,這些設(shè)計(jì)模式的巧妙使用是整個(gè)框架的精華。

          經(jīng)過整理,大概有以下設(shè)計(jì)模式,如圖1所示。


          01

          類型:創(chuàng)建型模式

          工廠模式

          SqlSessionFactory 的結(jié)構(gòu)如圖2所示。

          工廠模式:簡(jiǎn)單工廠是一種創(chuàng)建型模式,在父類中提供一個(gè)創(chuàng)建對(duì)象的方法,允許子類決定實(shí)例對(duì)象的類型。

          場(chǎng)景介紹:SqlSessionFactory 是獲取會(huì)話的工廠,每次使用MyBatis 操作數(shù)據(jù)庫時(shí), 都會(huì)開啟一個(gè)新的會(huì)話。在會(huì)話工廠的實(shí)現(xiàn)中,SqlSessionFactory 負(fù)責(zé)獲取數(shù)據(jù)源環(huán)境配置信息、構(gòu)建事務(wù)工廠和創(chuàng)建操作SQL 的執(zhí)行器,最終返回會(huì)話實(shí)現(xiàn)類。

          同類設(shè)計(jì):SqlSessionFactory、ObjectFactory、MapperProxyFactory 和DataSourceFactory。

          單例模式

          Configuration 單例配置類的結(jié)構(gòu)如圖3所示。

          單例模式:是一種創(chuàng)建型模式,能夠保證一個(gè)類只有一個(gè)實(shí)例,并且提供一個(gè)訪問該實(shí)例的全局節(jié)點(diǎn)。

          場(chǎng)景介紹:Configuration 是一個(gè)大單例,貫穿整個(gè)會(huì)話周期,所有的配置對(duì)象(如映射、緩存、入?yún)ⅰ⒊鰠ⅰr截器、注冊(cè)機(jī)和對(duì)象工廠等)都在Configuration 配置項(xiàng)中初始化, 并且隨著SqlSessionFactoryBuilder 構(gòu)建階段完成實(shí)例化操作。

          同類場(chǎng)景:ErrorContext、LogFactory 和Configuration。

          建造者模式

          ResultMap 建造者模式的結(jié)構(gòu)如圖4所示。

          建造者模式:使用多個(gè)簡(jiǎn)單的對(duì)象一步一步地構(gòu)建成一個(gè)復(fù)雜的對(duì)象,提供了一種創(chuàng)建對(duì)象的最佳方式。

          場(chǎng)景介紹:建造者模式在MyBatis 中使用了大量的XxxxBuilder,將XML 文件解析到各類對(duì)象的封裝中,使用建造者及建造者助手完成對(duì)象的封裝。它的核心目的是不希望把過多的關(guān)于對(duì)象的屬性設(shè)置寫到其他業(yè)務(wù)流程中,而是用建造者方式提供最佳的邊界隔離。

          同類場(chǎng)景:SqlSessionFactoryBuilder、XMLConfigBuilder、XMLMapperBuilder、XML StatementBuilder 和CacheBuilder。


          02

          類型:結(jié)構(gòu)型模式

          適配器模式

          日志實(shí)現(xiàn)類的結(jié)構(gòu)如圖5所示。

          適配器模式:是一種結(jié)構(gòu)型模式,能使接口不兼容的對(duì)象也可以相互合作。

          場(chǎng)景介紹:正是因?yàn)橛刑嗟娜罩究蚣埽↙og4j、Log4j2 和Slf4J 等,而這些日志框架的使用接口又各有差異,為了統(tǒng)一這些日志框架的接口,MyBatis 定義了一套統(tǒng)一的接口,為所有的其他日志框架的接口做相應(yīng)的適配。

          同類場(chǎng)景:主要集中在對(duì)Log 日志的適配上。

          代理模式

          代理模式的實(shí)現(xiàn)結(jié)構(gòu)如圖6所示。

          代理模式:是一種結(jié)構(gòu)型模式,能夠提供對(duì)象的替代品或占位符。代理控制元對(duì)象的訪問,并且允許在將請(qǐng)求提交給對(duì)象前進(jìn)行一些處理。

          場(chǎng)景介紹:沒有代理模式就不存在各類框架。就像MyBatis 中的MapperProxy 實(shí)現(xiàn)類, 代理工廠實(shí)現(xiàn)的功能就是完成DAO 接口的具體實(shí)現(xiàn)類的方法,配置的任何一個(gè)DAO 接口調(diào)用的CRUD 方法,都會(huì)被MapperProxy 接管,調(diào)用到方法執(zhí)行器等,并返回最終的數(shù)據(jù)庫執(zhí)行結(jié)果。

          同類場(chǎng)景:DriverProxy、Plugin、Invoker 和MapperProxy。

          組合模式

          解析節(jié)點(diǎn)類的結(jié)構(gòu)如圖7所示。

          組合模式:是一種結(jié)構(gòu)型模式,可以將對(duì)象組合成樹形結(jié)構(gòu)以表示“部分—整體” 的層次結(jié)構(gòu)。

          場(chǎng)景介紹:在MyBatis XML 動(dòng)態(tài)的SQL 配置中,共提供了9 種標(biāo)簽(trim、where、set、foreach、if、choose、when、otherwise 和bind),使用者可以組合出各類場(chǎng)景的SQL 語句。而SqlNode 接口的實(shí)現(xiàn)就是每個(gè)組合結(jié)構(gòu)中的規(guī)則節(jié)點(diǎn),通過規(guī)則節(jié)點(diǎn)的組裝,完成規(guī)則樹組合模式的使用。

          同類場(chǎng)景:主要體現(xiàn)在對(duì)各類SQL 標(biāo)簽的解析上,以實(shí)現(xiàn)SqlNode 接口的各個(gè)子類為主。

          裝飾器模式

          二級(jí)緩存裝飾器的實(shí)現(xiàn)結(jié)構(gòu)如圖8所示。

          裝飾器模式:是一種結(jié)構(gòu)型設(shè)計(jì)模式,允許將對(duì)象放入包含行為的特殊封裝對(duì)象中, 為元對(duì)象綁定新的行為。

          場(chǎng)景介紹:MyBatis 的所有SQL 操作都是經(jīng)過SqlSession 調(diào)用SimpleExecutor 完成的, 而一級(jí)緩存的操作也是在簡(jiǎn)單執(zhí)行器中處理的。這里的二級(jí)緩存因?yàn)槭腔谝患?jí)緩存刷新的,所以在實(shí)現(xiàn)上,通過創(chuàng)建一個(gè)緩存執(zhí)行器,包裝簡(jiǎn)單執(zhí)行器的處理邏輯,實(shí)現(xiàn)二級(jí)緩存操作。這里用到的就是裝飾器模式,也叫俄羅斯套娃模式。


          03

          類型:行為型模式

          模板模式

          SQL 執(zhí)行模板模式如圖9所示。

          模板模式:是一種行為型模式,在超類中定義了一個(gè)算法的框架,允許子類在不修改結(jié)構(gòu)的情況下重寫算法的特定步驟。場(chǎng)景介紹:存在一系列可被標(biāo)準(zhǔn)定義的流程,并且流程的步驟大部分采用通用邏輯,只有一小部分是需要子類實(shí)現(xiàn)的,通常采用模板模式來定義這個(gè)標(biāo)準(zhǔn)的流程。就像MyBatis 的BaseExecutor 就是一個(gè)用于定義模板模式的抽象類,在這個(gè)類中把查詢、修改的操作都定義為一套標(biāo)準(zhǔn)的流程。

          同類場(chǎng)景:BaseExecutor、SimpleExecutor 和BaseTypeHandler。

          策略模式

          多類型處理器策略模式的結(jié)構(gòu)如圖10所示。

          微信搜索公眾號(hào):架構(gòu)師指南,回復(fù):架構(gòu)師 領(lǐng)取資料 。

          策略模式:是一種行為型模式,能定義一系列算法,并將每種算法分別放入獨(dú)立的類中,從而使算法的對(duì)象能夠互相替換。

          場(chǎng)景介紹:在MyBatis 處理JDBC 執(zhí)行后返回的結(jié)果時(shí),需要按照不同的類型獲取對(duì)應(yīng)的值,這樣就可以避免大量的if 判斷。所以,這里基于TypeHandler 接口對(duì)每個(gè)參數(shù)類型分別做了自己的策略實(shí)現(xiàn)。

          同類場(chǎng)景:PooledDataSource、UnpooledDataSource、BatchExecutor、ResuseExecutor、SimpleExector、CachingExecutor、LongTypeHandler、StringTypeHandler 和DateTypeHandler。

          迭代器模式

          拆解字段解析實(shí)現(xiàn)的結(jié)構(gòu)如圖11所示。

          迭代器模式:是一種行為型模式,能在不暴露集合底層表現(xiàn)形式的情況下遍歷集合中的所有元素。

          場(chǎng)景介紹:PropertyTokenizer 用于MyBatis 的MetaObject 反射工具包下,用來解析對(duì)象關(guān)系的迭代操作。這個(gè)類在MyBatis 中使用得非常頻繁,包括解析數(shù)據(jù)源配置信息并填充到數(shù)據(jù)源類上,同時(shí)參數(shù)的解析、對(duì)象的設(shè)置都會(huì)使用這個(gè)類。

          同類場(chǎng)景:PropertyTokenizer。

          04

          總結(jié)

          通過梳理,MyBatis大約運(yùn)用了10種左右設(shè)計(jì)模式。可以說,復(fù)雜且優(yōu)秀的ORM 框架源碼在設(shè)計(jì)和實(shí)現(xiàn)的過程中都會(huì)使用大量的設(shè)計(jì)模式。

          在解決復(fù)雜場(chǎng)景的問題時(shí),需要采用分治、抽象的方法,運(yùn)用設(shè)計(jì)模式和設(shè)計(jì)原則等相關(guān)知識(shí),把問題合理切割為若干子問題,以便加以理解和解決。

          學(xué)習(xí)源碼遠(yuǎn)不是只是為了應(yīng)付面試,更重要的是學(xué)習(xí)優(yōu)秀框架在復(fù)雜場(chǎng)景下的解決方案。通過學(xué)習(xí)這些優(yōu)秀的方案技術(shù),可以提高對(duì)技術(shù)設(shè)計(jì)和實(shí)現(xiàn)的理解,擴(kuò)展編碼思維,積累落地經(jīng)驗(yàn)。只有經(jīng)過這樣長(zhǎng)期的積累,我們才更有可能成為優(yōu)秀的高級(jí)工程師和架構(gòu)師。

          到此文章就結(jié)束了。Java架構(gòu)師必看一個(gè)集公眾號(hào)、小程序、網(wǎng)站(3合1的文章平臺(tái),給您架構(gòu)路上一臂之力)。如果今天的文章對(duì)你在進(jìn)階架構(gòu)師的路上有新的啟發(fā)和進(jìn)步,歡迎轉(zhuǎn)發(fā)給更多人。歡迎加入架構(gòu)師社區(qū)技術(shù)交流群,眾多大咖帶你進(jìn)階架構(gòu)師,在后臺(tái)回復(fù)“加群”即可入群。



          這些年小編給你分享過的干貨


          1.idea永久激活碼(親測(cè)可用)

          2.優(yōu)質(zhì)ERP系統(tǒng)帶進(jìn)銷存財(cái)務(wù)生產(chǎn)功能(附源碼)

          3.優(yōu)質(zhì)SpringBoot帶工作流管理項(xiàng)目(附源碼)

          4.最好用的OA系統(tǒng),拿來即用(附源碼)

          5.SBoot+Vue外賣系統(tǒng)前后端都有(附源碼

          6.SBoot+Vue可視化大屏拖拽項(xiàng)目(附源碼)


          轉(zhuǎn)發(fā)在看就是最大的支持??

          瀏覽 697
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  欧美色图365 | 99国内自拍 | 大香蕉伊人在线观看视频 | 国产91精品国自产精品 | 波多野结衣网站 |