2011-12-21 72 views
0

我有c和c + +中的現有代碼。我在Android.mk文件中添加了這些c文件和cpp文件。我已經在我的應用程序中成功創建了名爲itv.so的.so文件。但現在當我試圖運行Android應用程序是顯示錯誤一樣...java.lang.ExceptionInInitializerError導致:java.lang.UnsatisfiedLinkError:庫未找到

12-20 13:26:31.362: E/AndroidRuntime(716): FATAL EXCEPTION: main 
12-20 13:26:31.362: E/AndroidRuntime(716): java.lang.ExceptionInInitializerError 
12-20 13:26:31.362: E/AndroidRuntime(716): at com.example.Internet_TV12.onCreate(Internet_TV12.java:38) 
12-20 13:26:31.362: E/AndroidRuntime(716): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
12-20 13:26:31.362: E/AndroidRuntime(716): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 
12-20 13:26:31.362: E/AndroidRuntime(716): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 
12-20 13:26:31.362: E/AndroidRuntime(716): at android.app.ActivityThread.access$2300(ActivityThread.java:125) 
12-20 13:26:31.362: E/AndroidRuntime(716): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 
12-20 13:26:31.362: E/AndroidRuntime(716): at android.os.Handler.dispatchMessage(Handler.java:99) 
12-20 13:26:31.362: E/AndroidRuntime(716): at android.os.Looper.loop(Looper.java:123) 
12-20 13:26:31.362: E/AndroidRuntime(716): at android.app.ActivityThread.main(ActivityThread.java:4627) 
12-20 13:26:31.362: E/AndroidRuntime(716): at java.lang.reflect.Method.invokeNative(Native Method) 
12-20 13:26:31.362: E/AndroidRuntime(716): at java.lang.reflect.Method.invoke(Method.java:521) 
12-20 13:26:31.362: E/AndroidRuntime(716): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
12-20 13:26:31.362: E/AndroidRuntime(716): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
12-20 13:26:31.362: E/AndroidRuntime(716): at dalvik.system.NativeStart.main(Native Method) 
12-20 13:26:31.362: E/AndroidRuntime(716): Caused by: java.lang.UnsatisfiedLinkError: Library itv not found 
12-20 13:26:31.362: E/AndroidRuntime(716): at java.lang.Runtime.loadLibrary(Runtime.java:461) 
12-20 13:26:31.362: E/AndroidRuntime(716): at java.lang.System.loadLibrary(System.java:557) 
12-20 13:26:31.362: E/AndroidRuntime(716): at com.example.Display.<clinit>(Display.java:69) 
12-20 13:26:31.362: E/AndroidRuntime(716): ... 14 more 

我不知道爲什麼這個錯誤即將到來。我已經看到lib文件夾裏有libitv.so文件。 我也試過

static { 
     try { 
      System.loadLibrary("itv"); 
      // System.load("/data/data/com/example/lib/itv.so"); 
     } 
     catch (UnsatisfiedLinkError use) { 
       Log.e("JNI", "WARNING: Could not load itv.so"); 
      } 
     } 

但是得到同樣的錯誤。 任何人都可以告訴我這個錯誤的解決方案。 先謝謝您。

+0

檢查這個職位http://stackoverflow.com/a/5367617/760489 – Pratik 2011-12-21 06:39:41

回答

7

該庫將被識別,如果它的名字是libitv.so是在構建.apk之前,將其放置在應用程序目錄中的libs \ armeabi目錄中。

有時,當庫沒有完全複製(部分複製)時,由於某些系統問題,部分庫也無法識別。

+0

感謝您的回覆...這可能是原因...但我該如何解決這個問題...你可以告訴我嗎? – geeta 2011-12-21 07:22:12

+0

爲了確保你能檢查你建立的地方和你複製的路徑的庫的大小? – Deepak 2011-12-21 10:35:39

+0

+1正確指示 – Sameer 2013-09-12 08:57:17

2

嘗試命名的實際文件libitv.so(LIB庫+姓名+的.so),並把它在你的庫目錄的文件夾armeabi

+1

感謝您的回覆。我已經嘗試了實際的文件名libitv.so ...但同樣的錯誤我越來越... – geeta 2011-12-21 07:20:49

+0

你在Mac上也許? – zienkikk 2011-12-21 07:29:12

+1

不,我在Windows ... – geeta 2011-12-21 07:31:02

相關問題