LogCat错误:java.lang.illegalstateexception无法执行活动的方法

时间:2013-10-16 03:17:00

标签: android logcat

您好我是Android开发新手。我创建此活动似乎每次我点击此活动中的一个按钮。我继续得到活动LogCat错误的无法执行方法。

这是我的活动Java文件

public class Add_Edit_Cows extends Activity  {

    Button cradd, credit, crdelete, crview;
EditText cowids, sire, dam, months, dates, years;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_add__edit__cows);
    cradd = (Button) findViewById(R.id.addcow);
    cowids = (EditText) findViewById(R.id.cowid);
    sire = (EditText) findViewById(R.id.sire);
    dam = (EditText) findViewById(R.id.dam);
    months = (EditText) findViewById(R.id.DOBM);
    dates = (EditText) findViewById(R.id.DOBd);
    years = (EditText) findViewById(R.id.DOBy);


    credit = (Button) findViewById(R.id.editcow);
    crdelete = (Button) findViewById(R.id.removecow);
    crview = (Button) findViewById(R.id.viewcows);
}
public void addcow (View view) {
    Cowsdatabase cowsdb = new Cowsdatabase(this, null, null, 1);

    int Cown = Integer.parseInt(cowids.getText().toString());
    String Sire = sire.getText().toString();
    String Dam = dam.getText().toString();
    int Month = Integer.parseInt(months.getText().toString());
    int Date = Integer.parseInt(dates.getText().toString());
    int Year = Integer.parseInt(years.getText().toString());

    cow Cow = new cow(Integer.parseInt(cowids.getText().toString()), Sire, Dam, Month, Date, Year);
    cowsdb.addcow(Cow);
    cowids.setText("");
    sire.setText("");
    dam.setText("");
    months.setText("");
    dates.setText("");
    years.setText("");
}

public void editcow(View view) {
    Cowsdatabase cowsdb = new Cowsdatabase(this, null, null, 1);

    cow Cow =
            cowsdb.findcow(Integer.parseInt(cowids.getText().toString()));
    if (Cow != null) {
        sire.setText(String.valueOf(Cow.getSire()));
        dam.setText(String.valueOf(Cow.getDam()));
        months.setText(String.valueOf(Cow.getMonth()));
        dates.setText(String.valueOf(Cow.getDate()));
        years.setText(String.valueOf(Cow.getYear()));
    } else {
        cowids.setText("No Match Found");
    }
    }
public void dcow (View view) {
    Cowsdatabase cowsdb = new Cowsdatabase(this, null, null, 1);
    boolean result = cowsdb.deleteCow(Integer.parseInt(cowids.getText().toString()));
    if (result)
    {
        cowids.setText("Record Deleted");
        sire.setText("");
        dam.setText("");
        months.setText("");
        dates.setText("");
        years.setText("");
    }
    else
        cowids.setText("No Match Found");
}
public void viewcow (View view){
startActivity(new Intent("Ag.Access.Viewcows"));
}
}

LogCat错误消息:

10-15 20:02:51.735: E/AndroidRuntime(7738): FATAL EXCEPTION: main
10-15 20:02:51.735: E/AndroidRuntime(7738): java.lang.IllegalStateException: Could not execute method of the activity
10-15 20:02:51.735: E/AndroidRuntime(7738):     at android.view.View$1.onClick(View.java:3591)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at android.view.View.performClick(View.java:4084)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at android.view.View$PerformClick.run(View.java:16966)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at android.os.Handler.handleCallback(Handler.java:615)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at android.os.Handler.dispatchMessage(Handler.java:92)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at android.os.Looper.loop(Looper.java:137)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at android.app.ActivityThread.main(ActivityThread.java:4745)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at java.lang.reflect.Method.invokeNative(Native Method)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at java.lang.reflect.Method.invoke(Method.java:511)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at dalvik.system.NativeStart.main(Native Method)
10-15 20:02:51.735: E/AndroidRuntime(7738): Caused by: java.lang.reflect.InvocationTargetException
10-15 20:02:51.735: E/AndroidRuntime(7738):     at java.lang.reflect.Method.invokeNative(Native Method)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at java.lang.reflect.Method.invoke(Method.java:511)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at android.view.View$1.onClick(View.java:3586)
10-15 20:02:51.735: E/AndroidRuntime(7738):     ... 11 more
10-15 20:02:51.735: E/AndroidRuntime(7738): Caused by: java.lang.NullPointerException
10-15 20:02:51.735: E/AndroidRuntime(7738):     at ag.access.cowsdb.Cowsdatabase.addcow(Cowsdatabase.java:64)
10-15 20:02:51.735: E/AndroidRuntime(7738):     at ag.access.Add_Edit_Cows.addcow(Add_Edit_Cows.java:48)
10-15 20:02:51.735: E/AndroidRuntime(7738):     ... 14 more

我的XML文件:

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="ag.access"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="18" />
<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name`"`enter code here`
    android:theme="@style/AppTheme" >
    <activity
        android:name="ag.access.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>
    <activity
        android:name="ag.access.Farming"
        android:label="@string/title_activity_farming"
        android:parentActivityName="ag.access.MainActivity" >
        <intent-filter>
            <action android:name="ag.access.Farming" />
            <category android:name="android.intent.category.DEFAULT" />
        </intent-filter>
        <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value="ag.access.MainActivity" />
    </activity>
    <activity
        android:name="ag.access.Dairy"
        android:label="@string/title_activity_dairy"
        android:parentActivityName="ag.access.MainActivity" >
        <intent-filter>
            <action android:name="ag.access.Dairy" />
            <category android:name="android.intent.category.DEFAULT" />
        </intent-filter>
        <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value="ag.access.MainActivity" />
    </activity>
    <activity
        android:name="ag.access.Daily_log"
        android:label="@string/title_activity_daily_log"
        android:parentActivityName="ag.access.Dairy" >
        <intent-filter>
            <action android:name="ag.access.Daily_log" />
            <category android:name="android.intent.category.DEFAULT" />
        </intent-filter>
        <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value="ag.access.Dairy" />
    </activity>
    <activity
        android:name="ag.access.Viewlogs"
        android:label="@string/title_activity_viewlogs"
        android:parentActivityName="ag.access.Daily_log" >
        <intent-filter>
            <action android:name="ag.access.Viewlogs" />
            <category android:name="android.intent.category.DEFAULT" />
        </intent-filter>
        <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value="ag.access.Daily_log" />
    </activity>
    <activity
        android:name="ag.access.Add_Edit_Cows"
        android:label="@string/title_activity_add__edit__cows"
        android:parentActivityName="ag.access.Dairy" >
        <intent-filter>
            <action android:name="ag.access.Add_Edit_Cows" />
            <category android:name="android.intent.category.DEFAULT" />
        </intent-filter>
        <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value="ag.access.Dairy" />
     </activity>
     <activity
        android:name="ag.access.Viewcows"
        android:label="@string/title_activity_viewcows"
        android:parentActivityName="ag.access.Add_Edit_Cows" >
        <intent-filter>
            <action android:name="ag.access.Viewcows" /
            <category android:name="android.intent.category.DEFAULT" />
        </intent-filter>
        <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value="ag.access.Add_Edit_Cows" />
    </activity>
 </application>
 </manifest>

我的Add_Edit_Cows活动

<ScrollView
 xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent">
<LinearLayout 
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
tools:context=".Add_Edit_Cows" >
    <TextView
    android:id="@+id/textView1"
    android:layout_width="280dp"
    android:layout_height="wrap_content"
    android:text="Add Edit Delete Cows"
    android:textAppearance="?android:attr/textAppearanceLarge" />
    <EditText
    android:id="@+id/cowid"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:inputType="number"
    android:hint="@string/cowid" />     
    <EditText
    android:id="@+id/sire"
    android:layout_width="280dp"
    android:layout_height="wrap_content"
    android:inputType="text"
    android:hint="@string/sire"/>
    <EditText
    android:id="@+id/dam"
    android:layout_width="280dp"
    android:layout_height="wrap_content"
    android:inputType="text"
    android:hint="@string/dam"/>
    <EditText 
    android:id="@+id/DOBM"
    android:layout_width="280dp"
    android:layout_height="wrap_content"
    android:inputType="number"
    android:hint="@string/DOBM"/>
    <EditText 
    android:id="@+id/DOBd"
    android:layout_width="280dp"
    android:layout_height="wrap_content"
    android:inputType="number"
    android:hint="@string/DOBD"/>
    <EditText 
    android:id="@+id/DOBy"
    android:layout_width="280dp"
    android:layout_height="wrap_content"
    android:inputType="number"
    android:hint="@string/DOBY"/>
    <Button
    android:id="@+id/addcow"
    android:layout_width="261dp"
    android:layout_height="wrap_content"
    android:onClick="addcow"
    android:text="@string/baddcow" />
    <Button
    android:id="@+id/editcow"
    android:layout_width="261dp"
    android:layout_height="wrap_content"
    android:onClick="editcow"
    android:text="@string/editcow" />  
    <Button
    android:id="@+id/removecow"
    android:layout_width="261dp"
    android:layout_height="wrap_content"
    android:onClick="dcow"
    android:text="@string/deletecow" />  
    <Button
    android:id="@+id/viewcows"
    android:layout_width="261dp"
    android:layout_height="wrap_content"
    android:onClick="viewcow"
    android:text="@string/viewc" />  

 </LinearLayout>
 </ScrollView>

Cowsdatabase.java

 package ag.access.cowsdb;

 import ag.access.cowsdb.provider.Cows_Provider;
 import android.content.ContentResolver;
 import android.content.ContentValues;
 import android.content.Context;
 import android.database.Cursor;
 import android.database.sqlite.SQLiteDatabase;
 import android.database.sqlite.SQLiteDatabase.CursorFactory;
 import android.database.sqlite.SQLiteOpenHelper;

 public class Cowsdatabase extends SQLiteOpenHelper {

private ContentResolver cowcr;

public Cowsdatabase(Context context, String name, CursorFactory factory,
        int version) {
    super(context, name, factory, version);
    // TODO Auto-generated constructor stub
}

public static final String Key_id = "_id";
public static final String Key_Cow = "Cowid";
public static final String Key_Sire = "Sire";
public static final String Key_Dam = "Dam";
public static final String Key_DOBM = "Month";
public static final String Key_DOBD = "Date";
public static final String Key_DOBY = "Year";

private static final String DATABASE_NAME = "CowsDB";
public static final String DATABASE_TABLE = "Cows";

private static final int DATABASE_VERSION = 1;

@Override
public void onCreate(SQLiteDatabase db) {
    // TODO Auto-generated method stub
    String Create_Cows_Table = "CREATE TABLE" + 
    DATABASE_TABLE + "(" +
    Key_id + "INTEGER PRIMARY KEY AUTOINCREMENT," +
    Key_Cow + "INTEGER NOT NULL" +
    Key_Sire + "TEXT NOT NULL," +
    Key_Dam  + "TEXT NOT NULL," +
    Key_DOBM + "INTEGER NOT NULL," +
    Key_DOBD + "INTEGER NOT NULL," +
    Key_DOBY + "INTEGER NOT NULL," + ")";
    db.execSQL(Create_Cows_Table);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // TODO Auto-generated method stub
    db.execSQL("DROP TABLE IF EXIST " + DATABASE_TABLE);
}
    public void addcow(cow Cow) {
ContentValues values = new ContentValues();
values.put(Key_Cow, Cow.getCowid());
values.put(Key_Sire, Cow.getSire());
values.put(Key_Dam, Cow.getDam());
values.put(Key_DOBM, Cow.getMonth());
values.put(Key_DOBD, Cow.getDate());
values.put(Key_DOBY, Cow.getYear());

cowcr.insert(Cows_Provider.Content_Uri, values);
 }
 public cow findcow(int cowid) {
String[] projection = {Key_id, Key_Cow, Key_Sire, Key_Dam, Key_DOBM, Key_DOBD, Key_DOBY};

String selection = "cowid = \"" + cowid + "\"";
Cursor cursor = cowcr.query(Cows_Provider.Content_Uri, projection, selection, null, null);

cow cow = new cow();

if (cursor.moveToFirst()) {
    cursor.moveToFirst();
    cow.Setid(Integer.parseInt(cursor.getString(0)));
    cow.SetCowid(Integer.parseInt(cursor.getString(1)));
    cow.setSire(cursor.getString(2));
    cow.setDam(cursor.getString(3));
    cow.setMonth(Integer.parseInt(cursor.getString(4)));
    cow.setDate(Integer.parseInt(cursor.getString(5)));
    cow.setYear(Integer.parseInt(cursor.getString(6)));
    cursor.close();
} else {
    cow = null;
}
return cow;
 }
public boolean deleteCow (int cowid) {
    boolean result = false;

    String selection = "cowid = \"" + cowid + "\"";

    int rowsDeleted = cowcr.delete(Cows_Provider.Content_Uri, selection, null);

    if (rowsDeleted > 0)
        result = true;

    return result;
}
 }

对于cradd按钮,我希望它将edittexts中的值添加到我的数据库,而我的内容提供商又接收了这些值 对于信用按钮,我希望能够编辑数据库中的奶牛。 对于crdelete按钮,我希望能够删除该数据库条目。 对于Crview,我希望它能够访问另一个活动,以便能够查看内容提供者。

就像我之前说的那样,所有按钮都会出现“无法执行活动的方法”LOGCAT错误。

您的帮助将不胜感激。

谢谢

2 个答案:

答案 0 :(得分:1)

您忘记注册视图对象的onclick事件。 setOnClickListener(本)

答案 1 :(得分:1)

错误来自第64行的Cowsdatabase.java

我认为它在这个街区的某个地方:

int Cown = Integer.parseInt(cowids.getText().toString());
String Sire = sire.getText().toString();
String Dam = dam.getText().toString();
int Month = Integer.parseInt(months.getText().toString());
int Date = Integer.parseInt(dates.getText().toString());
int Year = Integer.parseInt(years.getText().toString());

因为它是NullPointerException,我们可以假设其中一个variable.getText()执行返回null。如果是这样,则以下toString()将触发异常。

使用调试器可以非常清楚。