最近需要一些比较骚的操作,所以需要将gson编译成dex。
因为手上有jar包,所以就拿出了android sdk准备一把入魂,结果报错不断,让人无奈。只好根据报错来调整编译步骤,不得不为安卓环境更新Debug。
1、dx变d8
并不确定安卓更名的原因,但找到这个只是根据名字前面有个相同的d,这对于不太熟悉更新的人来说,只能靠蒙。
并不确定从哪个版本开始,dx.bat更新成了d8.bat。而且在使用中,命令方式也发生了变化,这个后面再讲。
所以,原来的dx --dex --output xxx.dex xxx.jar命令,不能使用了。
2、jre环境报错。
日常使用java的人,我觉得大多数人还是使用1.8。
不过随着各种软件,及编译环境的更新,java1.8的问题慢慢出现了,也出现了各种不兼容的情况。
只是到目前为止,还没有更新的动力。
这次编译,报错了:
Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.UnsupportedClassVersionError: com/android/tools/r8/D8 has been compiled by a more recent version of the Java Runtime (class file version 55.0), this version of the Java Runtime only recognizes class file versions up to 52.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(Unknown Source)
at java.security.SecureClassLoader.defineClass(Unknown Source)
at java.net.URLClassLoader.defineClass(Unknown Source)
at java.net.URLClassLoader.access$100(Unknown Source)
at java.net.URLClassLoader$1.run(Unknown Source)
at java.net.URLClassLoader$1.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at sun.launcher.LauncherHelper.checkAndLoadMain(Unknown Source)
报错就是说java1.8太老了,带不动了。
所以,切换java版本,运行了,继续报错。
3、命令换了
C:\Users\Administrator\Desktop\gson>d8
Exception in thread "main" java.lang.RuntimeException: Invalid invocation.
Usage: d8 [options] [@<argfile>] <input-files>
where <input-files> are any combination of dex, class, zip, jar, or apk files
and each <argfile> is a file containing additional arguments (one per line)
and options are:
--debug # Compile with debugging information (default).
--release # Compile without debugging information.
--output <file> # Output result in <file>.
# <file> must be an existing directory or a zip file.
--lib <file|jdk-home> # Add <file|jdk-home> as a library resource.
--classpath <file> # Add <file> as a classpath resource.
--min-api <number> # Minimum Android API level compatibility (default: 1).
--pg-map <file> # Use <file> as a mapping file for distribution.
--intermediate # Compile an intermediate result intended for later
# merging.
--file-per-class # Produce a separate dex file per class.
# Synthetic classes are in their own file.
--file-per-class-file # Produce a separate dex file per input .class file.
# Synthetic classes are with their originating class.
--no-desugaring # Force disable desugaring.
--desugared-lib <file> # Specify desugared library configuration.
# <file> is a desugared library configuration (json).
--desugared-lib-pg-conf-output <file>
# Output the Proguard configuration for L8 to <file>.
--main-dex-rules <file> # Proguard keep rules for classes to place in the
# primary dex file.
--main-dex-list <file> # List of classes to place in the primary dex file.
--main-dex-list-output <file>
# Output resulting main dex list in <file>.
--force-enable-assertions[:[<class name>|<package name>...]]
--force-ea[:[<class name>|<package name>...]]
# Forcefully enable javac generated assertion code.
--force-disable-assertions[:[<class name>|<package name>...]]
--force-da[:[<class name>|<package name>...]]
# Forcefully disable javac generated assertion code.
# This is the default handling of javac assertion code
# when generating DEX file format.
--force-passthrough-assertions[:[<class name>|<package name>...]]
--force-pa[:[<class name>|<package name>...]]
# Don't change javac generated assertion code. This
# is the default handling of javac assertion code when
# generating class file format.
--force-assertions-handler:<handler method>[:[<class name>|<package name>...]]
--force-ah:<handler method>[:[<class name>|<package name>...]]
# Change javac and kotlinc generated assertion code
# to invoke the method <handler method> with each
# assertion error instead of throwing it.
# The <handler method> is specified as a class name
# followed by a dot and the method name.
# The handler method must take a single argument of
# type java.lang.Throwable and have return type void.
--thread-count <number> # Use <number> of threads for compilation.
# If not specified the number will be based on
# heuristics taking the number of cores into account.
--map-diagnostics[:<type>] <from-level> <to-level>
# Map diagnostics of <type> (default any) reported as
# <from-level> to <to-level> where <from-level> and
# <to-level> are one of 'info', 'warning', or 'error'
# and the optional <type> is either the simple or
# fully qualified Java type name of a diagnostic.
# If <type> is unspecified, all diagnostics at
# <from-level> will be mapped.
# Note that fatal compiler errors cannot be mapped.
--android-platform-build
# Compile as a platform build where the runtime/bootclasspath
# is assumed to be the version specified by --min-api.
--art-profile <input> <output>
# Rewrite human readable ART profile read from <input> and write to <output>.
--startup-profile <file>
# Startup profile <file> to use for dex layout.
--version # Print the version of d8.
--help # Print this message.
最显著的变化有两个:
1、不再需要 --dex 命令
2、不能直接转化成.dex文件,需要zip或者jar后缀。