Исключительная ситуация времени выполнения Java: невозможно запустить активность componentInfo

Я создаю приложение для связи с радиоуправлением с помощью Bluetooth. Но он падает на устройстве, говоря: "К сожалению, приложение Wheeler остановлено". Итак, я запустил его в эмуляторе, зная, что исключение нулевого указателя будет сгенерировано в строке 111, поскольку оно не является реальным устройством, пытаясь выяснить, что вызывает исключение времени выполнения, говорящее "Невозможно запустить действие ComponentInfo". Вот мой полный код -

package com.in2gravity.wheeler;
package com.in2gravity.wheeler;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Set;
import java.util.UUID;

import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothSocket;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Chronometer;
import android.widget.ImageView;
import android.widget.TextView;

public class MainActivity extends Activity implements OnClickListener {

private BluetoothAdapter mBluetoothAdapter;
private BluetoothDevice mDevice;
private ConnectThread mConnectThread;
private ConnectedThread mConnectedThread;
Handler mHandler;
private byte[] up, down, left, right, g1, g2, g3, g4, launch, dock;


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

    //Buttons Enlisting
    Button upnavbutton , downnavbutton, leftnavbutton, rightnavbutton,gearup1, gearup2, geardown1, geardown2, launchbutton, dockbutton;
    // texts Enlisting & id registration
    TextView propellerText = (TextView)findViewById(R.id.propellerText);
    TextView in2gravityText = (TextView)findViewById(R.id.in2gravityText);
    TextView timerText = (TextView)findViewById(R.id.timerText);
    // imageview enlisting & id registration
    ImageView appLogo = (ImageView)findViewById(R.id.appLogo);
    //chronometer enlisting & id registration
    Chronometer timer = (Chronometer)findViewById(R.id.chronometer1);
    //button id registration
    upnavbutton = (Button)findViewById(R.id.upnavbutton);
    downnavbutton = (Button)findViewById(R.id.downnavbutton);
    leftnavbutton = (Button)findViewById(R.id.leftnavbutton);
    rightnavbutton = (Button)findViewById(R.id.rightnavbutton);
    gearup1 = (Button)findViewById(R.id.gearbutton3);
    gearup2 = (Button)findViewById(R.id.gearbutton4);
    geardown2 = (Button)findViewById(R.id.gearbutton2);
    geardown1 = (Button)findViewById(R.id.gearbutton1);
    launchbutton = (Button)findViewById(R.id.launchbutton);
    dockbutton = (Button)findViewById(R.id.dockbutton);
    // setting onclick listener to this class

    upnavbutton.setOnClickListener(this);
    downnavbutton.setOnClickListener(this);
    leftnavbutton.setOnClickListener(this);
    rightnavbutton.setOnClickListener(this);
    launchbutton.setOnClickListener(this);
    dockbutton.setOnClickListener(this);
    gearup1.setOnClickListener(this);
    gearup2.setOnClickListener(this);
    geardown2.setOnClickListener(this);
    geardown1.setOnClickListener(this);
    // converting strings to bytes for further use
    up = "u".getBytes();
    down = "d".getBytes();
    left = "l".getBytes();
    right = "r".getBytes();
    launch = "L".getBytes();
    dock = "D".getBytes();
    g1 = "1".getBytes();
    g2 = "2".getBytes();
    g3 = "3".getBytes();
    g4 = "4".getBytes();

    mHandler = new Handler() {
            @Override
            public void handleMessage(Message msg) {
            byte[] writeBuf = (byte[]) msg.obj;
            int begin = (int)msg.arg1;
            int end = (int)msg.arg2;
            switch(msg.what) {
            case 1:
            String writeMessage = new String(writeBuf);
            writeMessage = writeMessage.substring(begin, end);
            break;
            }
            }
            };

