我有一个 Android 应用程序项目 (A) 和一个 Android 库项目 (L)。A 使用 L 作为库。
L 库项目已经使用了一些外部库:Apache Commons Codec 1.7、Apache Commons Lang3 3.1、Android 支持库 V4 和 ActionBarSherlock 4.0,作为库项目引用。所有这些库以及调用它们的代码都可以正常工作,并且已经正常工作了一段时间。
但是,我最近又添加了一个库:Apache Commons IO 2.4。现在,每当库代码(在 L 中)尝试调用 Commons IO 中的方法时,我的应用程序就会崩溃。
我添加 IO 库的方式与添加其他所有外部库的方式完全相同:
当我的应用程序第一次启动时,我得到:
11-01 12:32:14.243: I/dalvikvm(3815): Could not find method org.apache.commons.io.FileUtils.copyInputStreamToFile, referenced from method au.com.grdc.alib.helpers.LibraryCommon.download
11-01 12:32:14.243: W/dalvikvm(3815): VFY: unable to resolve static method 7039: Lorg/apache/commons/io/FileUtils;.copyInputStreamToFile (Ljava/io/InputStream;Ljava/io/File;)V
后来我得到:
11-01 14:50:48.913: E/AndroidRuntime(10030): FATAL EXCEPTION: AsyncTask #1
11-01 14:50:48.913: E/AndroidRuntime(10030): java.lang.RuntimeException: An error occured while executing doInBackground()
...
11-01 12:35:10.268: E/AndroidRuntime(4493): Caused by: java.lang.NoClassDefFoundError: org.apache.commons.io.FileUtils
11-01 12:35:10.268: E/AndroidRuntime(4493): at au.com.grdc.alib.helpers.LibraryCommon.download(LibraryCommon.java:89)
我看到有人建议将我的“lib”文件夹重命名为“libs”,我已经这样做了——这并没有解决问题。
我还看到了标记要导出的外部库的建议,我也这样做了,但也没有解决问题。