Java Jar 在 Android 中不起作用
Java Jar does not work in Android
我写了一个小的 Java 应用程序,我编译成一个可执行的 jar 文件。该程序使用在 jar 文件中编译的 .txt 文件。为了访问 jar 中的 .txt 文件,您需要使用 ClassLoader.getSystemResourceAsSteam("");
jar文件中的方法如下:
private ArrayList<String> loadChainRestaurantsList() throws IOException {
ArrayList chains = new ArrayList();
InputStream in = ClassLoader.getSystemResourceAsStream("chains.txt");
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
String name;
while((name = reader.readLine()) != null) {
chains.add(name);
}
return chains;
}
如果我 运行 来自 cmd 行的 jar 作为独立的 Java 程序或来自 Eclipse,则此代码有效。如果我导出为 jar 然后将其放入另一个 Java 程序并使用它,它甚至可以正常工作,它可以按预期工作。问题是当我把罐子扔进一个 Android 项目时。我收到此错误:
FATAL EXCEPTION: AsyncTask #1
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: Process: com.jasonjohn.unchainedandroid, PID: 8821
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: java.lang.RuntimeException: An error occured while executing doInBackground()
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at android.os.AsyncTask.done(AsyncTask.java)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.FutureTask.run(FutureTask.java:242)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at android.os.AsyncTask$SerialExecutor.run(AsyncTask.java)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.lang.Thread.run(Thread.java:818)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: Caused by: java.lang.NullPointerException: lock == null
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.io.Reader.<init>(Reader.java:64)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.io.InputStreamReader.<init>(InputStreamReader.java:120)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.io.InputStreamReader.<init>(InputStreamReader.java:57)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at com.jasonjohn.unchainedapi.UnchainedAPI.loadChainRestaurantsList(UnchainedAPI.java:123)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at com.jasonjohn.unchainedapi.UnchainedAPI.getUnchainedRestaurants(UnchainedAPI.java:71)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at com.jasonjohn.unchainedandroid.MainActivity$UnchainedAsync.doInBackground(MainActivity.java:69)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at com.jasonjohn.unchainedandroid.MainActivity$UnchainedAsync.doInBackground(MainActivity.java:62)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at android.os.AsyncTask.call(AsyncTask.java)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.FutureTask.run(FutureTask.java:237)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at android.os.AsyncTask$SerialExecutor.run(AsyncTask.java)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.lang.Thread.run(Thread.java:818)
我以前从未见过这个错误。任何人都可以解释发生了什么事吗?我假设 InputStream/InputStreamReader 为空,但我不知道如何解决这个问题。
你可能应该使用
getResourceAsStream("/chains.txt")
而不是使用
getSystemResourceAsStream(...).
路径前面的/表示在jar的根目录中查找。否则,它将在与您从中获得 classloader 的 class 相同的包中查找 chains.txt。例如,如果你这样做:
package com.potter.harry;
...
InputStream is = this.getClass().getResourceAsStream("chains.txt");
引用的文件必须放在“/com/potter/harry/chains.txt”
在 zip 文件中。
我写了一个小的 Java 应用程序,我编译成一个可执行的 jar 文件。该程序使用在 jar 文件中编译的 .txt 文件。为了访问 jar 中的 .txt 文件,您需要使用 ClassLoader.getSystemResourceAsSteam("");
jar文件中的方法如下:
private ArrayList<String> loadChainRestaurantsList() throws IOException {
ArrayList chains = new ArrayList();
InputStream in = ClassLoader.getSystemResourceAsStream("chains.txt");
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
String name;
while((name = reader.readLine()) != null) {
chains.add(name);
}
return chains;
}
如果我 运行 来自 cmd 行的 jar 作为独立的 Java 程序或来自 Eclipse,则此代码有效。如果我导出为 jar 然后将其放入另一个 Java 程序并使用它,它甚至可以正常工作,它可以按预期工作。问题是当我把罐子扔进一个 Android 项目时。我收到此错误:
FATAL EXCEPTION: AsyncTask #1
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: Process: com.jasonjohn.unchainedandroid, PID: 8821
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: java.lang.RuntimeException: An error occured while executing doInBackground()
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at android.os.AsyncTask.done(AsyncTask.java)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.FutureTask.run(FutureTask.java:242)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at android.os.AsyncTask$SerialExecutor.run(AsyncTask.java)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.lang.Thread.run(Thread.java:818)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: Caused by: java.lang.NullPointerException: lock == null
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.io.Reader.<init>(Reader.java:64)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.io.InputStreamReader.<init>(InputStreamReader.java:120)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.io.InputStreamReader.<init>(InputStreamReader.java:57)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at com.jasonjohn.unchainedapi.UnchainedAPI.loadChainRestaurantsList(UnchainedAPI.java:123)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at com.jasonjohn.unchainedapi.UnchainedAPI.getUnchainedRestaurants(UnchainedAPI.java:71)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at com.jasonjohn.unchainedandroid.MainActivity$UnchainedAsync.doInBackground(MainActivity.java:69)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at com.jasonjohn.unchainedandroid.MainActivity$UnchainedAsync.doInBackground(MainActivity.java:62)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at android.os.AsyncTask.call(AsyncTask.java)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.FutureTask.run(FutureTask.java:237)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at android.os.AsyncTask$SerialExecutor.run(AsyncTask.java)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
10-01 10:40:59.650 8821-8879/? E/AndroidRuntime: at java.lang.Thread.run(Thread.java:818)
我以前从未见过这个错误。任何人都可以解释发生了什么事吗?我假设 InputStream/InputStreamReader 为空,但我不知道如何解决这个问题。
你可能应该使用
getResourceAsStream("/chains.txt")
而不是使用
getSystemResourceAsStream(...).
路径前面的/表示在jar的根目录中查找。否则,它将在与您从中获得 classloader 的 class 相同的包中查找 chains.txt。例如,如果你这样做:
package com.potter.harry;
...
InputStream is = this.getClass().getResourceAsStream("chains.txt");
引用的文件必须放在“/com/potter/harry/chains.txt” 在 zip 文件中。