    Intent enableBluetooth = null;      
    mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
    if(mBluetoothAdapter== null){
        String tag = null;
        // no bluetooth support!
        Log.e(tag, "Bluetooth is not supported in this device");
    }
    if(!mBluetoothAdapter.isEnabled()){
        enableBluetooth = new   Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
        startActivityForResult(enableBluetooth, 1);
    }
    Set<BluetoothDevice> pairedDevices =  mBluetoothAdapter.getBondedDevices();
    if(pairedDevices.size() > 0){
        for(BluetoothDevice device : pairedDevices){
            mDevice = device;
        }
    }
    mConnectThread = new ConnectThread(mDevice);
    mConnectThread.start();

//  if (savedInstanceState == null) {
//      getFragmentManager().beginTransaction()
//              .add(R.id.container, new PlaceholderFragment()).commit();
//  }

}

Класс подключения потока:

private class ConnectThread extends Thread{

            private final BluetoothSocket mmSocket;
            private final BluetoothDevice mmDevice;
            private final UUID MY_UUID = UUID.fromString("00001101-0000-1000-8000-00805f9b34fb");


            public ConnectThread(BluetoothDevice device){
                BluetoothSocket tmp =null;
                mmDevice= device;
                try {
                    tmp = device.createRfcommSocketToServiceRecord(MY_UUID);
                } catch (IOException e) {}
                    // TODO Auto-generated catch block

                    mmSocket =tmp;
                }
                public void run() {
                    mBluetoothAdapter.cancelDiscovery();
                    try {
                    mmSocket.connect();
                    } catch (IOException connectException) {
                    try {
                    mmSocket.close();
                    } catch (IOException closeException) {
                        return; 

                    }

                    } 
                    mConnectedThread = new ConnectedThread(mmSocket);
                    mConnectedThread.start();
                    }
                    public void cancel() {
                    try {
                    mmSocket.close();
                    } catch (IOException e) { }
            }
         }

Класс подключенного потока:

    private  class ConnectedThread extends Thread {
        private final BluetoothSocket mmSocket;
        private final InputStream mmInStream;
        private final OutputStream mmOutStream;

        public ConnectedThread(BluetoothSocket socket) {
        mmSocket = socket;
        InputStream tmpIn = null;
        OutputStream tmpOut = null;
        try {
        tmpIn = socket.getInputStream();
        tmpOut = socket.getOutputStream();
        } catch (IOException e) { 

        }
        mmInStream = tmpIn;
        mmOutStream = tmpOut;
        }
        public void run() {
        byte[] buffer = new byte[1024];
        int begin = 0;
        int bytes = 0;
        while (true) {
        try {
        bytes += mmInStream.read(buffer, bytes, buffer.length - bytes);
        for(int i = begin; i < bytes; i++) {
        if(buffer[i] == "#".getBytes()[0]) {
        mHandler.obtainMessage(1, begin, i, buffer).sendToTarget();
        begin = i + 1;
        if(i == bytes - 1) {
        bytes = 0;
        begin = 0;
            }
        }
        }
        } catch (IOException e) {
        break;
        }
        }
        }
        public void write(byte[] bytes) {
        try {
        mmOutStream.write(bytes);
        } catch (IOException e) { e.printStackTrace(); }
        }
        public void cancel() {
        try {
        mmSocket.close();
        } catch (IOException e) {

        }
        }
        }

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

    @Override
    public void onClick(View v) {
        // TODO Auto-generated method stub

        switch(v.getId()){
        case R.id.launchbutton:

            //when launch button pressed
            mConnectedThread.write(launch);

            break;
        case R.id.dockbutton :
            //when dock button pressed
            mConnectedThread.write(dock);

            break;
        case R.id.upnavbutton :
            //when dock button pressed
            mConnectedThread.write(up);

            break;
        case R.id.downnavbutton :
            //when dock button pressed
            mConnectedThread.write(down);

            break;
        case R.id.leftnavbutton :
            //when dock button pressed
            mConnectedThread.write(left);

            break;
        case R.id.rightnavbutton :
            //when dock button pressed
            mConnectedThread.write(right);

            break;
        case R.id.gearbutton1 :
            //when dock button pressed
            mConnectedThread.write(g1);

            break;
        case R.id.gearbutton2 :
            //when dock button pressed
            mConnectedThread.write(g2);

            break;
        case R.id.gearbutton3 :
            //when dock button pressed
            mConnectedThread.write(g4);

            break;
        case R.id.gearbutton4 :
            //when dock button pressed
            mConnectedThread.write(g3);

            break;
        }
        }

   }

Logcat:

04-10 06: 27: 33.389: D / dalvikvm (2489): GC_FOR_ALLOC освобожден 51K, 5% свободен 2977K/3124K, приостановлен 64 мс, всего 68 мс

04-10 06:27:33.629: D/dalvikvm(2489): GC_FOR_ALLOC освободил 5K, 4% - 3425K/3568K, приостановлено 5 мс, всего 5 мс

04-10 06:27:33.729: E/BluetoothAdapter(2489): связыватель Bluetooth нулевой

04-10 06:27:33.729: E/(2489): Bluetooth не поддерживается в этом устройстве

04-10 06:27:33.729: D/AndroidRuntime(2489): выключение виртуальной машины

04-10 06:27:33.729: W/dalvikvm(2489): threadid=1: поток завершается с необработанным исключением (группа = 0xb3cd2b20)

04-10 06:27:33.829: E/AndroidRuntime(2489): ИСКЛЮЧИТЕЛЬНОЕ ИСКЛЮЧЕНИЕ: основное

04-10 06:27:33.829: E/AndroidRuntime(2489): процесс: com.in2gravity.wheeler, PID: 2489

04-10 06:27:33.829: E/AndroidRuntime(2489): java.lang.RuntimeException: невозможно запустить действие ComponentInfo

{com.in2gravity.wheeler / com.in2gravity.wheeler.MainActivity}: java.lang.NullPointerException

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2195)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:2245)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.app.ActivityThread.access $ 800 (ActivityThread.java:135)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.app.ActivityThread $ H.handleMessage (ActivityThread.java:1196)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.os.Handler.dispatchMessage (Handler.java:102)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.os.Looper.loop (Looper.java:136)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.app.ActivityThread.main (ActivityThread.java:5017)

04-10 06:27:33.829: E/AndroidRuntime(2489): в java.lang.reflect.Method.invokeNative(собственный метод)

04-10 06:27:33.829: E/AndroidRuntime(2489): на java.lang.reflect.Method.invoke (Method.java:515)

04-10 06:27:33.829: E/AndroidRuntime(2489): на com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:779)

04-10 06:27:33.829: E/AndroidRuntime(2489): на com.android.internal.os.ZygoteInit.main (ZygoteInit.java:595)

04-10 06:27:33.829: E/AndroidRuntime(2489): at dalvik.system.NativeStart.main (собственный метод)

04-10 06:27:33.829: E/AndroidRuntime(2489): вызвано: java.lang.NullPointerException

04-10 06:27:33.829: E/AndroidRuntime(2489): в com.in2gravity.wheeler.MainActivity.onCreate (MainActivity.java:112)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.app.Activity.performCreate (Activity.java:5231)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1087)

04-10 06:27:33.829: E/AndroidRuntime(2489): на android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2159)

04-10 06:27:33.829: E/AndroidRuntime(2489):... еще 11

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

<ImageView
    android:id="@+id/appLogo"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerHorizontal="true"
    android:layout_centerVertical="true"
    android:contentDescription="@string/app_logo"
    android:src="@drawable/wheelerapp_logo2" />

<Button
    android:id="@+id/upnavbutton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_above="@+id/appLogo"
    android:layout_centerHorizontal="true"
    android:background="@drawable/upnavbutton" />

<Button
    android:id="@+id/downnavbutton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignRight="@+id/upnavbutton"
    android:layout_below="@+id/appLogo"
    android:background="@drawable/upnavbutton"
    android:rotation="180" />

<Button
    android:id="@+id/rightnavbutton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerVertical="true"
    android:layout_marginLeft="8dp"
    android:layout_toRightOf="@+id/appLogo"
    android:background="@drawable/rightnavbutton" />

<Chronometer
    android:id="@+id/chronometer1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/downnavbutton"
    android:layout_alignLeft="@+id/leftnavbutton"
    android:layout_marginLeft="16dp"
    android:text="Chronometer"
    tools:ignore="HardcodedText" />

<TextView
    android:id="@+id/propellerText"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/leftnavbutton"
    android:layout_alignLeft="@+id/launchbutton"
    android:text="@string/Propeller_Text"
    android:textAppearance="?android:attr/textAppearanceSmall" />

