Мое приложение использует службы (клиент и сервер) для обработки связи Bluetooth между экземплярами сверстников в отдельных телефонах. Каждый из этих сервисов создает отдельный поток для обработки связи сокета. Служба клиента, пытаясь подключиться к своему одноранговому, улавливая исключение, если подключение не удалось, потому что одноранговый экзамен не активен, и запоминает после короткого ожидания. Все работает нормально, когда приложение находится на переднем плане. На заднем плане я вижу в logcat, что через короткое время onresume () не называется, когда приложение выходит на передний план, а приложение вскоре после этого. Насколько мне известно, я не намеренно не буду ждать в основном потоке. выпускаются. Я не думаю, что это неверная проблема ресурсов, так как цикл повторного рита, по-видимому, работает бесконечно на переднем плане, но если приложение помещается на фоновой передний план. Сообщения журнала отладки показывают, что OnResume () больше не называется. Другие сообщения журнала показывают, что клиентский поток продолжает работать нормально. Вскоре после этого появляется сообщение «waistingInmainsignalCatcherLoop: реагирование на сигнал 3» и приложение завершено.while (!model.clientStopping()) { // keep going until explicitly stopped
// cancel discovery because it otherwise slows down the connection.
getBluetoothAdapter().cancelDiscovery();
try {
// obtain a client socket
clientSocket = getBluetoothDevice().createRfcommSocketToServiceRecord(MY_UUID);
int count = model.getSocketCount().getValue();
model.updateSocketCount(++count);
} catch (IOException createSocketException) {
// treat this as a terminal error or we may just loop trying
model.setClientStopping(true);
break; // exit the connect loop
}
// we have a socket, now make a connection. If this fails, keep trying every n seconds
while (!connected && !model.clientStopping()) {
try {
// Connect to the remote server. If the server is not available
// an exception is thrown
clientSocket.connect();
connected = true;
...
} catch (IOException connectException) {
try {
clientSocket.close();
} catch (IOException ignored) {}
connectRetryCount++;
try {
// after the initial attempts, slow down the retry rate
int sleepTime = model.getConnectRetryTime();
if (connectRetryCount > model.getFastConnectRetryLimit()) {
sleepTime = sleepTime * model.getSlowConnectRetryFactor();
}
Thread.sleep(sleepTime);
} catch (InterruptedException ignored) {
// if the sleep gets interrupted, it just means the retry will be sooner
}
break;
}
}
if (connected) { // connected successfully
connectRetryCount = 0;
...
}
}
< /code>
пользовательский интерфейс - это фрагмент, а модель, полученная из ViewModel: < /p>
public class FirstFragment extends Fragment {
private BuddyModel buddyModel;
@Override
public View onCreateView(
@NonNull LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
model = ViewModelProviders.of(this).get(BuddyModel.class);
...
}
}
< /code>
и < /p>
public class BuddyModel extends ViewModel {
...
}
< /code>
Служба клиентов обновляет пользовательский интерфейс через наблюдателей на объектах Livedata, определенных в модели, и я вижу из журналов, что эти наблюдатели не запускаются, когда приложение находится в фоновом режиме - Основная проверка реальности о том, что вещи ведут себя в некоторой степени, как и ожидалось.>
Подробнее здесь: https://stackoverflow.com/questions/794 ... gnalcatche
Замораживание пользовательского интерфейса после приложения, принесенного с фона, ведущего к ожиданию wallinmainsignalca ⇐ Android
Форум для тех, кто программирует под Android
1740412660
Anonymous
Мое приложение использует службы (клиент и сервер) для обработки связи Bluetooth между экземплярами сверстников в отдельных телефонах. Каждый из этих сервисов создает отдельный поток для обработки связи сокета. Служба клиента, пытаясь подключиться к своему одноранговому, улавливая исключение, если подключение не удалось, потому что одноранговый экзамен не активен, и запоминает после короткого ожидания. Все работает нормально, когда приложение находится на переднем плане. На заднем плане я вижу в logcat, что через короткое время onresume () не называется, когда приложение выходит на передний план, а приложение вскоре после этого. Насколько мне известно, я не намеренно не буду ждать в основном потоке. выпускаются. Я не думаю, что это неверная проблема ресурсов, так как цикл повторного рита, по-видимому, работает бесконечно на переднем плане, но если приложение помещается на фоновой передний план. Сообщения журнала отладки показывают, что OnResume () больше не называется. Другие сообщения журнала показывают, что клиентский поток продолжает работать нормально. Вскоре после этого появляется сообщение «waistingInmainsignalCatcherLoop: реагирование на сигнал 3» и приложение завершено.while (!model.clientStopping()) { // keep going until explicitly stopped
// cancel discovery because it otherwise slows down the connection.
getBluetoothAdapter().cancelDiscovery();
try {
// obtain a client socket
clientSocket = getBluetoothDevice().createRfcommSocketToServiceRecord(MY_UUID);
int count = model.getSocketCount().getValue();
model.updateSocketCount(++count);
} catch (IOException createSocketException) {
// treat this as a terminal error or we may just loop trying
model.setClientStopping(true);
break; // exit the connect loop
}
// we have a socket, now make a connection. If this fails, keep trying every n seconds
while (!connected && !model.clientStopping()) {
try {
// Connect to the remote server. If the server is not available
// an exception is thrown
clientSocket.connect();
connected = true;
...
} catch (IOException connectException) {
try {
clientSocket.close();
} catch (IOException ignored) {}
connectRetryCount++;
try {
// after the initial attempts, slow down the retry rate
int sleepTime = model.getConnectRetryTime();
if (connectRetryCount > model.getFastConnectRetryLimit()) {
sleepTime = sleepTime * model.getSlowConnectRetryFactor();
}
Thread.sleep(sleepTime);
} catch (InterruptedException ignored) {
// if the sleep gets interrupted, it just means the retry will be sooner
}
break;
}
}
if (connected) { // connected successfully
connectRetryCount = 0;
...
}
}
< /code>
пользовательский интерфейс - это фрагмент, а модель, полученная из ViewModel: < /p>
public class FirstFragment extends Fragment {
private BuddyModel buddyModel;
@Override
public View onCreateView(
@NonNull LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
model = ViewModelProviders.of(this).get(BuddyModel.class);
...
}
}
< /code>
и < /p>
public class BuddyModel extends ViewModel {
...
}
< /code>
Служба клиентов обновляет пользовательский интерфейс через наблюдателей на объектах Livedata, определенных в модели, и я вижу из журналов, что эти наблюдатели не запускаются, когда приложение находится в фоновом режиме - Основная проверка реальности о том, что вещи ведут себя в некоторой степени, как и ожидалось.>
Подробнее здесь: [url]https://stackoverflow.com/questions/79464160/ui-freeze-after-app-brought-from-background-leading-to-waitinginmainsignalcatche[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия