java八大異常 寫JAVA后端代碼時邏輯混亂怎么辦?
寫JAVA后端代碼時邏輯混亂怎么辦?后端代碼的復(fù)雜性是通過除法和規(guī)則來解決的。如果存在單環(huán)依賴工程,則不能將其劃分為多個環(huán)。對于項目中的代碼,可以通過水平拆分和垂直拆分來降低復(fù)雜性。水平層分為控制器、
寫JAVA后端代碼時邏輯混亂怎么辦?
后端代碼的復(fù)雜性是通過除法和規(guī)則來解決的。如果存在單環(huán)依賴工程,則不能將其劃分為多個環(huán)。
對于項目中的代碼,可以通過水平拆分和垂直拆分來降低復(fù)雜性。水平層分為控制器、服務(wù)、Dao和sqlmap,垂直層分為系統(tǒng)、biz1、biz2、Bizn,但在數(shù)據(jù)通暢連接中,水平拆分和垂直拆分相結(jié)合,如下圖所示:
通過這種分層方式,代碼層是分開的,結(jié)構(gòu)清晰。對于一些跨模塊調(diào)用的接口,如同一個數(shù)據(jù)表需要在不同的模塊中操作時,可以將該接口作為公共接口升級到上層cxmodule,對于一些可重用的、相對獨立的功能,可以在cxmodule中定義一個干凈的接口,業(yè)務(wù)邏輯可以通過在模塊的功能模塊中實現(xiàn)接口來實現(xiàn),而不需要使用spring的事務(wù)管理機制,從而降低代碼的復(fù)雜度。
有人說設(shè)計模式是為了彌補Java語言的缺陷,你覺得是這樣嗎?
如果你從語言的角度來看設(shè)計模式,那是對的。一些設(shè)計模式彌補了Java語言的不足,其中最明顯的是singleton模式。
Java本身不提供單例對象創(chuàng)建,需要通過單例模式實現(xiàn)。什么樣的餓、懶、多線程都要注意DCL、易變關(guān)鍵字等,導(dǎo)致面試題很多。
在現(xiàn)代語言中,許多提供了創(chuàng)建單例對象的語法,例如scala和kotlin的對象關(guān)鍵字。
從架構(gòu)的角度來看,設(shè)計模式將組件關(guān)系解耦。
假設(shè)我們要實現(xiàn)一個帶有上載服務(wù)的文件服務(wù)器來上載文件。我們可以調(diào)用convertservice來轉(zhuǎn)換文件。Uploadservice屬于核心模塊upload module,convertservice屬于非核心模塊conversion module。
如果uploadservice直接調(diào)用convertservice來執(zhí)行轉(zhuǎn)換,則核心模塊依賴于非核心模塊。如下圖所示:
非核心模塊相對不穩(wěn)定,核心模塊相對穩(wěn)定。核心模塊對非核心模塊的依賴將導(dǎo)致核心模塊的不穩(wěn)定性。所以可以使用策略模式來解耦:
看箭頭方向,現(xiàn)在轉(zhuǎn)換模塊依賴于上傳模塊,轉(zhuǎn)換模塊的變化不會影響上傳模塊。依賴的方向改變了。這就是傳說中的“依賴倒置”!