<TextView
    android:id="@+id/in2gravityText"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/chronometer1"
    android:layout_alignBottom="@+id/chronometer1"
    android:layout_alignLeft="@+id/propellerText"
    android:text="@string/in2gravity_text"
    android:textAppearance="?android:attr/textAppearanceMedium" />

<Button
    android:id="@+id/launchbutton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_above="@+id/rightnavbutton"
    android:layout_alignRight="@+id/rightnavbutton"
    android:layout_marginRight="14dp"
    android:background="@android:color/holo_green_light"
    android:text="@string/launchbutton_text" />

<Button
    android:id="@+id/dockbutton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_above="@+id/rightnavbutton"
    android:layout_alignLeft="@+id/chronometer1"
    android:background="@android:color/holo_red_light"
    android:text="@string/Dockbutton_text" />

<Button
    android:id="@+id/leftnavbutton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignTop="@+id/rightnavbutton"
    android:layout_marginRight="10dp"
    android:layout_marginTop="7dp"
    android:layout_toLeftOf="@+id/appLogo"
    android:background="@drawable/leftnavbutton" />

<Button
    android:id="@+id/gearbutton3"
    style="?android:attr/buttonStyleSmall"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/launchbutton"
    android:layout_alignBottom="@+id/launchbutton"
    android:layout_marginLeft="8dp"
    android:layout_toRightOf="@+id/upnavbutton"
    android:background="@android:color/holo_blue_light"
    android:text="@string/gearup2_text" />

<Button
    android:id="@+id/gearbutton4"
    style="?android:attr/buttonStyleSmall"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/gearbutton3"
    android:layout_toLeftOf="@+id/upnavbutton"
    android:background="@android:color/holo_purple"
    android:text="@string/gearup1_text" />

<Button
    android:id="@+id/gearbutton1"
    style="?android:attr/buttonStyleSmall"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/rightnavbutton"
    android:layout_toLeftOf="@+id/downnavbutton"
    android:background="@android:color/holo_orange_light"
    android:text="@string/geardown2_text" />

<Button
    android:id="@+id/gearbutton2"
    style="?android:attr/buttonStyleSmall"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignLeft="@+id/gearbutton3"
    android:layout_alignTop="@+id/gearbutton1"
    android:background="@android:color/holo_orange_dark"
    android:text="@string/geardown1_text" />

<TextView
    android:id="@+id/timerText"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/leftnavbutton"
    android:layout_alignParentLeft="true"
    android:layout_marginLeft="9dp"
    android:text="@string/timer_text"
    android:textAppearance="?android:attr/textAppearanceSmall" />

   </RelativeLayout>

androidManifest:

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

<uses-sdk
    android:minSdkVersion="15"
    android:targetSdkVersion="19" />
<uses-permission android:name="android.permission.BLUETOOTH"/>
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN"/>

<application
    android:icon="@drawable/wheelerapp_logo2"
    android:label="@string/app_name"

    android:theme="@style/AppBaseTheme" android:allowBackup="true">
    <activity
     android:screenOrientation="landscape"
        android:name="com.in2gravity.wheeler.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>

Примечание: я использую пользовательские кнопки в этом приложении, если это помогает. Среди 10 кнопок одна (все они построены одинаковым образом) upnavbutton.xml:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >

<item android:state_enabled="true" 
 android:state_pressed="true"      android:drawable="@drawable/upnavbutton_pressed" />
<item android:state_enabled="true"
 android:drawable="@drawable/upnavbutton_normal" />

</selector>

1 ответ

Решение

Я изучил несколько случаев, вызывающих эту ошибку, и обнаружил, что иногда она вызвана представлением xml, для которого мы устанавливаем представление содержимого. Как и в этой программе, сначала я построил кнопки и другие виды fragment_main.xml файл, затем столкнулся с исключением нулевого указателя на слушателей кнопки. И я думал, что это может конфликтовать с программой в любом случае.

Итак, я копирую вставить весь XML в activity_main.xml затем удалил fragment_main.xml, А также закомментировал раскладку для фрагмента. Это вызывало проблемы, такие как загрязнение в идентификаторах просмотров.

После этого я запустил программу, и она отлично работает.

Другие вопросы по тегам