SpringBoot 階段測驗 1
目錄- SpringBoot 階段測驗 1
- 1、使用JDK8新語法完成下列集合練習:
- 1.1 List中有1,2,3,4,5,6,7,8,9幾個元素要求;
- (1) 將奇、偶數分別匯聚成一個List
- (2) 分別求出奇數和偶數的和
- 1.2 已知集合:[[1,3,5,7,5,3,11],[2,4,6,8,6,4,2],[5,8,7]]要求:
- 1.2.1 集合轉換:["1","3","5","7","5",...,"5", "8","7"],
- 1.1 List中有1,2,3,4,5,6,7,8,9幾個元素要求;
- 2、springboot框架下的為什么有些依賴是不需要版本號的?
- 3、springboot核心注解是什么,深入介紹下這個注解,
- 4、pringboot為什么可以打包成可執行的jar,執行命令是什么?
- 4.1 MANIFEST.MF的主要內容:
- 4.2 執行命令
- 5、Springboot的組態檔是哪個?你知道有哪些格式,這些格式的優先級是什么?配置過哪些內容?
- 5.1Springboot的組態檔
- 5.2 Springboot的組態檔格式,和優先級
- 5.3 配置過哪些內容
- 6、日志有哪些級別,springboot的默認日志框架是什么?專案中是如何使用的?
- 7、springboot中你知道有哪些方式可以用來讀取組態檔?他們的區別是什么?
- 8、你覺得在哪些業務中可以使用定時任務,在springboot中如何實作定時任務?
- 9、你覺得在哪些業務中可以使用異步任務,在 springboot中如何實作異步任務?
- 10、redis有哪些資料型別?你常用哪些資料型別?
- 11、如何在redis中保存一個java物件,又如何把redis中資料變為java物件?
- 12、什么是序列化?為什么需要序列化,在哪些場景中需要序列化?
- 13、redis是單執行緒還是單行程的?
- 14、簡述下redis 中 setnx命令的效果或作用?
- 15、介紹下你用redis做過的一些業務,以及為什么你用redis 做,
- 16.事務隔離級別有哪些?MySQL的默認隔離級別是?
- 17、為什么要使用統一回傳類?
- 18、什么叫物理洗掉什么叫邏輯洗掉,分別適用于哪些場景?
- 19、為什么要使用swagger?
- 20、使用springboot框架相較于之前的spring或者springmvc框架有哪些優勢?
1、使用JDK8新語法完成下列集合練習:
1.1 List中有1,2,3,4,5,6,7,8,9幾個元素要求;
(1) 將奇、偶數分別匯聚成一個List
//初始化集合
List<Integer> numList = new ArrayList<>();
//批量添加資料
Collections.addAll(numList,1,2,3,4,5,6,7,8,9,10);
//或者
//List<Integer> numList = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
//方法一: 使用 forEach
List<Integer> oddList = new ArrayList<>();
List<Integer> evenList = new ArrayList<>();
numList.forEach(num-> {
boolean temp = (num%2 == 1) ? oddList.add(num) : evenList.add(num);
});
log.info("numList:{}",numList); //numList:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
log.info("oddList:{}",oddList); //oddList:[1, 3, 5, 7, 9]
log.info("evenList:{}",evenList); //evenList:[2, 4, 6, 8, 10]
//方法二: 使用 filter 過濾 + collect 收集
List<Integer> oddList2 = numList.stream().filter(num -> num%2==1).collect(Collectors.toList());
List<Integer> evenList2 = numList.stream().filter(num -> num%2==0).collect(Collectors.toList());
log.info("oddList2:{}",oddList2); //oddList2:[1, 3, 5, 7, 9]
log.info("evenList2:{}",evenList2); //evenList2:[2, 4, 6, 8, 10]
(2) 分別求出奇數和偶數的和
//奇數集合
//使用選出來的奇數求和
Optional<Integer> oddSum = oddList.stream().reduce((n, m) -> n + m);
log.info("使用選出來的奇數求和 oddSum:{}",oddSum.get());
//使用選出來的奇數求和 oddSum:25
//使用源集合 求和
oddSum = numList.stream().filter(num -> num % 2 == 1).reduce((n, m) -> n + m);
log.info("使用源集合 求和 oddSum:{}",oddSum.get());
//使用源集合 求和 oddSum:25
//偶數集合
//使用選出來的偶數 求奇數和
Optional<Integer> evenSum = evenList.stream().reduce((n, m) -> n + m);
log.info("使用選出來的偶數 求奇數和 evenSum:{}",evenSum.get());
//使用選出來的偶數 求奇數和 evenSum:30
//使用源集合 求偶數和
evenSum = numList.stream().filter(num->num%2 == 0).reduce((n,m)->n+m);
log.info("使用源集合 求偶數和 evenSum:{}",evenSum.get());
//使用源集合 求偶數和 evenSum:30
1.2 已知集合:[[1,3,5,7,5,3,11],[2,4,6,8,6,4,2],[5,8,7]]要求:
1.2.1 集合轉換:["1","3","5","7","5",...,"5", "8","7"],
List<List<Integer>> oldList = new ArrayList<>();
Collections.addAll(oldList,Arrays.asList(1,3,5,7,5,3,11),Arrays.asList(2,4,6,8,6,4,2),Arrays.asList(5,8,7));
List<String> newList = new ArrayList<>();
oldList.forEach(num->num.forEach(n->newList.add("\""+n+"\"")));
//或
//oldList.forEach(nums->nums.stream().map(n -> "\""+n+"\"").forEach(n->newList.add(n)));
log.info("oldList:{}",oldList); //oldList:[[1, 3, 5, 7, 5, 3, 11], [2, 4, 6, 8, 6, 4, 2], [5, 8, 7]]
log.info("newList:{}",newList); //newList:["1", "3", "5", "7", "5", "3", "11", "2", "4", "6", "8", "6", "4", "2", "5", "8", "7"]
2、springboot框架下的為什么有些依賴是不需要版本號的?
springboot框架下的為什么有些依賴是不需要版本號的:
SpringBoot框架的版本仲裁中心,對一些依賴進行了版本可控制和沖突處理,版本控制中心沒有的需要自定義依賴版本;
3、springboot核心注解是什么,深入介紹下這個注解,
@SpringBootConfiguration: springboot的配置
@Configuration: spring配置類
@Component: 說明也是一個spring的組件
@EnableAutoConfiguration: 自動配置
@AutoConfigurationPackage: 自動配置包
@Import({Registrar.class}): 匯入自動配置包注冊 匯入著啟動類同包及其子內中的所有組件
@Import({AutoConfigurationImportSelector.class}): 匯入自動配置匯入選擇器
List<String> configurations = this.getCandidateConfigurations(annotationMetadata, attributes);//獲取所有的配置
@ComponentScan(excludeFilters = { : //按條件剔除一部分組件
@Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),
@Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })
4、pringboot為什么可以打包成可執行的jar,執行命令是什么?
Spring Boot 打包成Jar包運行的原理:https://blog.csdn.net/y5492853/article/details/123758851
4.1 MANIFEST.MF的主要內容:
xxx.jar/META-INFO/MANIFEST.MF
jar包啟動類:
Main-Class: org.springframework.boot.loader.JarLauncher
主啟動類:
Start-Class: com.kgc.scd.Edocmall96WebApplication
JarLauncher:
根據 Start-Class
通過反射拿到了專案的啟動類的main方法
從而啟動本地專案
4.2 執行命令
執行命令:
java -jar xxx.jar
可以添加引數:
java -jar xxx.jar --server.port=8081
java -jar -Dserver.port=8081 xxx.jar
5、Springboot的組態檔是哪個?你知道有哪些格式,這些格式的優先級是什么?配置過哪些內容?
5.1Springboot的組態檔
Springboot的組態檔是哪個:
application
5.2 Springboot的組態檔格式,和優先級
Springboot的組態檔格式:
application.properties,application.yml,
bootstrap.properties,bootstrap.yml
優先級:
bootstrap.properties>bootstrap.yml>application.properties>application.yml
組態檔路徑優先級:
專案根路徑下的confing下 > 專案根路徑下 > 專案類路徑(resource)下的confing下 > 專案類路徑下
5.3 配置過哪些內容
1、專案基本配置:
專案基本資訊
2、資料庫相關配置:
mybatis
mybatis-plus
jpa
逆向工程
3、組件相關:
dubbo
zookeeper
eureka
feign
hytrix
ribbon
zuul
config配置中心
4、一些官方介面線管:
微信相關
支付寶相關
驗證碼相關
短信相關
5、自定義配置:
一些方便修改的統一配置
6、日志有哪些級別,springboot的默認日志框架是什么?專案中是如何使用的?
日志有哪些級別: trace < dubug < info < warn < error
springboot的默認日志框架是什么: Sl4j + logback
默認日志級別是: info
專案中是如何使用的:
實體化日志物件: Logger logger = LoggerFactory.getLogger(getClass());
添加注解: @Sl4j
7、springboot中你知道有哪些方式可以用來讀取組態檔?他們的區別是什么?
讀取組態檔方式:
批量讀取: @ConfigurationProperties(prefix="xxx")
單個讀取: @Value("${xxx}")
如果需要指定組態檔:@PropertySource(value="https://www.cnblogs.com/xiaoqigui/archive/2022/10/30/classpath:xxx.properties")
區別:
批量獲取: 支持松散系結,支持復雜型別系結,支持資料格式校驗
8、你覺得在哪些業務中可以使用定時任務,在springboot中如何實作定時任務?
哪些業務中可以使用定時任務:
訂單審核、出庫、訂單超時自動取消與退款
優惠卷生成、發放與過期
物流資訊推送與狀態重繪
資料積壓監控、日志監控、服務可用性探測作業
定時備份與更新資料
金融系統每天的定時結算
按月批量統計報表資料
什么業務下需要要定時任務: https://www.csdn.net/tags/MtjaEg3sNjEzMjUtYmxvZwO0O0OO0O0O.html
springboot中如何實作定時任務:
方法上添加注解:
@Scheduled(fixedDelay=second)
@Scheduled(fixRate=second)
@Scheduled(cron="cronPartten")
主動啟動類上添加注解:
@EnableScheduling
9、你覺得在哪些業務中可以使用異步任務,在 springboot中如何實作異步任務?
哪些業務中可以使用異步任務:
發送短信驗證碼
購買成功或者抽獎成功短信通知
卡卷或優惠卷發放
發送微信紅包
微信訊息通知
訂單流程處理
定時批量處理(比如資料同步)
作業流性質的異步任務(未完成異步任務補償)
異步呼叫的經典業務場景: https://blog.csdn.net/fujuan08093206/article/details/79867367
springboot中如何實作異步任務:
方法上添加注解:
@Async
開啟異步執行緒注解,如果是同一個類中的其他方法呼叫,添加此異步處理注解,異步是不生效的
主啟動類上添加注解:
@EnableAsync
10、redis有哪些資料型別?你常用哪些資料型別?
redis有哪些資料型別:
string
list
set
hash
zset
geospatial
hyperloglog
bitmaps
常用哪些資料型別:
string
hash
zset: 比如 做瀏覽記錄
bitmaps: 比如 每日打卡(占用記憶體小)
11、如何在redis中保存一個java物件,又如何把redis中資料變為java物件?
如何在redis中保存一個java物件:
將物件轉換為json字串,存入redis中
如何把redis中資料變為java物件:
從redis中獲取物件json字串,再轉為對應的物件
注意: 需要自定義物件序列化方式
12、什么是序列化?為什么需要序列化,在哪些場景中需要序列化?
什么是序列化:
把物件轉換為位元組序列的程序
將物件的狀態資訊轉換為可以存盤或傳輸的形式的程序
什么是反序列化:
把位元組序列恢復為物件的程序
為什么需要序列化:
序列化的原因是 想將物件轉換成流,方便存盤和在網路上傳輸,
在哪些場景中需要序列化:
把記憶體中的物件狀態保存到一個檔案或者資料庫中時候
用套接字再網路上傳送物件的時候
通過RMI傳輸物件的時候(RMI是什么東西?):RMI總結來說就是遠程呼叫物件,在一個jvm上呼叫另一個jvm的物件,
通過RPC呼叫介面,獲取物件的時候
把物件存入redis中的時候
13、redis是單執行緒還是單行程的?
redis是單執行緒還是單行程:
單執行緒:
redis 為什么快:
為什么redis那么快?剖析redis快的原因:
https://blog.csdn.net/qq3073959033/article/details/127415029
https://blog.csdn.net/weixin_43001336/article/details/122773260
1.純記憶體KV操作
2.單執行緒操作
3.I/O 多路復用
4.Reactor 設計模式
那么為什么Redis是單執行緒的:
https://blog.csdn.net/weixin_44395707/article/details/106192656
原因如下:
1. CPU不是瓶頸:Redis的所有操作都是基于記憶體的,而CPU不是Redis的瓶頸,在大多數情況下,Redis的瓶頸很可能是機器記憶體或網路帶寬的大小,如果我們想要更高的性能,可以使用單執行緒Redis,我們可以使用集群(多個行程)解決方案,
2. 并發性:并行性不是支持多個客戶端的唯一策略,Redis使用epoll和事件回圈來實作并發策略并節省大量時間而無需背景關系切換,
3. 易于實作:撰寫多執行緒程式可能會更加困難,我們需要為執行緒添加鎖和同步機制,
4. 易于部署:單執行緒應用程式可以部署在至少具有單個CPU內核的任何計算機上,
14、簡述下redis 中 setnx命令的效果或作用?
redis 中 setnx命令的效果或作用:
只有key不存在的情況下,設定key的值,如key存在,則什么也不做,
設定成功回傳1,失敗回傳0;
redis setnx java_Redis SETNX 命令:
https://blog.csdn.net/weixin_39517289/article/details/114468562
15、介紹下你用redis做過的一些業務,以及為什么你用redis 做,
用redis做過的一些業務:
快取
資料共享分布式
分布式鎖
全域ID
計數器
限流
位統計
購物車
用戶訊息時間線timeline
訊息佇列
抽獎
點贊
簽到
打卡
商品標簽
商品篩選
用戶關注
推薦模型
排行榜
Redis 16 個常見的使用場景:
https://blog.csdn.net/gp_911014/article/details/124744869
16.事務隔離級別有哪些?MySQL的默認隔離級別是?
事務隔離級別有哪些:
讀未提交
讀已提交
可重復讀
可串行化
MySQL的默認隔離級別是:
可重復讀
臟讀、幻讀和不可重復讀:
https://blog.csdn.net/qq_41776884/article/details/81608777
臟讀: 臟讀就是指當一個事務正在訪問資料,并且對資料進行了修改,而這種修改還沒有提交到資料庫中,這時,另外一個事務也訪問這個資料,然后使用了這個資料,
不可重復讀: 是指在一個事務內,多次讀同一資料,在這個事務還沒有結束時,另外一個事務也訪問該同一資料,那么,在第一個事務中的兩次讀資料之間,由于第二個事務的修改,那么第一個事務兩次讀到的的資料可能是不一樣的,這樣就發生了在一個事務內兩次讀到的資料是不一樣的,因此稱為是不可重復讀,
幻讀: 是指當事務不是獨立執行時發生的一種現象,例如第一個事務對一個表中的資料進行了修改,這種修改涉及到表中的全部資料行,同時,第二個事務也修改這個表中的資料,這種修改是向表中插入一行新資料,那么,以后就會發生操作第一個事務的用戶發現表中還有沒有修改的資料行,就好象發生了幻覺一樣.
提醒:
臟讀:
一個事務讀取到另外一個事務沒有提交的修改資料
不可重復讀的重點是修改:
同樣的條件,你讀取過的資料,再次讀取出來發現值不一樣了
幻讀的重點在于新增或者洗掉:
同樣的條件,第 1 次和第 2 次讀出來的記錄數不一樣
| 隔離級別 | 臟讀 | 不可重復讀 | 幻讀 |
|---|---|---|---|
| READ-UNCOMMITTED | √ | √ | √ |
| READ-COMMITTED | × | √ | √ |
| REPEATABLE-READ | × | × | √ |
| SERIALIZABLE | × | × | × |
17、為什么要使用統一回傳類?
為什么要使用統一回傳類:
統一回傳值型別是介面開發中的一種良好的開發習慣(企業級開發基本都有),統一介面回傳值的目的是為了加快開發速率以及形成團隊良好的代碼規范
18、什么叫物理洗掉什么叫邏輯洗掉,分別適用于哪些場景?
物理洗掉:
物理洗掉是真正物理地址上的洗掉,是將資料從資料庫中移除的操作,也就是洗掉的一般意義,
資料被物理洗掉后在資料庫中就不在存在了,是無法(難以)被恢復的,
邏輯洗掉:
邏輯洗掉不是真正意義上的洗掉,而是邏輯意義上的洗掉,通常的實作方式是在資料表中添加一個欄位,比如deleted(是否洗掉,0未洗掉,1已洗掉),
資料被邏輯洗掉后在資料庫中依然是存在的,是可以(容易)被恢復的,
適用于哪些場景:
物理洗掉的場景: 資料不再有實際的意義,
邏輯洗掉的場景: 資料的失效屬于狀態的改變,比如訂單作廢,用戶禁用,員工離職,文稿廢棄,優惠券作廢,商品下架等,
小知識【1】邏輯洗掉和物理洗掉的區別:
https://blog.csdn.net/qq_39288456/article/details/84786980
19、為什么要使用swagger?
為什么要使用swagger:
隨著sprnigboot、springcloud等微服務的流行,在微服務的設計下,小公司微服務小的幾十,大公司大的幾百上萬的微服務,
這么多的微服務必定產生了大量的介面呼叫,而介面的呼叫就必定要寫介面檔案,
在微服務的盛行下,成千上萬的介面檔案撰寫,不可能靠人力來撰寫,故swagger就產生了,它采用自動化實作并解決了人力撰寫介面檔案的問題;
Swagger 提供了一個全新的維護 API 檔案的方式,有4大優點:
1.自動生成檔案:只需要少量的注解,Swagger 就可以根據代碼自動生成 API 檔案,很好的保證了檔案的時效性,
2.跨語言性,支持 40 多種語言,
3.Swagger UI 呈現出來的是一份可互動式的 API 檔案,我們可以直接在檔案頁面嘗試 API 的呼叫,省去了準備復雜的呼叫引數的程序,
4.還可以將檔案規范匯入相關的工具(例如 SoapUI), 這些工具將會為我們自動地創建自動化測驗,
20、使用springboot框架相較于之前的spring或者springmvc框架有哪些優勢?
springboot框架相較于之前的spring或者springmvc框架有哪些優勢:
Spring Boot實作了自動配置,降低了專案搭建的復雜度,
獨立運行的spring專案:
內嵌Tomcat或Jetty等Servlet容器;
無代碼生成和xml配置
準生產的應用監控
提供starter 簡化Maven 配置
集成了常用的第三方庫配置
Spring Boot優點:
1、Spring Boot實作了自動配置,降低了專案搭建的復雜度,:
眾所周知Spring框架需要進行大顯的配置,Spring Boot引入自動配置的概念,讓專案設定變得很容易,
自動配置 spring:Spring Boot 會根據在類路徑中的jar包,類,為jar包里的類自動配置Bean,這樣會極大減少我們要使用的配置,
2、獨立運行的spring專案:
Spring Boot可以以jar包形式直接運行,如java-jar xxxjar優點是:節省服務器資源
3、內嵌Tomcat或Jetty等Servlet容器;:
Spring Boot 可以選擇內嵌Tomcat,Jetty,這樣我們無須以war包形式部署專案,
4、無代碼生成和xml配置:
Spring Boot大量使用spring4.x提供的注解新特性來實作無代碼生成和xml 配置,spring4.x提倡使用Java配置和注解配置組合
Spring Boot不需要任何xml配置即可實作spring的所有配置,
5、準生產的應用監控:
Spring Boot 提供基于http,sh,telnet對運行時的專案進行監控
6、提供starter 簡化Maven 配置:
在Spring Boot 專案中為我們提供了很多的spring-boot-starter-xxx的專案,我們匯入指定的這些專案的坐標,就會自動匯入和該模塊相關的依賴包:
7、集成了常用的第三方庫配置:
集成了大星常用的第三方庫配置(例如Jackson,JDBC, Mongo, Redis, Mail等等),Spring Boot應用中這些第三方庫幾乎可以零配置的開箱即用,大部分的Spring Boot應用都只需要非常少量的配置代碼,開發者能夠更加專注于業務邏輯,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/523158.html
標籤:其他
