我的套用应用程式停止运作-如何解决?

时间:2018-09-15 18:06:56

标签: java android sockets crash

我正在尝试创建一个Android应用程序,该应用程序将通过套接字发送字符串,但是一旦在我的android系统上启动,该应用程序便立即停止运行,我的主要活动代码是:

package com.example.phoenix.coreclient;

import android.app.Activity;
import android.os.AsyncTask;
import android.os.Bundle;
import android.provider.Settings.System;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.view.View.OnClickListener;

import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;

class AsyncTaskActivity extends Activity implements OnClickListener {

Button btn;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    btn = (Button) findViewById(R.id.button_id);
    // because we implement OnClickListener we only have to pass "this"
    // (much easier)
    btn.setOnClickListener(this);
}

public void onClick(View view) {
    // detect the view that was "clicked"
    switch (view.getId()) {
        case (R.id.button_id):
            new LongOperation().execute("");
            break;
    }
}

private class LongOperation extends AsyncTask<String, Void, String> {

    @Override
    protected String doInBackground(String... params) {
        for (int i = 0; i < 5; i++) {
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                Thread.interrupted();
            }
        }
        return "Executed";
    }

    @Override
    protected void onPostExecute(String result) {
        final TextView mStatusText = (TextView) findViewById(R.id.text_view_id);

        try {
            Socket socket = new Socket("192.168.1.68", 60000);
            OutputStream out = socket.getOutputStream();
            PrintWriter output = new PrintWriter(out);

            mStatusText.setText("Sending Data to PC");
            output.println("Hello from Android");
            out.flush();
            out.close();
            mStatusText.setText("Data sent to PC");

            socket.close();
            mStatusText.setText("Socket closed");
        } catch (Exception e) {
            mStatusText.setText(e.toString());
        }
    }

    @Override
    protected void onPreExecute() {
    }

    @Override
    protected void onProgressUpdate(Void... values) {
        }
    }
}

我不太擅长调试,我需要一些帮助

09-15 21:01:38.837 29818-29818/? D/dalvikvm: Late-enabling CheckJNI
09-15 21:01:38.951 29818-29818/com.example.phoenix.coreclient D/HyLog: I : /data/font/config/dfactpre.dat, No such file or directory (2)
09-15 21:01:39.061 29818-29818/com.example.phoenix.coreclient D/AndroidRuntime: Shutting down VM
09-15 21:01:39.061 29818-29818/com.example.phoenix.coreclient W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0x419a8d58)
09-15 21:01:39.080 29818-29818/com.example.phoenix.coreclient E/AndroidRuntime: FATAL EXCEPTION: main
                                                                                Process: com.example.phoenix.coreclient, PID: 29818
                                                                                java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.phoenix.coreclient/com.example.phoenix.coreclient.MainActivity}: java.lang.ClassNotFoundException: Didn't find class "com.example.phoenix.coreclient.MainActivity" on path: DexPathList[[zip file "/data/app/com.example.phoenix.coreclient-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.example.phoenix.coreclient-2, /vendor/lib, /system/lib]]
                                                                                    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2128)
                                                                                    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2252)
                                                                                    at android.app.ActivityThread.access$800(ActivityThread.java:139)
                                                                                    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1200)
                                                                                    at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                                    at android.os.Looper.loop(Looper.java:136)
                                                                                    at android.app.ActivityThread.main(ActivityThread.java:5103)
                                                                                    at java.lang.reflect.Method.invokeNative(Native Method)
                                                                                    at java.lang.reflect.Method.invoke(Method.java:515)
                                                                                    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
                                                                                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
                                                                                    at dalvik.system.NativeStart.main(Native Method)
                                                                                 Caused by: java.lang.ClassNotFoundException: Didn't find class "com.example.phoenix.coreclient.MainActivity" on path: DexPathList[[zip file "/data/app/com.example.phoenix.coreclient-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.example.phoenix.coreclient-2, /vendor/lib, /system/lib]]
                                                                                    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
                                                                                    at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
                                                                                    at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
                                                                                    at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
                                                                                    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2119)
                                                                                    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2252) 
                                                                                    at android.app.ActivityThread.access$800(ActivityThread.java:139) 
                                                                                    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1200) 
                                                                                    at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                                                    at android.os.Looper.loop(Looper.java:136) 
                                                                                    at android.app.ActivityThread.main(ActivityThread.java:5103) 
                                                                                    at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                                    at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                                    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) 
                                                                                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605) 
                                                                                    at dalvik.system.NativeStart.main(Native Method) 

那么这里的问题是什么,我该如何解决?我已经添加了互联网许可,并且服务器端是经过测试的计算机上的简单python代码,并且运行正常

2 个答案:

答案 0 :(得分:0)

您必须检查清单文件中的LAUNCHER活动,或将类名称更改为MainActivity

答案 1 :(得分:0)

您没有将活动添加到AndroidManifest.xml中。 您应该在清单文件中注册活动。

应该是这样的:

<application
    android:name=".Phoenix"
    android:icon="@mipmap/ic_launcher"
    ...>
    <activity
        android:name=".AsyncTaskActivity"
        ...>
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    ...
</application>