С Новым годом! Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/18: Рейтинг темы: голосов - 18, средняя оценка - 4.78
0 / 0 / 0
Регистрация: 04.08.2013
Сообщений: 6

Очередь потоков

16.10.2013, 20:18. Показов 3777. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
1. Два потока должны выводить по очереди слова из предложения.
2. Алфавит. Один поток выводит на консоль гласные буквы, другой согласные.
Подскажите, пожалуйста, как этого добиться... Вот, что у меня пока что есть:
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
public class ThreadOfWords extends Thread{ 
public ThreadOfWords(String str){ 
super(); 
setName(str); 
}
 
public synchronized void run(){
    String [] mas1 = {"My", "is", "I", "java."};
    String [] mas2 = {"name", "Leyla.", "like", ":)"};
    String [] mas3 = {"a", "e", "i", "o", "u"};
    String [] mas4 = {"b", "c", "d", "f", "g", "h", "j", "k", "l", "m", "n", "p", "q", "r", "s", "t", "v", "w", "x", "y", "z"};
    String nameT = getName();
 
    if("First".equals(nameT)){
        for(int i = 0; i < mas1.length; i++){
            System.out.println(mas1[i]);
            try{
                Thread.sleep(200);
            } catch(InterruptedException e){
                System.out.println(nameT + "прерван");
            }
        }
    } else if("Second".equals(nameT)){
        for(int i = 0; i < mas2.length; i++){
            System.out.println(mas2[i]);
            try{
                Thread.sleep(200);
            } catch(InterruptedException e){
                System.out.println(nameT + "прерван");
            }
        }
    } else if("Third".equals(nameT)){
        for(int i = 0; i < mas3.length; i++){
            System.out.println(mas3[i]);
            try{
                Thread.sleep(500);
            } catch(InterruptedException e){
                System.out.println(nameT + "прерван");
            }
        }
    } else if("Fourth".equals(nameT)){
        for(int i = 0; i < mas4.length; i++){
            System.out.println(mas4[i]);
            try{
                Thread.sleep(500);
            } catch(InterruptedException e){
                System.out.println(nameT + "прерван");
            }
        }
    }       
}
}
 
public class Words { 
public static void main(String[] args) { 
ThreadOfWords tr1 = new ThreadOfWords("First"); 
ThreadOfWords tr2 = new ThreadOfWords("Second");
 
    tr1.setPriority(10);
    tr2.setPriority(1);
 
    tr1.start();
    tr2.start();                
}
}
 
public class ABC { 
public static void main(String[] args) { 
ThreadOfWords tr1 = new ThreadOfWords("Third"); 
ThreadOfWords tr2 = new ThreadOfWords("Fourth");
 
    tr1.setPriority(10);
    tr2.setPriority(1);
 
    tr1.start();
    tr2.start();
}
}
 Комментарий модератора 
5.16 Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.
правила форума
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.10.2013, 20:18
Ответы с готовыми решениями:

Очередь из 3-х потоков
Может кто-то сделать пример очереди из трех потоков, например, чтобы первый выводил &quot;А&quot;, второй &quot;Б&quot;, а третий...

Как создать очередь потоков
Есть ли в Java класс, в который можно добавить N потоков, потом одним действем их запустить, и что бы они выполнялись по очереди и еще,...

Замедление работы потоков если запущено несколько потоков
Есть отдельный поток который движет красным квадратом. Он каждую миллисекунду меняет положение квадрата на пиксель. Есть другой поток, он...

2
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
17.10.2013, 09:37
Цитата Сообщение от leyla89 Посмотреть сообщение
Два потока должны выводить по очереди слова из предложения
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
import java.util.Scanner;
 
class WordByWord {
    private boolean oddWord;
    private String [] words;
    private Scanner scan;
    
    WordByWord() {
        scan = new Scanner(System.in);
        
        
        while ( true ) {
            System.out.print("String: ");
            String str = scan.nextLine();
            if ( str.isEmpty() )
                break;
            
            words = str.split(" ");
            oddWord = true;
            
            Thread odds = new Thread(new Runnable() {
                @Override
                public void run() {
                    for ( int i = 0; i < words.length; i += 2 ) {
                        waitMyTurn(true);
                        System.out.println("Odd: " + words[i]);
                        setOddWord(false);
                    }
                }
            });
            
            Thread evens = new Thread(new Runnable() {
                @Override
                public void run() {
                    for ( int i = 1; i < words.length; i += 2 ) {
                        waitMyTurn(false);
                        System.out.println("Even: " + words[i]);
                        setOddWord(true);
                    }
                }
            });
            
            odds.start();
            evens.start();
            try {
                odds.join();
                evens.join();
            }
            catch ( InterruptedException ie ) {
                System.err.println("Interrupted!");
            }
        }
    }
    
