2020年java程序員如何找工作嗎?這18道java面試題要看哦!



小時(shí)候總期盼著2020年到來(lái),可真的要到了2020年,我們大多數(shù)都是心慌的,仿佛曾經(jīng)所幻想的所堅(jiān)持的都被時(shí)間打敗。有些人2019年初辭職,結(jié)果到了2019年末還未找到合適的工作。有些人為了堅(jiān)持自己的喜歡不想隨波逐流,再一次一次面試中被打敗。有些人一邊忍受著領(lǐng)導(dǎo)一邊想在2020年找到自己喜歡的工作。作為一名java程序員,如何在2020年找到適合自己的工作呢?

今天,小編整理18道java常見(jiàn)面試題,希望能幫助到大家!

1、什么是 Spring Boot?

多年來(lái),隨著新功能的增加,spring 變得越來(lái)越復(fù)雜。訪問(wèn)spring官網(wǎng)頁(yè)面,我們就會(huì)看到可以在我們的應(yīng)用程序中使用的所有 Spring 項(xiàng)目的不同功能。如果必須啟動(dòng)一個(gè)新的 Spring 項(xiàng)目,我們必須添加構(gòu)建路徑或添加 Maven 依賴關(guān)系,配置應(yīng)用程序服務(wù)器,添加 spring 配置。因此,開(kāi)始一個(gè)新的 spring 項(xiàng)目需要很多努力,因?yàn)槲覀儸F(xiàn)在必須從頭開(kāi)始做所有事情。

Spring Boot 是解決這個(gè)問(wèn)題的方法。Spring Boot 已經(jīng)建立在現(xiàn)有 spring 框架之上。使用 spring 啟動(dòng),我們避免了之前我們必須做的所有樣板代碼和配置。因此,Spring Boot 可以幫助我們以最少的工作量,更加健壯地使用現(xiàn)有的 Spring功能。

2、Spring Boot 有哪些優(yōu)點(diǎn)?

Spring Boot 的優(yōu)點(diǎn)有:

1、減少開(kāi)發(fā),測(cè)試時(shí)間和努力。

2、使用 JavaConfig 有助于避免使用 XML。

3、避免大量的 Maven 導(dǎo)入和各種版本沖突。

4、提供意見(jiàn)發(fā)展方法。

5、通過(guò)提供默認(rèn)值快速開(kāi)始開(kāi)發(fā)。

6、沒(méi)有單獨(dú)的 Web 服務(wù)器需要。這意味著你不再需要啟動(dòng) Tomcat,Glassfish或其他任何東西。

7、需要更少的配置 因?yàn)闆](méi)有 web.xml 文件。只需添加用@ Configuration 注釋的類,然后添加用@Bean 注釋的方法,Spring 將自動(dòng)加載對(duì)象并像以前一樣對(duì)其進(jìn)行管理。您甚至可以將@Autowired 添加到 bean 方法中,以使 Spring 自動(dòng)裝入需要的依賴關(guān)系中。

8、基于環(huán)境的配置 使用這些屬性,您可以將您正在使用的環(huán)境傳遞到應(yīng)用程序:-Dspring.profiles.active = {enviornment}。在加載主應(yīng)用程序?qū)傩晕募,Spring 將在(application{environment} .properties)中加載后續(xù)的應(yīng)用程序?qū)傩晕募?/P>

3、什么是 JavaConfig?

Spring JavaConfig 是 Spring 社區(qū)的產(chǎn)品,它提供了配置 Spring IoC 容器的純Java 方法。因此它有助于避免使用 XML 配置。使用 JavaConfig 的優(yōu)點(diǎn)在于:

(1)面向?qū)ο蟮呐渲。由于配置被定義為 JavaConfig 中的類,因此用戶可以充分利用 Java 中的面向?qū)ο蠊δ堋R粋(gè)配置類可以繼承另一個(gè),重寫(xiě)它的@Bean 方法等。

(2)減少或消除 XML 配置;谝蕾囎⑷朐瓌t的外化配置的好處已被證明。但是,許多開(kāi)發(fā)人員不希望在 XML 和 Java 之間來(lái)回切換。JavaConfig 為開(kāi)發(fā)人員提供了一種純 Java 方法來(lái)配置與 XML 配置概念相似的 Spring 容器。從技術(shù)角度來(lái)講,只使用 JavaConfig 配置類來(lái)配置容器是可行的,但實(shí)際上很多人認(rèn)為將JavaConfig 與 XML 混合匹配是理想的。

(3)類型安全和重構(gòu)友好。JavaConfig 提供了一種類型安全的方法來(lái)配置 Spring容器。由于 Java 5.0 對(duì)泛型的支持,現(xiàn)在可以按類型而不是按名稱檢索 bean,不需要任何強(qiáng)制轉(zhuǎn)換或基于字符串的查找。

4、如何重新加載 Spring Boot 上的更改,而無(wú)需重新啟動(dòng)服務(wù)器?

這可以使用 DEV 工具來(lái)實(shí)現(xiàn)。通過(guò)這種依賴關(guān)系,您可以節(jié)省任何更改,嵌入式tomcat 將重新啟動(dòng)。Spring Boot 有一個(gè)開(kāi)發(fā)工具(DevTools)模塊,它有助于提高開(kāi)發(fā)人員的生產(chǎn)力。Java 開(kāi)發(fā)人員面臨的一個(gè)主要挑戰(zhàn)是將文件更改自動(dòng)部署到服務(wù)器并自動(dòng)重啟服務(wù)器。開(kāi)發(fā)人員可以重新加載 Spring Boot 上的更改,而無(wú)需重新啟動(dòng)服務(wù)器。這將消除每次手動(dòng)部署更改的需要。Spring Boot 在發(fā)布它的第一個(gè)版本時(shí)沒(méi)有這個(gè)功能。這是開(kāi)發(fā)人員最需要的功能。DevTools 模塊完全滿足開(kāi)發(fā)人員的需求。該模塊將在生產(chǎn)環(huán)境中被禁用。它還提供 H2 數(shù)據(jù)庫(kù)控制臺(tái)以更好地測(cè)試應(yīng)用程序。

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-devtools</artifactId>

<optional>true</optional>

5、Spring Boot 中的監(jiān)視器是什么?

Spring boot actuator 是 spring 啟動(dòng)框架中的重要功能之一。Spring boot 監(jiān)視器可幫助您訪問(wèn)生產(chǎn)環(huán)境中正在運(yùn)行的應(yīng)用程序的當(dāng)前狀態(tài)。有幾個(gè)指標(biāo)必須在生產(chǎn)環(huán)境中進(jìn)行檢查和監(jiān)控。即使一些外部應(yīng)用程序可能正在使用這些服務(wù)來(lái)向相關(guān)人員觸發(fā)警報(bào)消息。監(jiān)視器模塊公開(kāi)了一組可直接作為 HTTP URL 訪問(wèn)的REST 端點(diǎn)來(lái)檢查狀態(tài)。

6、如何在 Spring Boot 中禁用 Actuator 端點(diǎn)安全性?

默認(rèn)情況下,所有敏感的 HTTP 端點(diǎn)都是安全的,只有具有 ACTUATOR 角色的用戶才能訪問(wèn)它們。安全性是使用標(biāo)準(zhǔn)的 HttpServletRequest.isUserInRole 方法實(shí)施的。 我們可以使用來(lái)禁用安全性。只有在執(zhí)行機(jī)構(gòu)端點(diǎn)在防火墻后訪問(wèn)時(shí),才建議禁用安全性。

7、如何在自定義端口上運(yùn)行 Spring Boot 應(yīng)用程序?

為了在自定義端口上運(yùn)行 Spring Boot 應(yīng)用程序,您可以在application.properties 中指定端口。server.port = 8090

8、什么是 YAML?

YAML 是一種人類可讀的數(shù)據(jù)序列化語(yǔ)言。它通常用于配置文件。與屬性文件相比,如果我們想要在配置文件中添加復(fù)雜的屬性,YAML 文件就更加結(jié)構(gòu)化,而且更少混淆。可以看出 YAML 具有分層配置數(shù)據(jù)。

9、如何實(shí)現(xiàn) Spring Boot 應(yīng)用程序的安全性?

為了實(shí)現(xiàn) Spring Boot 的安全性,我們使用 spring-boot-starter-security 依賴項(xiàng),并且必須添加安全配置。它只需要很少的代碼。配置類將必須擴(kuò)展WebSecurityConfigurerAdapter 并覆蓋其方法。

10、如何集成 Spring Boot 和 ActiveMQ?

對(duì)于集成 Spring Boot 和 ActiveMQ,我們使用依賴關(guān)系。 它只需要很少的配置,并且不需要樣板代碼。

