主頁 > 軟體設計 > 作業3年去大廠面試Java開發,被Spring問自閉了...

作業3年去大廠面試Java開發,被Spring問自閉了...

2020-09-21 13:11:57 軟體設計

前言:

又到了金九銀十的日子,前幾天好朋友發來喜訊,跳槽一個月了,面試了有二十家公司,在面試官的狂轟濫炸下終于拿到了不錯的offer,但是比較可惜的是朋友內推的大廠面試失敗了,而且還是在Spring上,就令人挺無語的,他說本來以為大廠的面試會問一下高并發執行緒組件方面的知識,所以就著重看了一下這些,沒想到栽倒了Spring上,真是太慘了!

所以今天我就總結一下幾個關于Spring的高頻面試題,比如:SpringAOP和aspectJ AOP有什么區別?springbean的生命周期?事務控制等,希望對大家有所幫助,
在這里插入圖片描述

另外本人整理收藏了20年多家公司面試知識點整理 ,以及各種Java核心知識點免費分享給大家,想要資料的話請點795983544暗號CSDN,

在這里插入圖片描述

IOC

IOC(Inversion Of Controll,控制反轉)是一種設計思想,將原本在程式中手動創建物件的控制權,交由給Spring框架來管理,IOC容器是Spring用來實作IOC的載體,IOC容器實際上就是一個Map(key, value),Map中存放的是各種物件,

這樣可以很大程度上簡化應用的開發,把應用從復雜的依賴關系中解放出來,IOC容器就像是一個工廠,當需要創建一個物件,只需要配置好組態檔/注解即可,不用考慮物件是如何被創建出來的,大大增加了專案的可維護性且降低了開發難度,

AOP

AOP(Aspect-Oriented Programming,面向切面編程)能夠將那些與業務無關,卻為業務模塊所共同呼叫的邏輯或責任(例如事務處理、日志管理、權限控制等)封裝起來,便于減少系統的重復代碼,降低模塊間的耦合度,并有利于未來的可擴展性和可維護性,使用AOP之后我們可以把一些通用功能抽象出來,在需要用到的地方直接使用即可,這樣可以大大簡化代碼量,提高了系統的擴展性,

Spring AOP是基于動態代理的,如果要代理的物件實作了某個介面,那么Spring AOP就會使用JDK動態代理去創建代理物件;而對于沒有實作介面的物件,就無法使用JDK動態代理,轉而使用CGlib動態代理生成一個被代理物件的子類來作為代理,
在這里插入圖片描述

Spring AOP / AspectJ AOP 的區別?

Spring AOP屬于運行時增強,而AspectJ是編譯時增強,

Spring AOP基于代理(Proxying),而AspectJ基于位元組碼操作(Bytecode Manipulation),

AspectJ相比于Spring AOP功能更加強大,但是Spring AOP相對來說更簡單,如果切面比較少,那么兩者性能差異不大,但是,當切面太多的話,最好選擇AspectJ,它比SpringAOP快很多,

Spring框架中都用到了哪些設計模式?

  1. 代理模式:在AOP和remoting中被用的比較多,

  2. 單例模式:在spring組態檔中定義的bean默認為單例模式,

  3. 模板方法模式:用來解決代碼重復的問題,

  4. 前端控制器模式:Spring提供了DispatcherServlet來對請求進行分發,

  5. 依賴注入模式:貫穿于BeanFactory / ApplicationContext介面的核心理念,

  6. 工廠模式:BeanFactory用來創建物件的實體,

springmvc的核心是什么,請求的流程是怎么處理的,控制反轉怎么實作的

在這里插入圖片描述

核心:控制反轉和面向切面

請求處理流程:

首先用戶發送請求到前端控制器,前端控制器根據請求資訊(如URL)來決定選擇哪一個頁面控制器進行處理并把請求委托給它,即以前的控制器的控制邏輯部分;
頁面控制器接收到請求后,進行功能處理,首先需要收集和系結請求引數到一個物件,并進行驗證,然后將命令物件委托給業務物件進行處理;處理完畢后回傳一個ModelAndView(模型資料和邏輯視圖名);
前端控制器識訓控制權,然后根據回傳的邏輯視圖名,選擇相應的視圖進行渲染,并把模型資料傳入以便視圖渲染;
前端控制器再次識訓控制權,將回應回傳給用戶,
控制反轉如何實作:

