亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用IDEA異常斷點來定位java.lang.ArrayStoreException的問題

 更新時間:2021年12月24日 14:31:13   作者:空山新雨  
這篇文章主要介紹了使用IDEA異常斷點來定位java.lang.ArrayStoreException的問題,平常開發(fā)過程中面對這種描述不夠清楚,無法定位具體原因的問題該如何處理,下面我們來一起學(xué)習(xí)一下吧

前言

最近對 base-spring-boot?項目進(jìn)行了升級。在將其用于應(yīng)用開發(fā)中時遇到j(luò)ava.lang.ArrayStoreException的異常導(dǎo)致程序無法啟動。平常開發(fā)過程中面對這種描述不夠清楚,無法定位具體原因的問題該如何處理?本文分享通過使用IDEA異常斷點來定位此類問題的方法。

啟動程序時拋出如下異常,導(dǎo)致啟動失敗

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'devGlobalExceptionHandler' defined in class path resource [cn/jboost/springboot/autoconfig/error/exception/ExceptionHandlerAutoConfiguration.class]: Post-processing of merged bean definition failed; nested exception is java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:570) ~[spring-beans-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:515) ~[spring-beans-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:320) ~[spring-beans-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222) ~[spring-beans-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:318) ~[spring-beans-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199) ~[spring-beans-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:843) ~[spring-beans-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:877) ~[spring-context-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:549) ~[spring-context-5.1.7.RELEASE.jar:5.1.7.RELEASE]
at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:142) ~[spring-boot-2.1.5.RELEASE.jar:2.1.5.RELEASE]
at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:775) [spring-boot-2.1.5.RELEASE.jar:2.1.5.RELEASE]
at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:397) [spring-boot-2.1.5.RELEASE.jar:2.1.5.RELEASE]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:316) [spring-boot-2.1.5.RELEASE.jar:2.1.5.RELEASE]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1260) [spring-boot-2.1.5.RELEASE.jar:2.1.5.RELEASE]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1248) [spring-boot-2.1.5.RELEASE.jar:2.1.5.RELEASE]
at com.cnbot.kindergarten.CnbotKindergartenApplication.main(CnbotKindergartenApplication.java:10) [classes/:na]
Caused by: java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy
at sun.reflect.annotation.AnnotationParser.parseClassArray(AnnotationParser.java:724) ~[na:1.8.0_201]
at sun.reflect.annotation.AnnotationParser.parseArray(AnnotationParser.java:531) ~[na:1.8.0_201]
at sun.reflect.annotation.AnnotationParser.parseMemberValue(AnnotationParser.java:355) ~[na:1.8.0_201]
at sun.reflect.annotation.AnnotationParser.parseAnnotation2(AnnotationParser.java:286) ~[na:1.8.0_201]
at sun.reflect.annotation.AnnotationParser.parseAnnotations2(AnnotationParser.java:120) ~[na:1.8.0_201]
at sun.reflect.annotation.AnnotationParser.parseAnnotations(AnnotationParser.java:72) ~[na:1.8.0_201]
...

單純看異常棧,無法定位問題原因,只能看到是在調(diào)用devGlobalExceptionHandler創(chuàng)建bean時出錯,錯誤信息java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy。

這屬于框架內(nèi)部拋出的異常,通常的設(shè)置斷點Debug的方法很難定位到具體原因,可通過IDEA的異常斷點來進(jìn)行定位,它會在程序運(yùn)行過程中出現(xiàn)指定異常時進(jìn)行阻斷。

1. 添加異常斷點
在IDEA的Debug面板中,點擊“View Breakpoints”(兩個重疊的紅色圈按鈕),如下

打開“Breakpoints”窗口,在該窗口中點擊“+”按鈕,選擇“Java Exception Breakpoints”, 如下圖

然后在彈出的“Enter Exception Class”窗口中輸入ArrayStoreException選中對應(yīng)異常,依次點擊OK,Done按鈕即完成異常斷點添加。

2. 程序debug

開始以Debug模式啟動程序。 程序運(yùn)行后,在前面配置的異常出現(xiàn)時,將會進(jìn)行阻斷,如圖

可以看到程序阻斷在上圖高亮的那行代碼處,異常便是從這里拋出的。查看parseClassValue方法,可看到這里有catchTypeNotPresentException異常,并且包裝成我們在異常??吹降腡ypeNotPresentExceptionProxy返回。離真相很近了。

我們可以在上述catch塊中添加一個斷點,查看異常包裝前的狀態(tài),如圖

重新Debug運(yùn)行,將定位到上圖代碼處,查看異常,看到如下圖所示信息

該信息表示org.springframework.security.access.AccessDeniedException這個類不存在,導(dǎo)致BaseWebApplicationExceptionHandler類型的bean實例化時出錯。這時候問題基本已經(jīng)定位到了。

