我在主线程中有一个创建另一个线程的事件。这个新线程必须休眠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事件)。
答案 0 :(得分:1)
问题是,如果启动该线程,它就是MainT睡眠(即使我通过调试工具传递新坐标,也不会调用GPS事件)。
正如@Joni所提到的,除非更新字符串值的synchronized
部分代码执行一些可能需要很长时间的复杂操作,否则很难看到main会在哪里睡觉。可能是主要试图分叉2个线程而第二个正在等待锁定?如果您提供更多代码,我们可能会看到您的问题。
在分叉线程和主线程之间共享st
值方面,您可能会考虑像AtomicReference<String>
这样的东西。这将允许您set(...)
分叉线程中的值和get()
main中的值而不锁定。