我們每次使用spring框架都要配置xml檔案,這個xml配置了bean的id和class,
spring中默認的bean為單實體模式,通過bean的class參考反射機制可以創建這個實體,
因此,spring框架通過反射替我們創建好了實體并且替我們維護他們,
A需要參考B類,spring框架就會通過xml把B實體的參考傳給了A的成員變數,

你用過哪些重要的 Spring 注解?

@Controller - 用于 Spring MVC 專案中的控制器類,
@Service - 用于服務類,
@RequestMapping - 用于在控制器處理程式方法中配置 URI 映射,
@ResponseBody - 用于發送 Object 作為回應,通常用于發送 XML 或 JSON 資料作為回應,
@PathVariable - 用于將動態值從 URI 映射到處理程式方法引數,
@Autowired - 用于在 spring bean 中自動裝配依賴項,
@Qualifier - 使用 @Autowired 注解,以避免在存在多個 bean 型別實體時出現混淆,
@Scope - 用于配置 spring bean 的范圍,
@Configuration,@ComponentScan 和 @Bean - 用于基于 java 的配置,
@Aspect,@Before,@After,@Around,@Pointcut - 用于切面編程(AOP),

@Component, @Controller, @Repository, @Service 有何區別?

  • @Component:這將 java 類標記為 bean,它是任何 Spring 管理組件的通用構造型,spring
    的組件掃描機制現在可以將其拾取并將其拉入應用程式環境中,
  • @Controller:這將一個類標記為 Spring Web MVC 控制器,標有它的 Bean 會自動匯入到 IoC 容器中,
  • @Service:此注解是組件注解的特化,它不會對 @Component 注解提供任何其他行為,您可以在服務層類中使用
  • @Service 而不是 @Component,因為它以更好的方式指定了意圖,
  • @Repository:這個注解是具有類似用途和功能的 @Component 注解的特化,它為 DAO 提供了額外的好處,它將 DAO匯入 IoC 容器,并使未經檢查的例外有資格轉換為 Spring DataAccessException,

SpringMVC 流程?

1)用戶發送請求至前端控制器 DispatcherServlet,
2)DispatcherServlet 收到請求呼叫 HandlerMapping 處理器映射器,
3)處理器映射器找到具體的處理器(可以根據 xml 配置、注解進行查找),生成處理器及處理器攔截器(如果有則生成)一并回傳給 DispatcherServlet,
4)DispatcherServlet 呼叫 HandlerAdapter 處理器配接器,
5)HandlerAdapter 經過適配呼叫具體的處理器(Controller,也叫后端控制器)
6)Controller 執行完成回傳 ModelAndView,
7)HandlerAdapter 將 controller 執行結果 ModelAndView 回傳給 DispatcherServlet,8)DispatcherServlet 將 ModelAndView 傳給 ViewReslover 視圖決議器,
9)ViewReslover 決議后回傳具體 View,
10)DispatcherServlet 根據 View 進行渲染視圖(即將模型資料填充至視圖中),
11)DispatcherServlet 回應用戶,

SpringMvc 怎么和 AJAX 相互呼叫的?

通過 Jackson 框架就可以把 Java 里面的物件直接轉化成 Js 可以識別的 Json 物件具體步驟如下
1)加入 Jackson.jar
2)在組態檔中配置 json 的映射
3)在接受 Ajax 方法里面可以直接回傳 Object,List 等,但方法前面要加上@ResponseB注解

有哪些不同型別的依賴注入實作方式?

依賴注入是時下最流行的IoC實作方式,依賴注入分為介面注入(Interface Injection),Setter方法注入(Setter Injection)和構造器注入(Constructor Injection)三種方式,其中介面注入由于在靈活性和易用性比較差,現在從Spring4開始已被廢棄,

