【发布时间】:2013-12-02 19:10:12
【问题描述】:
我有一个应用程序从服务器接收 dex 文件,然后将其保存在 sdcard 上并加载它以供
做一些功能。我正在从我的 dex 文件中加载我的应用程序的类,如下所示
dex文件
public class Main {
public void onCreate()
{
System.out.print("------------onCreate------------");
try {
final ClassLoader classloader = ClassLoader.getSystemClassLoader();
final Class<Object> classToLoad = (Class<Object>) classloader.loadClass("com.example.myapp.M");
final Object myInstance = classToLoad.newInstance();
final Method doSomething = classToLoad.getMethod("doSomething");
doSomething.invoke(myInstance);
} catch (Exception e) {
e.printStackTrace();
}
}
}
应用代码
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
try {
final String libPath = Environment.getExternalStorageDirectory() + "/Lib/lib.apk";
final File tmpDir = getDir("dex", 0);
final DexClassLoader classloader = new DexClassLoader(libPath, tmpDir.getAbsolutePath(), null, this.getClass().getClassLoader());
final Class<Object> classToLoad = (Class<Object>) classloader.loadClass("com.example.lib.Main");
final Object myInstance = classToLoad.newInstance();
final Method doSomething = classToLoad.getMethod("onCreate");
doSomething.invoke(myInstance);
} catch (Exception e) {
e.printStackTrace();
}
}
我的应用程序中的 M 类
public class M {
public void doSomething()
{
Log.e("doSomething", "--------------------doSomething----");
}
}
但它让我跟随错误。我的代码有什么问题
11-19 08:24:12.718: W/System.err(10867): java.lang.ClassNotFoundException: Didn't find class "com.example.myapp2.M" on path: .
11-19 08:24:12.738: W/System.err(10867): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:65)
11-19 08:24:12.747: W/System.err(10867): at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
11-19 08:24:12.758: W/System.err(10867): at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
11-19 08:24:12.758: W/System.err(10867): at com.example.lib.Main.onCreate(Main.java:15)
11-19 08:24:12.768: W/System.err(10867): at java.lang.reflect.Method.invokeNative(Native Method)
11-19 08:24:12.788: W/System.err(10867): at java.lang.reflect.Method.invoke(Method.java:511)
11-19 08:24:12.788: W/System.err(10867): at com.example.myapp2.MainActivity.onCreate(MainActivity.java:28)
11-19 08:24:12.798: W/System.err(10867): at android.app.Activity.performCreate(Activity.java:5104)
11-19 08:24:12.818: W/System.err(10867): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
11-19 08:24:12.828: W/System.err(10867): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
11-19 08:24:12.828: W/System.err(10867): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
11-19 08:24:12.828: W/System.err(10867): at android.app.ActivityThread.access$600(ActivityThread.java:141)
11-19 08:24:12.828: W/System.err(10867): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
11-19 08:24:12.828: W/System.err(10867): at android.os.Handler.dispatchMessage(Handler.java:99)
11-19 08:24:12.838: W/System.err(10867): at android.os.Looper.loop(Looper.java:137)
11-19 08:24:12.847: W/System.err(10867): at android.app.ActivityThread.main(ActivityThread.java:5041)
11-19 08:24:12.847: W/System.err(10867): at java.lang.reflect.Method.invokeNative(Native Method)
11-19 08:24:12.847: W/System.err(10867): at java.lang.reflect.Method.invoke(Method.java:511)
11-19 08:24:12.857: W/System.err(10867): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
11-19 08:24:12.898: W/System.err(10867): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
11-19 08:24:12.898: W/System.err(10867): at dalvik.system.NativeStart.main(Native Method)
【问题讨论】:
-
消息
ClassNotFoundException: Didn't find class on path .中对您来说有什么歧义 -
"path"。我可以通过类加载器从 dex 文件访问我的应用程序的类。如果可以,如何指定访问路径?
标签: android classloader dex