Java AbstractMethodError原因案例詳解
背景
AbstractMethodError異常對于我來說還是比較不常遇見的,最近有幸遇到,并僥幸的解決了,在這里把此種場景剖析一番,進(jìn)入正題,下面是AbstractMethodError在Java的異常機(jī)制中所處的位置:
現(xiàn)在明確了AbstractMethodError所具有的特性:
1.它是Error的子類,Error類及其子類都是被劃分在非檢查異常之列的,就是說這些異常不能在編譯階段被檢查出來,只能在運(yùn)行時(shí)才會觸發(fā)。
2.通過API文檔里面的解釋大致得出的結(jié)論就是說A依賴于B,但是執(zhí)行的時(shí)候發(fā)現(xiàn)類B的定義發(fā)生了改變,這個(gè)改變是針對編譯的時(shí)候發(fā)生了改變,也就是說將類A由java文件編譯成.class文件的時(shí)候用到了類B的class文件,但是在執(zhí)行的時(shí)候JVM發(fā)現(xiàn)真正用到的B的class文件和編譯的時(shí)候用的不是一個(gè)了。于是這個(gè)異常就被拋了出來。
至此,AbstractMethodError發(fā)生的底層原因也了解的差不多了,再往深層的話就是java的編譯機(jī)制,以及java代碼的執(zhí)行檢查這些更靠近虛擬機(jī)的東東,那些我也沒什么研究,暫且不表。
底層原因了解了,我們繼續(xù)談下平常遇到的更直觀的場景:
ClassA ->AbstractClassB ClassA 依賴于AbstractClassB,通常A是我們自己開發(fā)的類,而B則是引用的第三方j(luò)ar包里面的抽象類。我們的項(xiàng)目中又存在AbstractClassB的多個(gè)實(shí)現(xiàn)版本,比如:1.0,1.2,2.0等版本,通常主版本號發(fā)生了改變的話,一般都是不兼容的。
類A
class A { B dependency = new BImpl(); public void testMethod(){ dependency.changedMethodInDifVersion(arg1, arg2); } }
1.0版本的AbstractClassB:
abstract class B { // v1.0 public abstract void changedMethodInDifVersion(int arg1); } class BImpl extends B{ public void changedMethodInDifVersion(int arg1){ System.out.prinln("我是AbstractClassB 的 1.0 版本實(shí)現(xiàn),Class A編譯的時(shí)候我沒參與,但是Class A運(yùn)行的時(shí)候我卻參與了。"); } }
2.0版本的AbstractClassB:
abstract class B { //v2.0 public abstract void changedMethodInDifVersion(int arg1, String arg2); } class BImpl extends B{ public void changedMethodInDifVersion(int arg1, String arg2){ System.out.prinln("我是AbstractClassB 的 2.0 版本實(shí)現(xiàn),編譯的時(shí)候是我參與了編譯"); } }
如果在編譯的時(shí)候使用的2.0版本中的BImpl和2.0版本的AbstractClassB,然而執(zhí)行的時(shí)候使用的又是1.0版本的BImpl,那么就會拋出AbstractMethodError,這個(gè)異常拋出以后會把運(yùn)行時(shí)真正找到的那個(gè)方法簽名給打印出來的,異常信息會入下:
Exception in Thread XXXXX java.lang.AbstractMehodError package.Class.運(yùn)行時(shí)實(shí)際找到的方法
這個(gè)時(shí)候在你的classpath中尋找這個(gè)類,剔除掉不需要的版本就可以了。
如果在編譯的時(shí)候使用的2.0版本中的BImpl和2.0版本的AbstractClassB,然而執(zhí)行的時(shí)候使用的又是1.0版本的BImpl 和 1.0版本的AbstractClassB,就會報(bào)NoSuchMethodError。
到此這篇關(guān)于Java AbstractMethodError原因案例詳解的文章就介紹到這了,更多相關(guān)Java AbstractMethodError內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解Matisse與Glide--java.lang.NoSuchMethodError:com.bumptech.glide.RequestManager.load
- Java異常 Factory method''sqlSessionFactory''rew exception;ested exception is java.lang.NoSuchMethodError:
- 解決啟動(dòng)Azkaban報(bào)錯(cuò)問題:java.lang.NoSuchMethodError: com.google.common.collect.ImmutableMap.toImmutableMap
- 解決 java.lang.NoSuchMethodError的錯(cuò)誤
- java.lang.AbstractMethodError: org.apache.xerces.dom.DocumentImpl.setXmlVersion問題解決方法
- Java AbstractMethodError案例分析詳解
相關(guān)文章
一文掌握Spring?中?@Component?和?@Bean?區(qū)別(最新推薦)
?@Component?用于標(biāo)識一個(gè)普通的類,@Bean用于配置類里面,在方法上面聲明和配置?Bean?對象,這篇文章主要介紹了Spring?中?@Component?和?@Bean?區(qū)別(最新推薦),需要的朋友可以參考下2024-04-04解決mybatis 數(shù)據(jù)庫date 與 java中Date類型映射問題
這篇文章主要介紹了解決mybatis 數(shù)據(jù)庫date 與 java中Date類型映射問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來吧2020-11-11vue+springboot+shiro+jwt實(shí)現(xiàn)登錄功能
這篇文章主要介紹了vue+springboot+shiro+jwt實(shí)現(xiàn)登錄功能,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04Springboot項(xiàng)目優(yōu)雅地處理日志的方法詳解
這篇文章主要介紹了Springboot項(xiàng)目---優(yōu)雅地處理日志,本文通過實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-07-07Springboot 整合通用mapper和pagehelper展示分頁數(shù)據(jù)的問題(附github源碼)
這篇文章主要介紹了Springboot 整合通用mapper和pagehelper展示分頁數(shù)據(jù)(附github源碼),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09Java:不支持發(fā)行版本5的超詳細(xì)簡單解決方案
發(fā)行版本5是Java5,已經(jīng)是十多年前的版本了,現(xiàn)在已經(jīng)不再被支持,如果您使用的是舊版的Java開發(fā)工具,可能會出現(xiàn)這樣的錯(cuò)誤,這篇文章主要給大家介紹了關(guān)于Java:不支持發(fā)行版本5的超詳細(xì)簡單解決方案,需要的朋友可以參考下2024-01-01