[英]Android Service with multiple Threads
我已经建立了一个ListView。 每个ListView-Items都包含一个ToggleButton,该按钮可启动或停止服务中的线程。
只要激活toggleButtons,线程就需要运行。 如果活动停止,则该服务和已激活的线程需要继续。
//In MainActivity
@Override
public void onCheckedChanged(CompoundButton buttonView,
boolean isChecked) {
Intent intent = new Intent(context,MyService.class);
intent.putExtra("id",listviewPosition);
startService(intent);
}
//MyService
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
// Thread(startId) starten
HandlerThread thread = new HandlerThread(String.valueOf(startId));
thread.start();
// Threads looper holen und beim servicehandler benutzen
serviceHandler = new ServiceHandler(thread.getLooper());
listServericeHandler.add(serviceHandler);
//message ausm pool holen
Message msg = serviceHandler.obtainMessage();
msg.arg1 = startId;
serviceHandler.sendMessage(msg);
return START_STICKY;
}
private final class ServiceHandler extends Handler {
public ServiceHandler(Looper looper) {
super(looper);
}
@Override
public void handleMessage(Message msg) {
while (continueUntilToggleButtonIsDeactivated) {
Log.d(MainActivity.TAG, "Thread " + tring.valueOf(msg.arg1)
+ " running: " + url.toExternalForm());
synchronized (this) {
try {
//do stuff
wait(1000);
} catch (Exception e) {
}
}
}
}
}
因此,我每次激活toggleButton时都试图在OnStartCommand()
启动线程。
我不知道如何停止线程并退出while循环。
您只需要为while循环创建一个标志即可遵守,以知道何时停止。 例如:
private final class ServiceHandler extends Handler {
private volatile boolean _continueRunning = true;
public ServiceHandler(Looper looper) {
super(looper);
}
public void stopRunning() {
_continueRunning = false;
this.notify(); //Interrupts the wait
}
@Override
public void handleMessage(Message msg) {
while (_continueRunning) { //Watches the variable
Log.d(MainActivity.TAG, "Thread " + tring.valueOf(msg.arg1)
+ " running: " + url.toExternalForm());
synchronized (this) {
try {
//do stuff
wait(1000);
} catch (Exception e) {}
}
}
}
编辑
您应该在服务的onCreate()
方法中创建处理程序。 onStartCommand
方法通知您新消息。
//In your Service Class
...
private ServiceHandler _serviceHandler;
@Override
public void onCreate() {
HandlerThread thread = new HandlerThread("ServiceClassName");
thread.start();
// Threads looper holen und beim servicehandler benutzen
serviceHandler = new ServiceHandler(thread.getLooper());
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
//message ausm pool holen
Message msg = _serviceHandler.obtainMessage();
msg.arg1 = startId;
serviceHandler.sendMessage(msg);
return START_STICKY;
}
private class mRunnable implements Runnable {
private volatile boolean _continueRunning = true;
@Override
public void run() {
while (_continueRunning) { //Watches the variable
synchronized (this) {
try {
//do stuff
wait(1000);
} catch (Exception e) {
//Purposefully left blank
}
}
}
}
public void stopRunning() {
_continueRunning = false;
this.notify();
}
}
然后您将ServiceHandler更改为
private final class ServiceHandler extends Handler {
//TODO whatever type of list you need
private List<mRunnable> _runningThreads = new LinkedList<mRunnable>();
public ServiceHandler(Looper looper) {
super(looper);
}
@Override
public void handleMessage(Message msg) {
mRunnable runnable = new mRunnable();
new Thread(runnable).start();
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.