Java Android错误-致命异常:main
我正在做一个Android初学者作业(一个应该用来购买汽车渡轮票并计算车票成本的应用程序),我在让应用程序在模拟器中运行时遇到了问题。我已经得到了一个在模拟器中运行的示例程序,但是我不知道这个程序有什么问题。另一方面,我使用的是Mac电脑,如果这意味着什么的话,我正在运行Eclipse。以下是MainActivity.java代码:Java Android错误-致命异常:main,java,android,eclipse,Java,Android,Eclipse,我正在做一个Android初学者作业(一个应该用来购买汽车渡轮票并计算车票成本的应用程序),我在让应用程序在模拟器中运行时遇到了问题。我已经得到了一个在模拟器中运行的示例程序,但是我不知道这个程序有什么问题。另一方面,我使用的是Mac电脑,如果这意味着什么的话,我正在运行Eclipse。以下是MainActivity.java代码: package net.androidbootcamp.carferryfare; import java.text.DecimalFormat; import
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部分的导入,这就是代码不起作用的原因。谢谢你,帕尼尼,希望这能帮助其他遇到与我相同问题的人。原因:java.lang.IllegalStateException:你需要使用Theme.AppCompat主题(或后代)通过此活动。请发布您的XML
作为主要活动。感谢panini…我发现我需要包含import android.app.activity;。。。你可能会认为这是书中的一部分,但是哦,好吧,现在修好了