11、如何使用 Spring Boot 實(shí)現(xiàn)分頁(yè)和排序?

使用 Spring Boot 實(shí)現(xiàn)分頁(yè)非常簡(jiǎn)單。使用 Spring Data-JPA 可以實(shí)現(xiàn)將可分頁(yè)的傳遞給存儲(chǔ)庫(kù)方法。

12、什么是 Swagger?你用 Spring Boot 實(shí)現(xiàn)了它嗎?

Swagger 廣泛用于可視化 API,使用 Swagger UI 為前端開(kāi)發(fā)人員提供在線沙箱。Swagger 是用于生成 RESTful Web 服務(wù)的可視化表示的工具,規(guī)范和完整框架實(shí)現(xiàn)。它使文檔能夠以與服務(wù)器相同的速度更新。當(dāng)通過(guò) Swagger 正確定義時(shí),消費(fèi)者可以使用最少量的實(shí)現(xiàn)邏輯來(lái)理解遠(yuǎn)程服務(wù)并與其進(jìn)行交互。因此,Swagger消除了調(diào)用服務(wù)時(shí)的猜測(cè)。

13、什么是 Spring Profiles?

Spring Profiles 允許用戶根據(jù)配置文件(dev,test,prod 等)來(lái)注冊(cè) bean。因此,當(dāng)應(yīng)用程序在開(kāi)發(fā)中運(yùn)行時(shí),只有某些 bean 可以加載,而在 PRODUCTION中,某些其他 bean 可以加載。假設(shè)我們的要求是 Swagger 文檔僅適用于 QA 環(huán)境,并且禁用所有其他文檔。這可以使用配置文件來(lái)完成。Spring Boot 使得使用配置文件非常簡(jiǎn)單。

14、什么是 Spring Batch?

Spring Boot Batch 提供可重用的函數(shù),這些函數(shù)在處理大量記錄時(shí)非常重要,包括日志/跟蹤,事務(wù)管理,作業(yè)處理統(tǒng)計(jì)信息,作業(yè)重新啟動(dòng),跳過(guò)和資源管理。它還提供了更先進(jìn)的技術(shù)服務(wù)和功能,通過(guò)優(yōu)化和分區(qū)技術(shù),可以實(shí)現(xiàn)極高批量和高性能批處理作業(yè)。簡(jiǎn)單以及復(fù)雜的大批量批處理作業(yè)可以高度可擴(kuò)展的方式利用框架處理重要大量的信息。

15、什么是 FreeMarker 模板?

FreeMarker 是一個(gè)基于 Java 的模板引擎,最初專注于使用 MVC 軟件架構(gòu)進(jìn)行動(dòng)態(tài)網(wǎng)頁(yè)生成。使用 Freemarker 的主要優(yōu)點(diǎn)是表示層和業(yè)務(wù)層的完全分離。程序員可以處理應(yīng)用程序代碼,而設(shè)計(jì)人員可以處理 html 頁(yè)面設(shè)計(jì)。最后使用freemarker 可以將這些結(jié)合起來(lái),給出最終的輸出頁(yè)面。

16、如何使用 Spring Boot 實(shí)現(xiàn)異常處理?

Spring 提供了一種使用 ControllerAdvice 處理異常的非常有用的方法。 我們通過(guò)實(shí)現(xiàn)一個(gè) ControlerAdvice 類,來(lái)處理控制器類拋出的所有異常。

17、您使用了哪些 starter maven 依賴項(xiàng)?

使用了下面的一些依賴項(xiàng)

spring-boot-starter-activemq

spring-boot-starter-security

這有助于增加更少的依賴關(guān)系,并減少版本的沖突。

18、什么是 CSRF 攻擊?

CSRF 代表跨站請(qǐng)求偽造。這是一種攻擊,迫使最終用戶在當(dāng)前通過(guò)身份驗(yàn)證的Web 應(yīng)用程序上執(zhí)行不需要的操作。CSRF 攻擊專門(mén)針對(duì)狀態(tài)改變請(qǐng)求,而不是數(shù)據(jù)竊取,因?yàn)楣粽邿o(wú)法查看對(duì)偽造請(qǐng)求的響應(yīng)。

以上,就是小編為大家整理的18道java常見(jiàn)面試題,希望能夠幫助到大家!

北大青鳥(niǎo)網(wǎng)上報(bào)名
北大青鳥(niǎo)招生簡(jiǎn)章