2013-09-24 60 views
0

我有这样的代码:我需要一些帮助等待的线程结束

jsonObject1=getLocationInfo(direction); 

它的目的是返回一个JSONObject,以后将被解析,我会得到lattitude和经度。

这是方法:

public JSONObject getLocationInfo(final String address) { 

      Thread thread=new Thread(){ 

       public void run(){ 
        String adressString=address.replaceAll("\\s+",","); 
        StringBuilder stringBuilder = new StringBuilder(); 

        try { 



        HttpPost httppost = new HttpPost("http://maps.google.com/maps/api/geocode/json?address=" + adressString + "&sensor=false"); 
        HttpClient client = new DefaultHttpClient(); 
        HttpResponse response; 
        stringBuilder = new StringBuilder(); 


         response = client.execute(httppost); 
         HttpEntity entity = response.getEntity(); 
         InputStream stream = entity.getContent(); 
         int b; 
         while ((b = stream.read()) != -1) { 
          stringBuilder.append((char) b); 
         } 

        } catch (ClientProtocolException e) { 
        } catch (IOException e) { 
        } 

        ; 
        try { 
         jsonObject = new JSONObject(stringBuilder.toString()); 
        } catch (JSONException e) { 
         // TODO Auto-generated catch block 
         e.printStackTrace(); 
        } 



       } 
      }; 
      thread.start(); 

      return jsonObject; 
     } 

问题是...因为这方法涉及HTTPGET,它必须在另一个线程。但是,在thread.start()方法之后,返回的jsonObject行被调用,所以返回的对象将为空......我怎么能等待线程在返回之前结束?

谢谢。

+1

使用asynctask它更容易编码。 – Raghunandan

+0

如果您在开始/等待某个线程后不做任何操作,则不需要/不应该使用线程。你不会得到'NetworkOnMainThreadException',因为你隐藏了阻止http的主线程的事实,但你基本上是在主线程中执行它,因为只要另一个线程执行http,它就会等待。 – zapl

回答

0

使用AsyncTask,所有网络的东西是在doInBackground完成,之后即大功告成onPostExecute被调用,让你知道当HTTPGET已完成,你需要做的还有

+0

我的课程扩展服务,所以我不能扩展AsyncTask – Fustigador

+0

你创建AsyncTask作为你的服务中的内部类 – tyczj

+0

我会寻找一些关于这个的例子... – Fustigador

0

很少有什么方法如何做到这一点。但是,如果您只是想使用上面的线程,请使用Handler并通过Handlers发送数据。让我知道您是否想要查看一些代码。