簡體   English   中英

Android錯誤-致命異常:主要

[英]Android Error - FATAL EXCEPTION: main

我正在從事初學者Android任務(應購買汽車渡輪票並計算車票成本的應用程序),而讓該應用程序在仿真器中運行時遇到問題。 我有一個示例程序可以在仿真器中運行,但是我無法弄清楚這個問題是什么。 附帶說明一下,我正在使用Mac,如果有任何意義,我正在運行Eclipse。 這是MainActivity.java代碼:

package net.androidbootcamp.carferryfare;

import java.text.DecimalFormat;

import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Spinner;
import android.widget.TextView;
import android.view.View.OnClickListener;



public class MainActivity extends ActionBarActivity 
{
int costPerTicket = 18;
int numberOfTickets = 0;
int totalCost = 0;
String ferryChoice = "";
@Override
protected void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    final EditText tickets=( EditText)findViewById(R.id.txtTickets);
    final Spinner group=(Spinner)findViewById(R.id.txtGroup);
    Button cost = (Button)findViewById(R.id.btnCost);
    final TextView result = ((TextView)findViewById(R.id.txtResult));   
    cost.setOnClickListener( new OnClickListener()
    {



        @Override

        public void onClick(View v) 
        {
            // TODO Auto-generated method stub
            numberOfTickets =  Integer.parseInt(tickets.getText().toString());
            totalCost = costPerTicket * numberOfTickets;
            DecimalFormat currency = new DecimalFormat("$###,###");
            ferryChoice = group.getSelectedItem().toString();
            result.setText("Total Cost for " + ferryChoice + " is " +       currency.format(totalCost));
        }

        });

}


@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);
}
}

這是顯示的LogCat數據:

09-29 18:18:56.049: D/AndroidRuntime(2033): Shutting down VM
09-29 18:18:56.099: W/dalvikvm(2033): threadid=1: thread exiting with uncaught exception        (group=0xb0cd7b20)
09-29 18:18:56.159: E/AndroidRuntime(2033): FATAL EXCEPTION: main
09-29 18:18:56.159: E/AndroidRuntime(2033): Process: net.androidbootcamp.carferryfare, PID:    2033
09-29 18:18:56.159: E/AndroidRuntime(2033): java.lang.RuntimeException: Unable to start    activity     ComponentInfo{net.androidbootcamp.carferryfare/net.androidbootcamp.carferryfare.MainActivity}:    java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with   this activity.
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.app.ActivityThread.access$800(ActivityThread.java:135)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.os.Handler.dispatchMessage(Handler.java:102)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.os.Looper.loop(Looper.java:136)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.app.ActivityThread.main(ActivityThread.java:5017)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at java.lang.reflect.Method.invokeNative(Native Method)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at java.lang.reflect.Method.invoke(Method.java:515)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at dalvik.system.NativeStart.main(Native Method)
09-29 18:18:56.159: E/AndroidRuntime(2033): Caused by: java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with this activity.
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.support.v7.app.ActionBarActivityDelegate.onCreate(ActionBarActivityDelegate.java:110)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.support.v7.app.ActionBarActivityDelegateICS.onCreate(ActionBarActivityDelegateICS.java:57)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.support.v7.app.ActionBarActivity.onCreate(ActionBarActivity.java:99)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at net.androidbootcamp.carferryfare.MainActivity.onCreate(MainActivity.java:27)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.app.Activity.performCreate(Activity.java:5231)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
09-29 18:18:56.159: E/AndroidRuntime(2033):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
09-29 18:18:56.159: E/AndroidRuntime(2033):     ... 11 more
09-29 18:19:04.359: I/Process(2033): Sending signal. PID: 2033 SIG: 9

好的,很清楚,我需要包括: import android.app.Activity; 作為MainActivity.java部分中的導入,這就是代碼無法正常工作的原因。 謝謝您,帕尼尼(panini),希望這可以對遇到同樣問題的其他人有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM