Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 05.07.2019
Сообщений: 43

Exception in thread "main" java.lang.StackOverflowError

04.11.2021, 15:12. Показов 1051. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Exception in thread "main" java.lang.StackOverflowError
at TaskQueue.push(TaskQueue.java:21)
at TaskQueue.push(TaskQueue.java:21)
at TaskQueue.push(TaskQueue.java:21)
at TaskQueue.push(TaskQueue.java:21)

Почему так происходит? Как исправить?
Так же, по неизвестным мне причинам isEmpty возвращает всегда 0.
И метод shwResult не работает.


Main
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import java.util.*;
 
public class Main {
    public static void main(String[] args) {
 
        ArrayList<Integer> num = new ArrayList<Integer>();
        TaskQueue tq = new TaskQueue();
        MyTask t = new MyTask(1);
 
        long start, end;
        start = System.currentTimeMillis();
        t.findPrime(num, 0, 9);
        tq.push(t);
    }
}
MyTask
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import java.util.*;
 
 
public class MyTask<E> {
 
    private int start;
    private int end;
    private final int size;
    private ArrayList<Integer> answer;
    private ArrayList<Integer> num;
 
    public MyTask(int size) {
        this.size = size;
    }
 
    /*    public int[] findPrime(int[] nums, int start, int end) {
            int[] result = new int[size];
            for (int k = 0; k < size; k++) {
                for (int j = 2; j < nums[start]; j++) {
                    while(start != end + 1) {
                        if (nums[start] % j == 0) {
                            System.out.println("Vse");
                            break;
                        }
                        result[end - start] = nums[k];
                    }
                    start++;
                }
            }
            return result;
        } */
    public ArrayList<Integer> findPrime(ArrayList<Integer> num, int start, int end) {
        int m = 0;
        int a = 0;
        Integer[] nums = new Integer[10];
        Random r = new Random();
        for (int i = 0; i < nums.length; i++) {
            nums[i] = r.nextInt(24);
        }
        Integer[] res = new Integer[nums.length];
        System.arraycopy(nums, 0, res, 0, nums.length);
        if (start == 0 && end == nums.length - 1) {
            for (int k = start; k < end + 1; k++) {
                for (int j = 2; j < (nums[k] / 2) + 1; j++) {
                    if (nums[k] % j == 0) {
                        res[a] = m;
                        break;
                    }
                }
                a++;
            }
        }
        if (start > 0 || end < nums.length) {
            for (int k = start; k < end + 1; k++) {
                for (int j = 2; j < (nums[k] / 2) + 1; j++) {
                    for (int z = 0; z < start; z++) {
                        res[z] = m;
                        if (nums[k] % j == 0) {
                            res[k] = m;
                        }
                    }
                    for (int q = end + 1; q < nums.length; q++) {
                        res[q] = m;
                        if (nums[k] % j == 0) {
                            res[k] = m;
                        }
                    }
                }
                a++;
            }
        }
 
        System.out.println(Arrays.toString(nums));
        ArrayList<Integer> answer = new ArrayList<>(Arrays.asList(res));
        answer.removeIf(nSet -> nSet == 0);
        this.answer = answer;
        System.out.println(this.answer);
        return this.answer;
    }
 
    public ArrayList<Integer> getPrime() {
        return this.answer;
    }
 
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append(this.num);
        return sb.toString();
    }
 
}
TaskQueue
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
import java.util.ArrayList;
import java.util.LinkedList;
 
public class TaskQueue extends LinkedList<MyTask> {
    private int index = -1;
 
    public TaskQueue() {
        super();
    }
 
    public MyTask pop() {
        if(index < this.size() && !this.isEmpty()) {
            index++;
            return this.get(index);
        } else {
            return null;
        }
    }
 
    public void push(MyTask t) {
        this.push(t);
    }
 
    public void showResult() {
        while(!this.isEmpty()) {
            this.pollFirst();
        }
    }
 
    public boolean isEmpty() {
        if(this.size() != 0) {
            return true;
        } else {
            return false;
        }
    }
}
MyThread (недописал)
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
public class MyThread implements Runnable {
    private TaskQueue tq;
    private MyTask t;
 
    public MyThread(TaskQueue tq) {
        this.tq = tq;
        t = null;
    }
 
    @Override
    public void run() {
        while(!tq.isEmpty()) {
            synchronized (tq) {
                if(!tq.isEmpty()) {
                    t = tq.pop();
                }
            }
         //   if((t != null) && (t.primeFound())) {
      //          tq.countPrime();
                t = null;
            }
        }
    }
//}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.11.2021, 15:12
Ответы с готовыми решениями:

Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
При работе с потоками выходит ошибка, помогите пожалуйста Для начала пытаюсь считать из файла inputModels информацию Lada 4 ...

Ошибка: Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 20
Добрый день! Задание: в файле хранятся данные о школьниках. Вывести данные про тех, кто учится в пятом классе. Проблема: При чтении...

Exception in thread "main" java.lang.NullPointerException
Вот код: package ua.nure.cherevan.task1; public class Part1 { public static void main(String args) { int...

1
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
04.11.2021, 17:43
Java
1
2
3
public void push(MyTask t) {
        this.push(t);
    }
Вроде все очевидно
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.11.2021, 17:43
Помогаю со студенческими работами здесь

Exception in thread "main" java.lang.NullPointerException
Здравствуйте, нуждаюсь в вашей помощи! Необходимо предусмотреть ввод информации с клавиатуры с помощью потоков ввода, вывод информации в...

Exception in thread "main" java.lang.NullPointerException
Добрый день. Написал программу. В диалоговом окне вводится номер кабинета. На печать выводятся все первые ячейки строк, в которых...

Exception in thread "main" java.lang.NullPointerException
package newdimonproject; import java.util.ArrayList; public class House { int NumberHouse; String Street; ...

ошибка при создании приложения Exception in thread "main" java.lang.NullPointerException: Cannot invoke "java.net.URL.to
Ошибка: C:\Users\kozna\.jdks\openjdk-16\bin\java.exe &quot;-javaagent:D:\IntelliJ IDEA Community Edition...

Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: Index 3 out of bounds for length 3
Всем привет есть следующий код который находит матрицу графа, но есть одна ошибка, и не знаю как ее исправить Код: package codejav; ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru