-5
Android 프로젝트에서 Java 리플렉션으로 연주하고 있습니다.android Class.forName이 예외를 throw합니다.
소스 코드 :
Log.d("LOG", "begin");
try {
final android.view.View.OnSystemUiVisibilityChangeListener unusedVar = new android.view.View.OnSystemUiVisibilityChangeListener() {
@Override
public void onSystemUiVisibilityChange(int visibility) {
// TODO Auto-generated method stub
}
};
Log.d("LOG", "unusedVar is null = " + (unusedVar == null? "Yes": "No"));
Class newClass = Class.forName("android.view.View.OnSystemUiVisibilityChangeListener");
Log.d("LOG", "newClass created");
} catch (Exception ex) {
Log.d("LOG", "Failed to create newClass", ex);
}
Log.d("LOG", "end");
- 위의 코드 내 활동의()에서 onCreate입니다.
- 프로젝트의 빌드 대상은 Android 4.0입니다.
- Android 4.0.4가 설치된 기기에서 실행 중입니다.
결과 : 변수 unusedVar
이 null
아니라, Class.forName
이 ClassNotFoundException
가 발생합니다.
로그 :
D/LOG(13205): begin
D/LOG(13205): unusedVar is null = No
D/LOG(13205): Failed to create newClass
D/LOG(13205): java.lang.ClassNotFoundException: android.view.View.OnSystemUiVisibilityChangeListener
D/LOG(13205): at java.lang.Class.classForName(Native Method)
D/LOG(13205): at java.lang.Class.forName(Class.java:217)
D/LOG(13205): at java.lang.Class.forName(Class.java:172)
D/LOG(13205): at com.MyActivity.onCreate(VideoPlayerActivity.java:100)
D/LOG(13205): at android.app.Activity.performCreate(Activity.java:4465)
D/LOG(13205): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
D/LOG(13205): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
D/LOG(13205): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
D/LOG(13205): at android.app.ActivityThread.access$600(ActivityThread.java:123)
D/LOG(13205): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
D/LOG(13205): at android.os.Handler.dispatchMessage(Handler.java:99)
D/LOG(13205): at android.os.Looper.loop(Looper.java:137)
D/LOG(13205): at android.app.ActivityThread.main(ActivityThread.java:4424)
D/LOG(13205): at java.lang.reflect.Method.invokeNative(Native Method)
D/LOG(13205): at java.lang.reflect.Method.invoke(Method.java:511)
D/LOG(13205): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
D/LOG(13205): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
D/LOG(13205): at dalvik.system.NativeStart.main(Native Method)
D/LOG(13205): Caused by: java.lang.NoClassDefFoundError: android/view/View/OnSystemUiVisibilityChangeListener
D/LOG(13205): ... 18 more
D/LOG(13205): Caused by: java.lang.ClassNotFoundException: android.view.View.OnSystemUiVisibilityChangeListener
D/LOG(13205): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61)
D/LOG(13205): at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
D/LOG(13205): at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
D/LOG(13205): ... 18 more
D/LOG(13205): end
왜 그렇습니까? 그 이유는 android.view.View.OnSystemUiVisibilityChangeListener
이 클래스 대신 인터페이스이 되었기 때문입니까?
당신이를 java.lang.reflect.Proxy를 사용할 수 있습니다. 이것 좀 봐 : http://stackoverflow.com/questions/1082850/java-reflection-create-an-implementing-class – Naytzyrhc