【发布时间】:2014-08-16 07:52:33
【问题描述】:
我最近遇到了tool for android hotswapping。它有一个开始使用 eclipse(Luna) http://www.instareloader.com/enabling-instareloader-in-the-eclipse-ide/ 的教程。
该教程所说的是:
- 右键单击主项目,然后单击新建测试项目
- 将他们的库 jar 添加到 junit 测试中。
这是我主要项目的 xml:
<uses-sdk
android:minSdkVersion="11"
android:targetSdkVersion="17" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
这是我的 TestProject 的 xml:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.layoutreloadmyown.test"
android:versionCode="1"
android:versionName="1.0"
android:sharedUserId="com.test">
<uses-sdk android:minSdkVersion="11" />
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<instrumentation
android:name="android.test.InstrumentationTestRunner"
android:targetPackage="com.example.layoutreloadmyown" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<uses-library android:name="android.test.runner" />
<meta-data
android:name="instareloader.ip"
android:value="192.168.56.1" />
<meta-data
android:name="instareloader.port"
android:value="18080" />
<meta-data
android:name="instareloader.file.logger"
android:value="true" />
<activity
android:name="com.example.layoutreloadmyown.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
我做了它所说的一切,而且确实如此,但是我得到了一个 classnotfoundException:
08-16 12:29:51.995:E/AndroidRuntime(1745):致命异常:主要 08-16 12:29:51.995: E/AndroidRuntime(1745): java.lang.RuntimeException: 无法实例化活动 ComponentInfo{com.example.layoutreloadmyown.test/com.example.layoutreloadmyown.MainActivity}: java.lang.ClassNotFoundException : com.example.layoutreloadmyown.MainActivity 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1983) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.app.ActivityThread.access$600(ActivityThread.java:130) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.os.Handler.dispatchMessage(Handler.java:99) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.os.Looper.loop(Looper.java:137) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.app.ActivityThread.main(ActivityThread.java:4745) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 java.lang.reflect.Method.invokeNative(Native Method) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 java.lang.reflect.Method.invoke(Method.java:511) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 08-16 12:29:51.995: E/AndroidRuntime(1745): at dalvik.system.NativeStart.main(Native Method) 08-16 12:29:51.995: E/AndroidRuntime(1745): 引起: java.lang.ClassNotFoundException: com.example.layoutreloadmyown.MainActivity 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 java.lang.ClassLoader.loadClass(ClassLoader.java:501) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 java.lang.ClassLoader.loadClass(ClassLoader.java:461) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.app.Instrumentation.newActivity(Instrumentation.java:1053) 08-16 12:29:51.995: E/AndroidRuntime(1745): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1974)
【问题讨论】:
标签: java android eclipse junit