首先,我想说的是,对于Android(或Java,就此而言)我是一个新手,所以我很可能在一个非常基本的层面上做错了 - 请保留这个记住。
我将基本上包括整个来源,因为我不知道问题所在的位置(在任何人建议我尝试使用Google之前,我已经花了最近几天这样做了。)
当我尝试运行或调试应用程序时收到以下错误消息时出现问题:
eclipse.buildId=M20100909-0800
java.version=1.6.0_24
java.vendor=Sun Microsystems Inc.
BootLoader constants: OS=win32, ARCH=x86, WS=win32, NL=en_NZ
Framework arguments: -product org.eclipse.epp.package.java.product
Command-line arguments: -os win32 -ws win32 -arch x86 -product org.eclipse.epp.package.java.product
Error
Fri Feb 25 15:52:44 CET 2011
No command output when running: 'am start -n com.company.android.app/com.company.android.app.Home -a android.intent.action.MAIN -c android.intent.category.LAUNCHER' on device emulator-5554
com.android.ddmlib.ShellCommandUnresponsiveException
at com.android.ddmlib.AdbHelper.executeRemoteCommand(AdbHelper.java:408)
at com.android.ddmlib.Device.executeShellCommand(Device.java:276)
at com.android.ide.eclipse.adt.internal.launch.ActivityLaunchAction.doLaunchAction(Unknown Source)
at com.android.ide.eclipse.adt.internal.launch.AndroidLaunchController.launchApp(Unknown Source)
at com.android.ide.eclipse.adt.internal.launch.AndroidLaunchController.simpleLaunch(Unknown Source)
at com.android.ide.eclipse.adt.internal.launch.AndroidLaunchController.access$3(Unknown Source)
at com.android.ide.eclipse.adt.internal.launch.AndroidLaunchController$3.run(Unknown Source)
该应用程序是一个非常基本的东西。它有一个Activity,在视图中包含以下XML代码:
<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/helloAndroid"
android:text=""
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
以下代码在Activity的* .java中:
package com.company.android.app;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.webkit.WebView;
import android.widget.TextView;
public class Home extends Activity {
TextView helloWorld;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
helloWorld = ( TextView ) findViewById( R.id.helloAndroid );
helloWorld.setText( "Hello Android!" );
}
}
最后,在我的AndroidManifest.xml中:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.company.android.app"
android:versionCode="1"
android:versionName="1.0">
<uses-sdk android:minSdkVersion="7" />
<application android:icon="@drawable/icon" android:label="@string/app_name">
<activity android:name=".Home"
android:label="@string/app_name"
android:theme="@android:style/Theme.NoTitleBar">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
<uses-permission android:name="android.permission.INTERNET" />
</manifest>
当我运行或调试应用程序时,我在控制台中看到以下内容:
[2011-02-25 16:22:52 - com.company.android.app] adb is running normally.
[2011-02-25 16:22:52 - com.company.android.app] Performing com.company.android.app.Home activity launch
[2011-02-25 16:22:52 - com.company.android.app] Automatic Target Mode: using existing emulator 'emulator-5554' running compatible AVD 'Android-2.3.3'
[2011-02-25 16:22:57 - com.company.android.app] Uploading com.company.android.app.apk onto device 'emulator-5554'
[2011-02-25 16:23:00 - com.company.android.app] Installing com.company.android.app.apk...
[2011-02-25 16:23:22 - com.company.android.app] Success!
[2011-02-25 16:23:23 - com.company.android.app] Starting activity com.company.android.app.Home on device emulator-5554
一点额外信息:
我想不出任何其他内容。
可能导致此问题的任何想法?
非常感谢提前。 扎克
答案 0 :(得分:0)
我不明白(在eclipse中)你得到第一个错误日志。
你的代码非常正确,即使我在TextView周围没有使用任何布局(因为只是一个TextView没用),这很奇怪,在这里找到运行...
首先,您应该尝试运行“从头开始”的android项目并检查: 1.模拟器上生成的HelloWorld; 2.检查logcat视图并找到类似“ActivityManager显示的活动com.yourpackage.youractivity”的内容
如果它确实有效,请逐步使用程序化UI定义来满足您的需求。
无论如何,你应该使用“Log.i(”MyApp“,”on onCreate()“);”如果有任何异常,请检查logcat(logcat视图是你的朋友)。
雷诺
答案 1 :(得分:0)
我找到的解决方案是由@erichamion在我的问题评论中提供的。我通过AVD Manager重新启动了模拟器,并选中了“擦除用户数据”选项,并且未选中“从快照启动”选项。
我怀疑当我第一次加载模拟器时,它被我打断了,并且处于无法操作的状态。通过加载具有新状态的仿真器,清除用户数据并擦除快照克服了该问题。
感谢您的帮助...