2

ソケットを作成するサービスを作成しましたが、サーバーから送信されたデータを読み取ろうとするとすぐにハングします。一方、サービスを使用していないのにプレーンなアクティビティを使用していない場合、同じコードが実行されますか??

        import android.app.*;
        import android.content.*;
        import android.os.*;
        import android.util.*;
        import java.net.*;
        import java.io.*;
        import android.widget.*;




     public class BackgroundService extends Service
            {
                    private Socket socket=null;
                    private  InputStreamReader  in=null;
                    private String ip;

                    private String tag="BackgroundService";

                    public IBinder onBind(Intent p1)
                    {
                            // TODO: Implement this method
                            return null;
                    }

             public void onCreate(){
                     super.onCreate();




             }
            public void onStart(Intent i,int id){
             super.onStart(i,id);
                    ip=i.getStringExtra("Ip");

             Log.v(tag,"Ip "+i.getStringExtra("Ip"));
                    try
                    {
                            socket = new Socket(ip.trim(), 8888);
                            new Runnable() {

                                    public void run()
                                    { 
//                                        Hangs in this block.....
                                            try
                                            {
                                                    in = new InputStreamReader (socket.getInputStream());
                                            BufferedReader bf=new BufferedReader (in);
        //                                 Never Reaches this messge
                                            Log.v(tag,"mess:"+bf.readLine() );
                                            }
                                            catch (IOException e)
                                            {
                                                    e.printStackTrace();
                                            }


                                    }


                            }.run();



                    }
                    catch (IOException e)
                    {
                            e.printStackTrace();
                    }



            }

            }
4

1 に答える 1

2

Log.vは、値を出力できない問題であるため、System.out.println()を使用すると、bf.printlineにメッセージが含まれます。

于 2012-10-04T08:52:30.077 に答える