查看源碼,在BaseWebApplicationExceptionHandler中有對AccessDeniedException的統(tǒng)一處理,但是spring-boot-autoconfigure所有的依賴都是optional的(不會傳遞依賴),而在新開發(fā)的項目中,并沒有引入spring-security,因此導(dǎo)致AccessDeniedException這個類找不到而報錯。目前通過去掉該部分處理解決。

總結(jié)

IDEA的Debug支持好幾種斷點類型,如前文介紹的異常斷點,以及比較常用的條件斷點等。當(dāng)無法從異常棧信息找到問題所在時,借用這些類型的斷點進(jìn)行Debug,往往事情就變得簡單了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Docker 部署 SpringBoot 項目整合 Redis 鏡像做訪問計數(shù)示例代碼

    Docker 部署 SpringBoot 項目整合 Redis 鏡像做訪問計數(shù)示例代碼

    這篇文章主要介紹了Docker 部署 SpringBoot 項目整合 Redis 鏡像做訪問計數(shù)Demo,本文給大家介紹的非常詳細(xì),具有參考借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Spring Boot文件上傳原理與實現(xiàn)詳解

    Spring Boot文件上傳原理與實現(xiàn)詳解

    這篇文章主要介紹了Spring Boot 文件上傳原理與實現(xiàn)詳解,前端文件上傳是面向多用戶的,多用戶之間可能存在上傳同一個名稱、類型的文件;為了避免文件沖突導(dǎo)致的覆蓋問題這些應(yīng)該在后臺進(jìn)行解決,需要的朋友可以參考下
    2024-01-01
  • SpringBoot整合redis使用緩存注解詳解

    SpringBoot整合redis使用緩存注解詳解

    這篇文章主要介紹了SpringBoot整合redis使用緩存注解詳解,@Cacheable在方法執(zhí)行前判斷對應(yīng)緩存是否存在,如果存在直接返回緩存結(jié)果,否者執(zhí)行方法將結(jié)果緩存,適用于查詢類,需要的朋友可以參考下
    2024-01-01
  • Spring Boot 統(tǒng)一數(shù)據(jù)返回格式的解決方案

    Spring Boot 統(tǒng)一數(shù)據(jù)返回格式的解決方案

    統(tǒng)?的數(shù)據(jù)返回格式使? @ControllerAdvice 和 ResponseBodyAdvice 的?式實現(xiàn),下面給大家分享Spring Boot 統(tǒng)一數(shù)據(jù)返回格式的解決方案,感興趣的朋友一起看看吧
    2024-03-03
  • 使用java實現(xiàn)網(wǎng)絡(luò)爬蟲

    使用java實現(xiàn)網(wǎng)絡(luò)爬蟲

    這篇文章主要介紹了使用java實現(xiàn)網(wǎng)絡(luò)爬蟲,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • java根據(jù)富文本生成pdf文件過程解析

    java根據(jù)富文本生成pdf文件過程解析

    這篇文章主要介紹了java根據(jù)富文本生成pdf文件過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • Java設(shè)計模式之java組合模式詳解

    Java設(shè)計模式之java組合模式詳解

    這篇文章主要介紹了JAVA設(shè)計模式之組合模式,簡單說明了組合模式的原理,并結(jié)合實例分析了java組合模式的具體用法,需要的朋友可以參考下
    2021-09-09
  • javaWeb自定義標(biāo)簽用法實例詳解

    javaWeb自定義標(biāo)簽用法實例詳解

    這篇文章主要介紹了javaWeb自定義標(biāo)簽用法,結(jié)合實例形式分析了javaweb自定義標(biāo)簽的功能、定義方法及執(zhí)行原理,需要的朋友可以參考下
    2017-04-04
  • Java單例模式的五種實現(xiàn)方式

    Java單例模式的五種實現(xiàn)方式

    單例模式(Singleton Pattern)是Java中最簡單的設(shè)計模式之一,這種類型的設(shè)計模式屬于創(chuàng)建型模式,它提供了一種創(chuàng)建對象的最佳方式,下面這篇文章主要給大家介紹了關(guān)于Java單例模式的五種實現(xiàn)方式?,需要的朋友可以參考下
    2022-06-06
  • SpringCloud中的Stream服務(wù)間消息傳遞詳解

    SpringCloud中的Stream服務(wù)間消息傳遞詳解

    這篇文章主要介紹了SpringCloud中的Stream服務(wù)間消息傳遞詳解,Stream 就是在消息隊列的基礎(chǔ)上,對其進(jìn)行封裝,可以是我們更方便的去使用,Stream應(yīng)用由第三方的中間件組成,應(yīng)用間的通信通過輸入通道和輸出通道完成,需要的朋友可以參考下
    2024-01-01

最新評論