    synchronized void waitMyTurn(boolean needOdd) {
        while ( oddWord != needOdd ) {
            try {
                wait();
            }
            catch ( InterruptedException ie ) {}
        }
    }
    
    synchronized void setOddWord(boolean isOdd) {
        oddWord = isOdd;
        notifyAll();
    }
    
    public static void main(String [] args) {
        new WordByWord();
    }
}
1
10 / 10 / 5
Регистрация: 14.09.2013
Сообщений: 17
17.10.2013, 11:24
Что-то я, по ходу, замудрил

1) поставщик слов:
интерфейс:
Java
1
2
3
4
5
public interface SelectiveStringProvider {
        //отвечает, можно ли забрать слово
    public boolean isAllowed(int writerId);
    public String getString(int writerId);
}
реализация (вариант по словам):
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
public class WordProvider implements SelectiveStringProvider {
    // список слов из фразы
    private LinkedList<String> words;
    
    // идентификатор последнего класса-писателя
    private int lastWriterId;
    
    public WordProvider(String phrase) {
        lastWriterId = 0;
        words = new LinkedList<String>();
        
        StringTokenizer st = new StringTokenizer(phrase);
        while (st.hasMoreTokens()) {
            words.add(st.nextToken());
        }
    }
 
    @Override
    public boolean isAllowed(int writerId) {
        //если разрешение запрашивает писатель с таким же id, 
        //сообщаем, что считывание строки не разрешено
        if (writerId == lastWriterId) {
            return false;
        }
        return true;
    }
 
    @Override
    public String getString(int writerId) {
        //отдавая строку, запоминаем id писателя, которому её отдали
        lastWriterId = writerId;
        return words.pollFirst();
    }
2) Класс-писатель, реализующий Runnable:
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
public class StringWriter implements Runnable {
    private int id;
    private SelectiveStringProvider provider;
    
    public StringWriter(int id, SelectiveStringProvider provider) {
        this.id = id;
        this.provider = provider;
    }
 
    @Override
    public void run() {
        while(true) {
            // получаем монопольный доступ к провайдеру
            synchronized (provider) {
                //спрашиваем, можно ли нам считать строку
                if (provider.isAllowed(id)) {
                    //если можно - считываем
                    String current = provider.getString(id);
                    if (current != null) {
                        //если строка - не null
                        //печатаем, и освобождаем провайдер для другого потока
                        System.out.println(current);
                        //а вот так можно убедиться, что потоки чередуются
                        //System.out.println(current + " " + this.id);
                        provider.notify();
                    } else {
                        //если считали и строка - null
                        //завершаем работу, предварительно уведомив другие потоки
                        // чтобы они так же могли убедиться, что им пора останавливаться
                        provider.notify();
                        break;
                    }
                } else {
                    //если провайдер определил, что нам нельзя получить строку
                    //ждем, пока не уведовят об освобождении провайдера
                    try {
                        provider.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
        }
    }
 
}
3) и для запуска:
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 WordsThreadTest {
 
    public static void main(String[] args) {
        WordProvider wordProvider = 
                new WordProvider("Буря мглою небо кроет, вихри снежные крутя");
        
        StringWriter writer1 = new StringWriter(1, wordProvider);
        StringWriter writer2 = new StringWriter(2, wordProvider);
        
        Thread t1 = new Thread(writer1);
        Thread t2 = new Thread(writer2);
        
        t1.start();
        t2.start();
        
        try {
            t1.join();
            t2.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
 
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.10.2013, 11:24
Помогаю со студенческими работами здесь

Очередь потоков
Приветствую всех. Помогите разобраться с очередью потоков я опишу пример если не сложно набросайте код к примеру и я всё пойму. Сам пример,...

Очередь потоков
Есть несколько серверов, которые отправляют http-запросы в приложение, соответственно формируются потоки для обработки каждого запроса. В...

Как реализовать очередь потоков
Всем привет. Есть такая задача: надо реализовать очередь потоков. В один момент времени может выполняться только 10 потоков. Когда...

Как правильно реализовать очередь потоков
Доброго времени суток! Для работы пишу такую программу: форма содержит группу чекбоксов, с ссылками на дистрибутивы служебных...

Как реализовать очередь нескольких потоков?
Здравствуйте, коллеги! Посоветуйте, как мне реализовать очередь нескольких потоков? Мне нужно сделать так, чтобы после выполнения одного...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru