為什么編譯時會報 Unsupported major.minor version 51.0 錯誤?


2019-09-11

關鍵字:Android 大包編譯


 

搞 Android 系統開發的時候,常用的編譯模塊的命令無非就兩條:

mm
mmm

 

但有的時候卻發現,以前用的好好的編譯命令,突然就報錯了。比如:

Exception in thread "main" java.lang.UnsupportedClassVersionError: com/android/signapk/SignApk : Unsupported major.minor version 51.0
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
    at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
Could not find the main class: com.android.signapk.SignApk. Program will exit.
make: *** [out/target/product/rk3288/obj/APPS/GPIOAPI_intermediates/package.apk] Error 1

 

最后翻遍一眾博客並經過一頓思考,終尋得答案:編譯環境中的 JDK 版本有問題

 

從這個異常棧信息字面意思來看是 SignApk 這個程序所能支持的最小版本號越界了。SignApk 是干嘛的我暫時還不知道,不過我知道有一個 SignApk.jar,它是用來給編譯出來的 APK 簽名用的。也許這個 SignApk 也有差不多的作用吧。不過這並不重要。

 

既然異常信息棧中有提到因為 java 的 class loader 因版本越界而報錯,那我們就來看看當前系統的 PATH 信息:

$echo $PATH

/opt/jdk1.6.0_29//bin: ... :/opt/jdk1.6.0_29//bin:/opt/jdk1.6.0_29/jre/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games

這里可以很明顯地看到筆者所使用的系統環境下只引入了 JDK6,而剛好筆者在開發的 Android 系統是 5.1 的,這個版本的 Android 系統要求 JDK 版本至少要達到 7。這當然要報版本越界錯誤的嘛。

 

既然問題的原因搞清楚了,那解決的辦法自然也是很簡單了。

 

最快速、應急式的解決辦法,就是手動將 JDK7 的路徑引入到系統 PATH 中。

 

例如,筆者所使用的編譯服務器下已經安裝有 JDK7 的軟件了,它的路徑為:

/opt/jdk1.7.0_65/

所以,只需要使用如下命令手動添加 JDK7 的路徑進 PATH 即可:

export PATH=/opt/jdk1.7.0_65/bin:$PATH

 

這個時候可以再檢查一個 PATH 的信息,確認這個 JDK7 的路徑被應用上去了。

 

這個時候,再來編譯,就發現不會再報版本異常的錯誤了。

 

---

 

這里再貼一下上面異常棧中提到的 51.0 版本號與 JDK 版本號之間的對應關系

1.1  --->  45

1.2  --->  46

1.3  --->  47

1.4  --->  48

1.5  --->  49

1.6  --->  50

1.7  --->  51

1.8  --->  52

 

如果我們打一開始就知道這個 51.0 指代的就是 JDK1.7 版本,那肯定立馬就能想到是自己當前編譯鏈中的 JDK 版本有問題了。所以,適當的了解一下這些對應關系還是有一定幫助作用的。

 


 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM