2011-12-21 3 views
0

У меня есть существующий код в c и C++. Я добавил эти файлы c и файлы cpp в файл Android.mk. И я успешно создал файлы .so с именем itv.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"); 
      } 
     } 

Но получить такую ​​же ошибку. Может кто-нибудь, пожалуйста, скажите мне решение этой ошибки. Благодарим вас в Advance.

+0

проверить это сообщение http://stackoverflow.com/a/5367617/760489 – Pratik

ответ

7

Библиотека будет признана, если его имя libitv.so и помещается в каталог libs \ armeabi в каталоге приложения, прежде чем будет создан .apk.

Иногда, когда библиотека не копируется полностью (частичная копия), из-за некоторых проблем системы неполная библиотека тоже не будет распознана.

+0

Спасибо за ответ ... Это может быть причина ... Но как я могу решить эту проблему ... Можете ли вы, пожалуйста, сказать мне? – geeta

+0

Не забудьте проверить размеры библиотек в том месте, где вы строили, и путь, на который вы скопировали? – Deepak

+0

+1 для правильной индикации – Sameer

2

Попробуйте назвать фактический файл libitv.so (Lib + имя библиотеки + .so) и положить его в папку armeabi каталога ЛИЭС

+1

Спасибо за ваш ответ. Я пробовал по фактическому имени файла libitv.so ... Но такая же ошибка я получаю ... – geeta

+0

Возможно, вы на Mac? – zienkikk

+1

Нет Я нахожусь в Windows ... – geeta