AsyncTask,在 Android 中 doInBackground 从不运行。

4

当我尝试启动我的doinbackground等待接收消息时,它从来没有真正运行,而是直接跳过它。

public class Incomingdata extends AsyncTask<Void,Void,Void>
{
    Socket s  ;
    String input;

    public Incomingdata(Socket socket)
    {   
        super();
        this.s = socket;
    }

    @Override
    protected Void doInBackground(Void... params) 
    {
        Log.i("ddd","Got here before try");
        try
        {   
            InputStream in = s.getInputStream();
            Scanner r = new Scanner(in);
            Log.i("Info",s.getPort()+"");
            Log.i("ddd","Got here");
            while(s.isConnected() && r.hasNext())
            {
                String input =r.nextLine(); 
            }
        }
        catch (UnknownHostException e) 
        {
               e.printStackTrace();
        }
        catch (IOException e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        catch(NoSuchElementException e)
        {
            e.printStackTrace();
        }
        return null;
    }

    @Override
    protected void onPostExecute(Void input)
    {
        System.out.println("123"+input);
    }

}

这是我的日志记录:

 java.net.Socket.startupSocket(Socket.java:724)
04-25 23:50:26.659: W/System.err(28882):    at java.net.Socket.<init>(Socket.java:263)
04-25 23:50:26.659: W/System.err(28882):    at com.example.handy.myComs.sending_data(myComs.java:23)
04-25 23:50:26.659: W/System.err(28882):    at com.example.handy.MainActivity.readSms(MainActivity.java:277)
04-25 23:50:26.659: W/System.err(28882):    at com.example.handy.MainActivity$1.onClick(MainActivity.java:92)
04-25 23:50:26.659: W/System.err(28882):    at android.view.View.performClick(View.java:2485)
04-25 23:50:26.659: W/System.err(28882):    at android.view.View$PerformClick.run(View.java:9080)
04-25 23:50:26.659: W/System.err(28882):    at android.os.Handler.handleCallback(Handler.java:587)
04-25 23:50:26.659: W/System.err(28882):    at android.os.Handler.dispatchMessage(Handler.java:92)
04-25 23:50:26.659: W/System.err(28882):    at android.os.Looper.loop(Looper.java:130)
04-25 23:50:26.659: W/System.err(28882):    at android.app.ActivityThread.main(ActivityThread.java:3687)
04-25 23:50:26.659: W/System.err(28882):    at java.lang.reflect.Method.invokeNative(Native Method)
04-25 23:50:26.659: W/System.err(28882):    at java.lang.reflect.Method.invoke(Method.java:507)
04-25 23:50:26.659: W/System.err(28882):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
04-25 23:50:26.659: W/System.err(28882):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
04-25 23:50:26.659: W/System.err(28882):    at dalvik.system.NativeStart.main(Native Method)
04-25 23:50:26.729: I/System.out(28882): 123null

这是我调用它的地方。
public class myComs 
{
    private static int i = 0;

    public static void sending_data(String ipAddress, String message)
    {
        try
        {
            InetAddress inet = InetAddress.getByName(ipAddress);
            Socket s = new Socket(inet, 2000);
            OutputStream o = s.getOutputStream();
            PrintWriter p = new PrintWriter(o);
            while(i<1)
            {
                new Incomingdata(s).execute();
                i++;
            }
            p.println(message);
            p.flush();
        }
        catch (UnknownHostException e)
        {
            e.printStackTrace();
        }
        catch (IOException e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

如您所见,通过123null,它从未等待任何帮助。因为我已经花费了很长时间却没有任何进展,所以希望您能提供帮助。

谢谢!

更新 好的,我现在知道它正在获取端口,但仍然没有等待传入数据,而是直接结束了。


展示你的代码调用部分。 - minhaz
Log.i("ddd","Got here before try"); 显示了吗? - wtsang02
1
看起来你的代码在调用AsyncTask之前就失败了。当你创建Socket时,出现了at com.example.handy.myComs.sending_data(myComs.java:23) - SimonSays
你看,问题是我并没有在那里创建套接字,但每次在尝试使用ASYNCTASK之前似乎总会出现警告。程序一直按照我的要求执行,就像它应该做的那样。 - Paul Pandaboy Dennehy
1
@PaulPandaboyDennehy 请在那一行尝试使用 System.out.println("Got here before try");。如果它显示出来,一切都应该很清楚了。 - wtsang02
显示剩余3条评论
3个回答

0
我的问题是我像个傻瓜一样创建了太多次套接字,所以我只需创建一次套接字,然后调用它多次,现在看起来像魔法一样正常工作。
这是我的异步任务。
public class Incomingdata extends AsyncTask<Void,Void,String>
{

    Socket s  ;
    String input;

    public Incomingdata(Socket socket)
    {   
        super();
        this.s = socket;


    }





    @Override
    protected String doInBackground(Void... params) 
    {Log.i("ddd","Got here before try");
        try
        {   System.out.println("Got here");
            InputStream in = s.getInputStream();
            Scanner r = new Scanner(in);
            Log.i("Info",s.getPort()+"");
            Log.i("ddd","Got here");        

            input =r.nextLine();    


        }
        catch (UnknownHostException e) 
        {

               e.printStackTrace();
        }
        catch (IOException e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        catch(NoSuchElementException e)
        {
            e.printStackTrace();
        }
        return input ;
    }

    @Override
    protected void onPostExecute(String input)
    {

        String number = input.substring(0, 21).trim();
        String message = input.substring(20);
        System.out.println(""+input);
        sendSMS(number,message);
        new Incomingdata(s).execute();

    }

这是我创建套接字的地方

    public class myComs
{
    private static int i = 0;
    private static InetAddress inet;
    private static Socket s;
    private static OutputStream o;
    private static PrintWriter p;

    public static void createSocket(String ipAddress)
    {
        try
        {
            inet = InetAddress.getByName(ipAddress);

            s = new Socket(inet, 2000);
            o = s.getOutputStream();
            p = new PrintWriter(o);
            new Incomingdata(s).execute();
        }
        catch (Exception e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

    public static void sending_data(String message)
    {


        p.println(message);
        p.flush();

    }

}

然后在我的MainActivity上

   myComs.createSocket(getMyIp());

从文本字段中创建的set/get中获取我的IP,感谢您的帮助。

0

我注意到你正在使用

System.out.println("123"+input);

针对一种类型的调试,使用Log.d,其他情况下使用Log.i。也许代码在运行,但你的日志视图没有正确设置,无法看到Log.i。

如果你使用System.out来代替Log.i,你能看到其他的消息吗?


抱歉,我刚刚尝试了一下,它仍然直接进入 System.out.println("123"+input); 而从未进入 try doInBackground。 - Paul Pandaboy Dennehy
你把这行代码改成了什么?从 Log.i("ddd","Got here before try"); 改为 System.out.println("Got here before try") 了吗? - HalR
是的,我试过了,但仍然没有任何反应,它仍然直接输出 System.out.println("123"+input);。 - Paul Pandaboy Dennehy

0

你是否同时使用了多个异步任务?因为你的代码看起来没问题。在2.3之后,异步任务模型已经改变,禁止它们并行运行。请查看thisthis的SO问题。


是的,我正在运行2.3.5版本,但我只是尝试运行一个AsyncTask,目的是让套接字等待并监听传入的数据。 - Paul Pandaboy Dennehy

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接