構造器依賴注入:構造器依賴注入通過容器觸發一個類的構造器來實作的,該類有一系列引數,每個引數代表一個對其他類的依賴,

Setter方法注入:Setter方法注入是容器通過呼叫無參構造器或無參static工廠 方法實體化bean之后,呼叫該bean的setter方法,即實作了基于setter的依賴注入,

Spring Beans

什么是Spring beans?

Spring beans 是那些形成Spring應用的主干的java物件,它們被Spring IOC容器初始化,裝配,和管理,這些beans通過容器中配置的元資料創建,比如,以XML檔案中 的形式定義,

一個 Spring Bean 定義 包含什么?

一個Spring Bean 的定義包含容器必知的所有配置元資料,包括如何創建一個bean,它的生命周期詳情及它的依賴,

如何給Spring 容器提供配置元資料?Spring有幾種配置方式

這里有三種重要的方法給Spring 容器提供配置元資料,

XML組態檔,
基于注解的配置,
基于java的配置,

Spring組態檔包含了哪些資訊

Spring組態檔是個XML 檔案,這個檔案包含了類資訊,描述了如何配置它們,以及如何相互呼叫,

Spring基于xml注入bean的幾種方式

Set方法注入;
構造器注入:①通過index設定引數的位置;②通過type設定引數型別;
靜態工廠注入;
實體工廠;

關于事務控制

事務是一系列的動作,它們綜合在一起才是一個完整的作業單元,這些動作必須全部完成,如果有一個失敗的話,那么事務就會回滾到最開始的狀態,仿佛什么都沒發生過一樣,

1.1 spring中事務控制API
PlatformTransactionManager 介面提供事務操作的方法,包含三個具體的操作

public interface PlatformTransactionManager extends TransactionManager {
    // 獲取事務狀態資訊
    TransactionStatus getTransaction(@Nullable TransactionDefinition var1) throws TransactionException;

    // 提交事務
    void commit(TransactionStatus var1) throws TransactionException;

    // 回滾事務
    void rollback(TransactionStatus var1) throws TransactionException;
}

開發中常用的實作類:

org.springframework.jdbc.datasource.DataSourceTransactionManager :使用Spring JDBC或iBatis進行持久化資料時使用

spring中事務控制介面的結構
在這里插入圖片描述
1.1.2 TransactionDefinition

事務的定義資訊物件,包含如下方法:

獲取事務物件名稱:String getName()

獲取事務隔離級別:int getIsolationLevel()

獲取事務傳播行為:int getPropagationBehavior()

獲取事務超時時間:int getTimeout()

獲取事務是否只讀:boolean isReadOnly()

1.1.3 TransactionStatus

描述了某個時間點上事務物件的狀態資訊,包含6個具體的操作:

重繪事務:void flush()

獲取是否存在儲存點:boolean hasSavepoint()

獲取事務是否完成:boolean isCompleted()

獲取事務是否為新的事物:boolean isNewTransaction()

獲取事務是否回滾:boolean isRollbackOnly()

設定事務回滾:void set RollbackOnly()

1.2 事務的隔離級別

事務的隔離界別反映事務提交并發訪問時的處理態度

1.2.1 事務隔離的級別

  • ISOLATION_DEFAULT 默認級別,由 DBA 默認的設定來決定隔離級別,歸屬下列某一種
  • ISOLATION_READ_UNCOMMITTED 就是一個事務可以讀取另一個未提交事務的資料,會出現臟讀、不可重復讀、幻讀(隔離級別最低,但并發性高)
  • ISOLATION_READ_COMMITTED 就是一個事務要等另一個事務提交后才能讀取資料,解決臟讀問題,會出現不可重復讀、幻讀問題(鎖定正在讀取的行,適用于大多數系統,Oracle默認級別)
  • ISOLATION_REPEATABLE_READ 就是在開始讀取資料(事務開啟)時,不再允許修改操作,解決不可重復讀問題,會出現幻讀問題(鎖定所讀的所有行,MYSQL默認級別)
  • ISOLATION_SERALZABLE 是最高的事務隔離級別,在該級別下,事務串行化順序執行,可以避免臟讀、不可重復讀與幻讀,但是這種事務隔離級別效率低下,比較耗資料庫性能,一般不使用,

