2014-01-24 28 views
3

我正在嘗試在新項目Android中測試此緩存庫。
當我運行該項目,我得到這樣的logcat:
Project FilesHttpResponseCache和DiskLruCache的java.lang.NoClassDefFoundError

這是我MainActivity.java:

01-24 03:45:31.109: E/AndroidRuntime(1983): FATAL EXCEPTION: main 
01-24 03:45:31.109: E/AndroidRuntime(1983): Process: com.test_cache, PID: 1983 
01-24 03:45:31.109: E/AndroidRuntime(1983): java.lang.NoClassDefFoundError: com.jakewharton.DiskLruCache 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at com.integralblue.httpresponsecache.compat.libcore.net.http.HttpResponseCache.<init>(HttpResponseCache.java:83) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at com.integralblue.httpresponsecache.HttpResponseCache.<init>(HttpResponseCache.java:155) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at com.integralblue.httpresponsecache.HttpResponseCache.install(HttpResponseCache.java:192) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at com.test_cache.MainActivity.onCreate(MainActivity.java:21) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.app.Activity.performCreate(Activity.java:5243) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2140) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.app.ActivityThread.access$700(ActivityThread.java:135) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.os.Handler.dispatchMessage(Handler.java:102) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.os.Looper.loop(Looper.java:137) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at android.app.ActivityThread.main(ActivityThread.java:4998) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at java.lang.reflect.Method.invokeNative(Native Method) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at java.lang.reflect.Method.invoke(Method.java:515) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593) 
01-24 03:45:31.109: E/AndroidRuntime(1983):  at dalvik.system.NativeStart.main(Native Method) 

我在libs文件夾複製從項目HttpResponseCache by Craig AndrewsDiskLruCache by Jake Wharton兩個罐子

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    final long httpCacheSize = 10 * 1024 * 1024; // 10 MiB 
    final File httpCacheDir = new File(getCacheDir(), "http"); 

    try { 
     com.integralblue.httpresponsecache.HttpResponseCache.install(httpCacheDir, httpCacheSize); 
    } catch (IOException e) { 
     // TODO Auto-generated catch block 
     e.printStackTrace(); 
    }   
} 

我在其他線程看到它是訂單問題,所以在訂單&在Java構建路徑導出選項卡,我把這個排在首位: Build Path
Order and Export

我打掃proyect,重建並沒有什麼工作,問題仍然存在...
任何想法...?

謝謝。

回答

3

因爲使用disklrucache-2.0.2.jarhttpresponsecache-1.3.jar

在圖書館httpresponsecache-1.3.jar使用disklrucache-1.2.1.jar

disklrucache-1.2.1.jar該軟件包是:com.jakewharton但在2.0.2版中該軟件包更改爲com.j akewharton.disklrucache

這是根本原因。

如果你想使用disklrucache你應該使用1.2.1版

你可以從這裏下載:http://www.mediafire.com/download/e2q4vz7kdlwxxr3/disklrucache-1.2.1.jar(.jar)文件

或源文件:https://www.mediafire.com/?933nqqe9j4227cc(.jar)文件

希望這可以幫到你。

enter image description here

+0

BRI-LLI-ANT !!這讓我瘋狂。非常非常感謝你! – Randolf

+0

歡迎。使用java lib時請小心。 :) – Luc