【问题标题】:The simplest HELLO WORLD is not working on the Emulator最简单的 HELLO WORLD 在模拟器上不行
【发布时间】:2014-07-20 14:11:37
【问题描述】:

我刚接触 android 开发。事实上,我是在今天下午早些时候开始的。我按照此链接中的说明进行操作。

https://developer.android.com/training/basics/firstapp/creating-project.html

我只是将它重命名为 hello2。

一切似乎都很完美,除非我试图在 AVD 中运行它。我的 logcat 不断弹出一些错误。并且模拟器显示“不幸的是,hello2 已停止。”

有人可以帮我吗?

这是我的 java 文件

package com.example.hello2;

import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;

public class MainActivity extends ActionBarActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}

这是我的清单文件

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.hello2"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="21" />

    <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>

</manifest>

这是我的日志:

07-20 13:22:25.760: W/dalvikvm(960): threadid=1: thread exiting with uncaught exception (group=0xb3af1d70)
07-20 13:22:25.780: E/AndroidRuntime(960): FATAL EXCEPTION: main
07-20 13:22:25.780: E/AndroidRuntime(960): Process: com.example.hello2, PID: 960
07-20 13:22:25.780: E/AndroidRuntime(960): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.hello2/com.example.hello2.MainActivity}: android.util.AndroidRuntimeException: You cannot combine swipe dismissal and the action bar.
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2197)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2258)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.ActivityThread.access$800(ActivityThread.java:138)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1209)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.os.Handler.dispatchMessage(Handler.java:102)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.os.Looper.loop(Looper.java:136)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.ActivityThread.main(ActivityThread.java:5026)
07-20 13:22:25.780: E/AndroidRuntime(960):  at java.lang.reflect.Method.invokeNative(Native Method)
07-20 13:22:25.780: E/AndroidRuntime(960):  at java.lang.reflect.Method.invoke(Method.java:515)
07-20 13:22:25.780: E/AndroidRuntime(960):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
07-20 13:22:25.780: E/AndroidRuntime(960):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)
07-20 13:22:25.780: E/AndroidRuntime(960):  at dalvik.system.NativeStart.main(Native Method)
07-20 13:22:25.780: E/AndroidRuntime(960): Caused by: android.util.AndroidRuntimeException: You cannot combine swipe dismissal and the action bar.
07-20 13:22:25.780: E/AndroidRuntime(960):  at com.android.internal.policy.impl.PhoneWindow.requestFeature(PhoneWindow.java:275)
07-20 13:22:25.780: E/AndroidRuntime(960):  at com.android.internal.policy.impl.PhoneWindow.generateLayout(PhoneWindow.java:2872)
07-20 13:22:25.780: E/AndroidRuntime(960):  at com.android.internal.policy.impl.PhoneWindow.installDecor(PhoneWindow.java:3129)
07-20 13:22:25.780: E/AndroidRuntime(960):  at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:303)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.Activity.setContentView(Activity.java:1930)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.support.v7.app.ActionBarActivity.superSetContentView(ActionBarActivity.java:217)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.support.v7.app.ActionBarActivityDelegateICS.setContentView(ActionBarActivityDelegateICS.java:110)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.support.v7.app.ActionBarActivity.setContentView(ActionBarActivity.java:77)
07-20 13:22:25.780: E/AndroidRuntime(960):  at com.example.hello2.MainActivity.onCreate(MainActivity.java:13)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.Activity.performCreate(Activity.java:5242)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
07-20 13:22:25.780: E/AndroidRuntime(960):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2161)
07-20 13:22:25.780: E/AndroidRuntime(960):  ... 11 more

我希望有人可以帮助我..

PS:抱歉英语不好。

【问题讨论】:

标签: android


【解决方案1】:

由于您使用的是 ActionBarActivity,并且为您的活动设置的目标 SDK 不适用于 ActionBarActivity。更改 API 版本或仅使用扩展“Activity”而不是“ActionBarActivity”

【讨论】:

    【解决方案2】:

    您的目标是哪个 API?您可以在清单中检查。如果您的目标是 API 20,请将其更改为 19,它应该可以工作。

    希望对你有帮助。

    【讨论】:

    • 问题很简单,很遗憾我需要问一个问题,我按照西蒙的建议摆脱了targetSDKVersion。实际上,我没有编写清单文件。它是由eclipse自动生成的。我只是感到困惑,为什么 Eclipse 会生成一个有错误的清单文件?为什么我需要删除 targetSDKVersion?
    • 您需要拥有 targetSDKVersion 并且它必须是最后一个可用的 SDK 版本。但现在您应该使用 19,因为 20 仍处于测试阶段并正在开发中。你肯定需要声明 targetSDK。查看链接developer.android.com/guide/topics/manifest/…
    • 现在,问题又出现了。 -_- 我真的不知道该怎么办。我不知道是什么问题。
    • 我不知道我的 Eclipse 出了什么问题,我正在使用 Eclipse Luna。我的插件是,Android L (API20, L preview), Android 4.4W(API20)
    • 但是如果你将 targetSDK 设置为 19 并将 minSdk 设置为任何你需要支持的...会发生什么?
    【解决方案3】:

    嘿,RED_x,如果我们删除了它对我有用的目标 sdk 版本 2 !!后来有什么问题吗?

    【讨论】:

    • 我这么认为?因为当我开始遵循一些简单程序的指令时,我无法让它运行。
    猜你喜欢
    • 2016-11-25
    • 2011-10-17
    • 1970-01-01
    • 1970-01-01
    • 2016-03-16
    • 1970-01-01
    • 1970-01-01
    • 2019-01-14
    • 1970-01-01
    相关资源
    最近更新 更多