事務隔離級別由上到下依次提升,隔離級別越高,越能保證資料的完整性和一致性,但對資料庫性能的消耗依次增加,并發執行效率依次下降,

大多數的資料庫默認隔離級別為 Read Commited,比如 SqlServer、Oracle

少數資料庫默認隔離級別為:Repeatable Read 比如:MySQL InnoDB

1.2.2 資料庫讀取時會出現的三種問題

① Dirty reads:讀臟資料,

也就是說,比如事務A的未提交(還依然快取)的資料被事務B讀走,如果事務A失敗回滾,會導致事務B所讀取的的資料是錯誤的,

② non-repeatable reads:資料不可重復讀,

比如事務A中兩處讀取資料price的值,在第一讀的時候,price是100,然后事務B就把price的值改成 200;事務A再讀一次,結果就發現,price竟然就變成200了,造成事務A資料混亂,

③ phantom reads:幻象讀資料,

這個和non-repeatable reads相似,也是同一個事務中多次讀不一致的問題,但是 non-repeatable reads 的不一致是因為他所要取的資料值被改變了(比如price)而 phantom reads 所要讀的資料的不一致卻是他的條件資料集發生變化了,

比如:執行 Select account.id where account.name=“Bruce*”,第一次讀去了6個符合條件的id;第二次讀取的時候,由于事務B把一個帳號的名字由"dd"改成"Bruce1",結果取出來了7個資料,

不可重復讀的重點是修改:同樣的條件,兩次讀發現值不一樣;

幻讀的重點在于新增或者洗掉:同樣的條件,兩次讀發現得到的記錄數不一樣

1.2.3 資料隔離級別和出現的問題之間的關聯

在這里插入圖片描述

1.3 事務的傳播行為

  • REQUIRED:如果當前沒有事務,就新建一個事務,如果已經存在一個事務中,加入到這個事務中,一般的選 擇(默認值)

  • SUPPORTS:支持當前事務,如果當前沒有事務,就以非事務方式執行(沒有事務)

  • MANDATORY:使用當前的事務,如果當前沒有事務,就拋出例外,

  • REQUERS_NEW:新建事務,如果當前在事務中,把當前事務掛起,

  • NOT_SUPPORTED:以非事務方式執行操作,如果當前存在事務,就把當前事務掛起,

  • NEVER:以非事務方式運行,如果當前存在事務,拋出例外,

  • NESTED:如果當前存在事務,則在嵌套事務內執行,如果當前沒有事務,則執行REQUIRED類似的操作,

1.4 超時時間

指事務提交后最長可以等待的時間,超出時間則會自動失敗,默認值是-1,沒有時間限制,如果有,則以秒為單位進行設定,

1.5 是否為只讀事務

讀寫型事務:增加、洗掉、修改時開啟事務

只讀型事務:執行查詢時,也會開啟事務

面試總結:

無論是哪家公司,都很重視Spring框架技術,重視基礎,所以千萬別小看任何知識,面試是一個雙向選擇的程序,不要抱著畏懼的心態去面試,不利于自己的發揮,同時看中的應該不止薪資,還要看你是不是真的喜歡這家公司,是不是能真的得到鍛煉,其實我寫了這么多,只是我自己的總結,并不一定適用于所有人,相信經過一些面試,大家都會有這些感觸,

另外本人整理收藏了20年多家公司面試知識點整理 ,以及各種Java核心知識點免費分享給大家,下方只是部分截圖 想要資料的話也可以點擊795983544領取 暗號CSDN,

在這里插入圖片描述

在這里插入圖片描述

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/97202.html

標籤:其他

上一篇:LeetCode 1550. 存在連續三個奇數的陣列

下一篇:SpringMVC

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more