错误的线程是睡觉的人

时间:2013-09-17 17:46:36

标签: java android multithreading events sleep

我在主线程中有一个创建另一个线程的事件。这个新线程必须休眠60秒,然后必须检查主线程状态。我的代码是这样的:

public class Act extends Activity {
    Object lock=new Object();
    public class MainT implements LocationListener {
         public String str="";
         public void onLocationChanged(Location location) {
              synchronized(lock) {
                   str=String.valueOf(location.getLatitude())+" "+String.valueOf(location.getLongitude());
                   new SecondT(str).start();
              }
         }

         class SecondT extends Thread {
              public String st;
              SecondT(String s) {
                   st=s;
              }

              public void run() {
                   waitSeconds();
              }

              public void waitSeconds() {
                   try {
                        Thread.sleep(60000);
                        synchronized(lock) {
                             if (str.equals(st))
                             Log.d("SecondT", "Same string.");
                        }
                   } catch (InterruptedException e) {
                        e.printStackTrace();
                   }
              }
         }

        @Override
        public void onProviderDisabled(String arg0) {
        // TODO Auto-generated method stub
        }

        @Override
        public void onProviderEnabled(String provider) {
            // TODO Auto-generated method stub

        }

        @Override
        public void onStatusChanged(String provider, int status, Bundle extras) {
            // TODO Auto-generated method stub
        }
    }

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        LocationManager locMan = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
        MainT mt = new MainT();
        locMan.requestLocationUpdates(LocationManager.GPS_PROVIDER, 60000, 50, mt);
    }
}

问题是,如果启动该线程,它就是MainT睡眠(即使我通过调试工具传递新坐标,也不会调用GPS事件)。

1 个答案:

答案 0 :(得分:1)

  

问题是,如果启动该线程,它就是MainT睡眠(即使我通过调试工具传递新坐标,也不会调用GPS事件)。

正如@Joni所提到的,除非更新字符串值的synchronized部分代码执行一些可能需要很长时间的复杂操作,否则很难看到main会在哪里睡觉。可能是主要试图分叉2个线程而第二个正在等待锁定?如果您提供更多代码,我们可能会看到您的问题。

在分叉线程和主线程之间共享st值方面,您可能会考虑像AtomicReference<String>这样的东西。这将允许您set(...)分叉线程中的值和get() main中的值而不锁定。