У меня есть приложение пользовательского интерфейса, которое настроено на автозапуск при запуске, которое порождает несколько потоков, выполняющих некоторую работу в фоновом режиме. Он имеет один экран, который отображает информацию о работе фоновых потоков.
class AppName extends UiApplication implements SystemListener2 {
private static AppName app;
public static void main(String[] args) {
app = new AppName();
if (ApplicationManager.getApplicationManager().inStartup()) {
app.addSystemListener(app);
} else {
app.initializeLater();
}
app.enterEventDispatcher();
}
public AppName() {
pushScreen(new InfoScreen());
requestBackground();
}
private void initialize() {
// Spawns some threads doing work in the background
}
private void initializeLater() {
invokeLater(new Runnable() {
public void run() {
initialize();
}
});
}
public void powerUp() {
removeSystemListener(this);
initialize();
}
}
Когда я запускаю приложение в симуляторе, оно работает нормально. При запуске все запускается, а затем, когда я нажимаю на иконку, экран становится основным и отображается. Это вывод симулятора:
3:20:26.612: AM: Starting AppName
3:20:26.612: AM: AppName already running
3:20:26.612: AM: Foreground is requested: AppName(304)
3:20:26.628: AM: Foreground is set: AppName(304)
Однако на устройстве экран никогда не отображается. Это вывод отладчика устройства:
[0.0] Starting AppName
[0.0] AppName already running
Как видите, запрос переднего плана никогда не выполняется. Я подтвердил это, переопределив метод UiApplication.activate () и поместив сообщение System.out, чтобы увидеть, вызывается ли он, но не вызывается.
Кто-нибудь знает, почему это происходит?