Форум программистов, компьютерный форум CyberForum.ru

Тонкости потоков - Android

Восстановить пароль Регистрация
Другие темы раздела
Android Не отображаются логи в Logcat http://www.cyberforum.ru/android-dev/thread1142936.html
Ребят подскажите в чем проблема не отображаются логи в LogCat должны отображаться логи методов } // Конец onCreate(Bundle) @Override public void onStart(){ super.onStart(); Log.d(TAG, "onStart() called"); }
Android Небольшой конфуз с запуском второй Activity Всем приветик! Возникла небольшая проблемка с передачей данных между двумя активити. Вот код первой активити: import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.Menu; http://www.cyberforum.ru/android-dev/thread1142831.html
Android Создание ListView с CheckBox из БД
Привет, приложение создает БД с полями id, String и Int _id Name Check 1 Москва 1 2 Казань 0 3 Ростов 0 4 Минск 1 5 Дели 1
Как создать обработчик нажатия на картинку Android
Как создать обработчик нажатия на картинку если она не является View элементов, она часть слоев.
Android Pdf водяные знаки http://www.cyberforum.ru/android-dev/thread1142716.html
как программно реализовать вывод на каждой странице документа водяного знака?
Android Как программно создать ImageView Как программно создать ImageView и присвоить ему ID? подробнее

Показать сообщение отдельно
Netscape
 Аватар для Netscape
371 / 358 / 48
Регистрация: 02.10.2009
Сообщений: 712
Записей в блоге: 4
10.04.2014, 16:05     Тонкости потоков
Скажу сразу, я в этих вопросах не сильно компетентен, но попробую пояснить как это понимаю я сам.
Константу, которая отвечает за Thread stack size, можно найти в исходниках файла /vm/Thread.h.
#define kDefaultStackSize
по версиях:
API 3 (Android 1.5) = 8KB
API 4-10 (Android 1.6 - Android 2.3.7) = 12KB
API 14-19 (Android 4.0 - Android 4.4.2) = 16KB
Вот файл из исходников 4.4.2, строчка 79:
https://android.googlesource.com/pla...r2/vm/Thread.h

Если под поток выделяется 16кб, то кажется, что когда их будет много, они сожрут всю доступную память, возможно, андроид начнет освобождать ее, убивая все что сможет убить, после чего получим OutOfMemoryError.
Скорее всего, выброшен он будет при попытке создания нового потока и выделения под него памяти.
java.lang.OutOfMemoryError: unable to create new native thread
at java.lang.Thread.start0(Native Method)
at java.lang.Thread.start(Thread.java:640)
Добавлено через 1 час 38 минут
Решил проверить свою теорию.
pthread_create failed: couldn't allocate 1048576-byte stack
pthread_create (stack size 16384 bytes) failed: Try again

After creating 1,506 threads, java.lang.OutOfMemoryError: pthread_create (stack size 16384 bytes) failed: Try again
at java.lang.VMThread.create(Native Method)
at java.lang.Thread.start(Thread.java:1029)
Запускал на Samsung SIII, как видим, после создания 1,506 потоков, приложение благополучно упало.

Проверял этим:
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
public class MainActivity extends ActionBarActivity {
 
    public static final int BATCH_SIZE = 40;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
 
        List<Thread> threads = new ArrayList<Thread>();
        try {
            for (int i = 0; i <= 10 * 1000; i += BATCH_SIZE) {
                long start = System.currentTimeMillis();
                addThread(threads, BATCH_SIZE);
                long end = System.currentTimeMillis();
                Thread.sleep(500);
                long delay = end - start;
                System.out.printf("%,d threads: Time to create %,d threads was %.3f seconds %n", threads.size(), BATCH_SIZE, delay / 1e3);
            }
        } catch (Throwable e) {
            System.err.printf("After creating %,d threads, ", threads.size());
            e.printStackTrace();
        }
    }
 
    private static void addThread(List<Thread> threads, int num) {
        for (int i = 0; i < num; i++) {
            Thread t = new Thread(new Runnable() {
                @Override
                public void run() {
                    try {
                        while (!Thread.interrupted()) {
                            Thread.sleep(1000);
                        }
                    } catch (InterruptedException ignored) {
                        //
                    }
                }
            });
            t.setDaemon(true);
            t.setPriority(Thread.MIN_PRIORITY);
            threads.add(t);
            t.start();
        }
    }
 
}


Добавлено через 2 минуты
По-ходу, стек для потока выделяется из heap, а не оперативной памяти.
 
Текущее время: 08:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru