[삽질경험] crash at com.android.tools.profiler.support.ProfilerService.<clinit>(ProfilerService.java:44)

android 2017. 11. 6. 14:10

336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

Android Studio 3.0으로 업데이트를 하였는데.. 

구현단말기에서 아래와 같은 실행시 오류가 발생할때의 조치법. 


[crash callstack] 

D/dalvikvm: Trying to load lib /mnt/asec/[[packagename]]-1/lib/libsupportjni.so 0x41b13f30

E/dalvikvm: dlopen("/mnt/asec/[[packagename]]-1/lib/libsupportjni.so") failed: dlopen failed: cannot locate symbol "strtof" referenced by "libsupportjni.so"...

W/dalvikvm: Exception Ljava/lang/UnsatisfiedLinkError; thrown while initializing Lcom/android/tools/profiler/support/ProfilerService;

D/AndroidRuntime: Shutting down VM

W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0x41659ce0)

E/AndroidRuntime: FATAL EXCEPTION: main

              Process: [[packagename]], PID: 7500

              java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "strtof" referenced by "libsupportjni.so"...

                  at java.lang.Runtime.loadLibrary(Runtime.java:364)

                  at java.lang.System.loadLibrary(System.java:526)

                  at com.android.tools.profiler.support.ProfilerService.<clinit>(ProfilerService.java:44)

                  at [[packagename]].App.<init>(App.kt:25)

                  at java.lang.Class.newInstanceImpl(Native Method)

                  at java.lang.Class.newInstance(Class.java:1208)

                  at android.app.Instrumentation.newApplication(Instrumentation.java:990)

                  at android.app.Instrumentation.newApplication(Instrumentation.java:975)

                  at android.app.LoadedApk.makeApplication(LoadedApk.java:509)

                  at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4446)

                  at android.app.ActivityThread.access$1500(ActivityThread.java:144)

                  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1265)

                  at android.os.Handler.dispatchMessage(Handler.java:102)

                  at android.os.Looper.loop(Looper.java:136)

                  at android.app.ActivityThread.main(ActivityThread.java:5146)

                  at java.lang.reflect.Method.invokeNative(Native Method)

                  at java.lang.reflect.Method.invoke(Method.java:515)

                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:732)

                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:566)


위에 빨간색으로 표시한 부분이 힌트이다. 


재현된 경우는 다음과 같은 순서로 하면 재현이 된다. 

Android API Level 20 이상인 경우에는 profile을 지원해서 profile이 켜진상태로 실행을 하고, 

다음에 Android API Level 20 이하인 ( 본인은  Android 4.4 기기 ) 단말기를 연결해서 실행하니 위와 같은 오류가 발생하면서 죽는다. 


해결방법은 간단하다. 

메뉴에서 Run -> edit run configurations 를 연다음에 아래화면과 같이 체크박스를 해제해주면 된다. 






: