java - 不幸的是(android 应用程序)已停止。

标签 java android eclipse twitter android-asynctask

我正在使用 eclipse 学习 android 编程。我编写了一个 Twitter 应用程序,它只是让您发布状态并查看用户的时间线。但是,当我尝试在我的 samsung galaxy tab 3.0 上运行该应用程序时,该应用程序启动,我看到的只是顶部的标题,没有显示任何 TextView 或按钮,然后 2 秒后屏幕变黑,我收到错误消息(“不幸的是 TwitterApp 已停止”)我无法想象这与 Twitter 有关,因为没有显示任何小部件。这是我的主要 Activity 的代码和 activity_main.xml 文件。还有 logCat。我什至会包括 list

package com.example.twitterapp;

import java.util.List;

import twitter4j.Twitter;
import twitter4j.TwitterException;
import twitter4j.TwitterFactory;
import android.os.AsyncTask;
import android.os.Bundle;
import android.app.Activity;
import android.text.Editable;
import android.text.TextWatcher;
import android.text.method.ScrollingMovementMethod;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

public class MainActivity extends Activity {

TextView countCharsTV, timelineTV;
EditText usernameET, tweetET;
Button tweetBTN, timelineBTN;

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

    countCharsTV = (TextView) findViewById(R.id.textView1);

    timelineTV = (TextView) findViewById(R.id.textView2);
    timelineTV.setMovementMethod(new ScrollingMovementMethod());

    tweetET = (EditText) findViewById(R.id.editText1);
    tweetET.addTextChangedListener(new MyTextWatcher());

    usernameET = (EditText) findViewById(R.id.editText2);

    tweetBTN = (Button) findViewById(R.id.button1);
    tweetBTN.setOnClickListener(tweetBTNOnClickListener);

    timelineBTN.setOnClickListener(timelineBTNOnClickListener);
}

//BUTTON CLICK LISTENERS WITHOUT IMPLEMENTS
public OnClickListener tweetBTNOnClickListener = new OnClickListener() {

    @Override
    public void onClick(View arg0) {

        new MyAsyncTaskTweet().execute(tweetET.getText().toString());

    }
};

public OnClickListener timelineBTNOnClickListener = new OnClickListener() {

    @Override
    public void onClick(View v) {
        new MyAsyncTaskTimeline().execute(timelineTV.getText().toString());

    }
};
//END OF BUTTON CLICK LISTENERS

//COUNT CHARS IN TEXTVIEW USING IMPLEMENTS
class MyTextWatcher implements TextWatcher {

    @Override
    public void afterTextChanged(Editable arg0) {

        countCharsTV.setText("" + tweetET.getText().length());

    }

    @Override
    public void beforeTextChanged(CharSequence arg0, int arg1, int arg2,
            int arg3) {

    }

    @Override
    public void onTextChanged(CharSequence arg0, int arg1, int arg2,
            int arg3) {

    }


}
//End OF COUNT CHARS IN TEXTVIEW

//ASYNC TASK CLASSES
//TWEET ASYNC TASK
public class MyAsyncTaskTweet extends AsyncTask<String,Void,String> {

    @Override
    protected String doInBackground(String... tweet) {

        String result = "";

        Twitter twitter = TwitterFactory.getSingleton();

        try{

            twitter.updateStatus(tweet[0]);
            result = "Success";

        }catch(TwitterException twitterException) {

            result = "Failed to update status";

        }

        return result;

    }

    @Override
    protected void onPostExecute(String result){

        tweetET.setHint(result);
        tweetET.setText("");

    }

    }
//END OF TWEET ASYNC TASK

public class MyAsyncTaskTimeline extends AsyncTask<String, Void, String> {

    @Override
    protected String doInBackground(String... username) {

        String result = new String("");
        List<twitter4j.Status> statuses = null;

        Twitter twitter = TwitterFactory.getSingleton();
        try {

            statuses = twitter.getUserTimeline(username[0]);


        }catch (TwitterException twitterException) {

            twitterException.printStackTrace();

        }


        for(twitter4j.Status status : statuses) {

            result += status.getText();
            result += "\n";

        }
        return result;
    }

    @Override
    protected void onPostExecute(String result) {

        usernameET.setText("");
        timelineTV.setText(result);

    }


}

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

}

activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >

<Button
    android:id="@+id/button1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignLeft="@+id/editText1"
    android:layout_below="@+id/editText1"
    android:text="Tweet" />

<EditText
    android:id="@+id/editText1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignLeft="@+id/textView1"
    android:layout_alignParentTop="true"
    android:ems="10"
    android:hint="Type your tweet here" />

<TextView
    android:id="@+id/textView1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/editText2"
    android:layout_alignBottom="@+id/editText2"
    android:layout_toLeftOf="@+id/editText2"
    android:text="&apos;@" />

<Button
    android:id="@+id/button2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/editText2"
    android:layout_toRightOf="@+id/textView1"
    android:text="Timeline" />

<EditText
    android:id="@+id/editText2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/button1"
    android:layout_centerHorizontal="true"
    android:layout_marginTop="19dp"
    android:ems="10"
    android:hint="Type a username here" >

    <requestFocus />
</EditText>

<TextView
    android:id="@+id/textView2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/button2"
    android:layout_toRightOf="@+id/button1"
    android:text="Timeline will go here" />

</RelativeLayout>

AndroidManifest.xml

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

<uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="17" />
uses-permission android:name="android.permission.INTERNET"/>

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="com.example.twitterapp.MainActivity"
        android:label="@string/app_name" >
        android:windowSoftInputMode="adjustPan">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

</manifest>

日志

03-21 22:46:25.117: W/ActivityThread(3806): Application com.example.twitterapp can be        

debugged on port 8100...
03-21 22:46:25.289: E/SensorManager(3806): thread start
03-21 22:46:25.296: D/SensorManager(3806): registerListener :: handle = 1598182229      
name= BOSCH BMC150 Acceleration Sensor delay= 200000    
03-21 22:46:25.296: D/AndroidRuntime(3806): Shutting down VM
03-21 22:46:25.296: W/dalvikvm(3806): threadid=1: thread exiting with uncaught exception        
(group=0x40dcd2a0)
03-21 22:46:25.304: E/AndroidRuntime(3806): FATAL EXCEPTION: main
03-21 22:46:25.304: E/AndroidRuntime(3806): java.lang.RuntimeException: Unable to start     
activity ComponentInfo{com.example.twitterapp/com.example.twitterapp.MainActivity}:    
java.lang.NullPointerException
03-21 22:46:25.304: E/AndroidRuntime(3806):     at    
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2129)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at   
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2154)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at  
android.app.ActivityThread.access$700(ActivityThread.java:146)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at   
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1260)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at 
android.os.Handler.dispatchMessage(Handler.java:99)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at  
android.os.Looper.loop(Looper.java:137)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at 
android.app.ActivityThread.main(ActivityThread.java:4949)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at   
java.lang.reflect.Method.invokeNative(Native Method)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at  
java.lang.reflect.Method.invoke(Method.java:511)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at  
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1043)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at 
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:810)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at  
dalvik.system.NativeStart.main(Native Method)
03-21 22:46:25.304: E/AndroidRuntime(3806): Caused by: java.lang.NullPointerException
03-21 22:46:25.304: E/AndroidRuntime(3806):     at 
com.example.twitterapp.MainActivity.onCreate(MainActivity.java:45)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at 
android.app.Activity.performCreate(Activity.java:5185)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at 
android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)
03-21 22:46:25.304: E/AndroidRuntime(3806):     at          
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2093)
03-21 22:46:25.304: E/AndroidRuntime(3806):     ... 11 more
03-21 22:46:38.398: I/Process(3806): Sending signal. PID: 3806 SIG: 9

最佳答案

timelineBTN 引用在哪里? “timelineBTN”为空。 timelineBTN = (Button)findViewById(R.id.);

关于java - 不幸的是(android 应用程序)已停止。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22569746/

相关文章:

java - 如何在 Eclipse 中引用 JAR 文件中的类和方法?

java - 具有多个模块的 Maven 项目无法找到模块的 pom.xml - Jenkins/Eclipse

java - 记录生成的 MIDI 事件 : inner conversion from timestamps to midi file delta time

java - 如何更改选定单元格的背景?

java - 简单的 while 循环练习

Android Jack 编译器 : how to enable incremental mode?

java - 某些带有数字的短语不会乘以 2

Android WiFi Direct 设备详细信息

android - 如何处理 Firebase 17.0.1 的 INSTANCE_ID_EVENT 操作?

eclipse - 为什么Eclipse找不到原语和容器的源代码?