中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-07-21 13:53:37 來源:億速云 閱讀:569 作者:小新 欄目:編程語言

這篇文章將為大家詳細講解有關如何解決使用IDEA異常斷點來定位java.lang.ArrayStoreException的問題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

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

啟動程序時拋出如下異常,導致啟動失敗

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]
...

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

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

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

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

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

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

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

2. 程序debug

開始以Debug模式啟動程序。 程序運行后,在前面配置的異常出現時,將會進行阻斷,如圖

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

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

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

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

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

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

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

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

關于“如何解決使用IDEA異常斷點來定位java.lang.ArrayStoreException的問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

神木县| 海淀区| 金坛市| 方山县| 新巴尔虎右旗| 五台县| 镇沅| 西充县| 正定县| 宁明县| 望奎县| 利津县| 浏阳市| 五家渠市| 太仓市| 松桃| 平泉县| 博客| 洞头县| 上虞市| 德州市| 临沧市| 宾川县| 贵州省| 衡南县| 固镇县| 密山市| 且末县| 年辖:市辖区| 长汀县| 高碑店市| 白沙| 伊川县| 香港| 高台县| 沙坪坝区| 商城县| 乐东| 大连市| 泰宁县| 茂名市|