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

Не производится запись в файл и стандартный поток вывода при успешном завершении программы

29.09.2021, 00:18. Показов 889. Ответов 2

Студворк — интернет-сервис помощи студентам
Здравствуйте. Программа завершается успешно. Проходил в дебагере, ничего такого не обнаружил. Просто не записывает ничего в файлы или стандартный поток вывода (консоль). Писал в NetBeans, в качестве аргументов указывал ключи "-c E:\trashDir\inputPath.txt E:\trashDir\outputPath.txt". В программе можно вводить ключи [-c | -d | -u] [-i] [входной файл [выходной файл]]. Для тестирования можно не вводить вообще аргументы, тогда программа будет брать текст с ввода клавиатуры, пока пользователь не введет "-close", затем программа записывает данные в стандартный поток вывода (консоль). Использую для этого классы BufferedReader и BufferedWriter. Если не вводить аргументы, то запись в стандартный поток вывода (консоль) производится вот так:

Java
1
2
3
for(int i = 0; i < textLines.length; i++) {
                    writer.write(textLines[i] + "\n");
                }
Просто берется строка из списка строк и отправляется в консоль.

Объект writer инициализирован вот так:

Java
1
writer = new BufferedWriter(new OutputStreamWriter(System.out));
Вот полный код:

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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
package com.javaSPP;
 
import java.io.*;
 
class Lab2Ex2 {
    public static void main(String[] args) {
        try {
            byte[] arguments = {0, 0, 0, 0};
            
            for(String elem : args) {
                switch(elem) {
                    case "-u":
                        arguments[0]++;
                        break;
                    case "-d":
                        arguments[1]++;
                        break;
                    case "-c":
                        arguments[2]++;
                        break;
                    case "-i":
                        arguments[3]++;
                        break;
                }
            }
            
            if(arguments[0] > 1 || arguments[1] > 1 || arguments[2] > 1 || arguments[3] > 1) {
                System.out.println("Вводить один и тот же ключ разрешено только один раз.");
            }
            
            if(arguments[0] == 1 && arguments[1] == 0 && arguments[2] == 0 ||
               arguments[0] == 0 && arguments[1] == 1 && arguments[2] == 0 ||
               arguments[0] == 0 && arguments[1] == 0 && arguments[2] == 1)
            {}
            else {
                System.out.println("Разрешено указать только один из ключей [-u, -c, -d]");
            }
            
            int pathsCount = 0;
            int keysCount = 0;
            
            for(int elem : arguments) {
                keysCount += elem;
            }
            
            pathsCount = args.length - keysCount;
            
            if(pathsCount > 2) {
                System.out.println("Разрешено указывать только по одному пути для выходного и входного файлов.");
            }
            
            BufferedReader reader = null;
            BufferedWriter writer = null;
            
            switch(pathsCount) {
                case 0 -> {
                    reader = new BufferedReader(new InputStreamReader(System.in));
                    writer = new BufferedWriter(new OutputStreamWriter(System.out));
                    System.out.println("Для завершения ввода введите \"-close\"");
                }
                case 1 -> {
                    if(args[args.length - 1].equals("-")) {
                        reader = new BufferedReader(new InputStreamReader(System.in));
                        System.out.println("Для завершения ввода введите \"-close\"");
                    }
                    else {
                        reader = new BufferedReader(new FileReader(args[args.length - 1]));
                    }
                }
                case 2 -> {
                    if(args[args.length - 2].equals("-")) {
                        reader = new BufferedReader(new InputStreamReader(System.in));
                        System.out.println("Для завершения ввода введите \"-close\"");
                    }
                    else {
                        reader = new BufferedReader(new FileReader(args[args.length - 2]));
                    }
                    if(args[args.length - 1].equals("-")) {
                        writer = new BufferedWriter(new OutputStreamWriter(System.out));
                    }
                    else {
                        writer = new BufferedWriter(new FileWriter(args[args.length - 1]));
                    }
                }
            }
            
            String text = "";
            String newLine = "";
            
            while((newLine = reader.readLine()) != null) {
                if(newLine.equals("-close")) {
                    break;
                }
                text += newLine + "\n";
            }
            
            String[] textLines = text.split("\n");
            boolean keyI = false;
            if(arguments[3] == 1) {
                keyI = true;
            }
            
            if(arguments[0] == 1) {
                boolean doRepeat = false;
                
                for(int i = 0; i < textLines.length; i++) {
                    for(int j = 0; j < textLines.length; j++) {
                        if(isEqual(textLines[i], textLines[j], keyI) && i != j) {
                            doRepeat = true;
                            break;
                        }
                    }
                    if(!doRepeat) {
                        writer.write(textLines[i] + "\n");
                    }
                    doRepeat = false;
                }
            }
            else if(arguments[1] == 1) {
                for(int i = 0; i < textLines.length; i++) {
                    for(int j = 0; j < textLines.length; j++) {
                        if(isEqual(textLines[i], textLines[j], keyI) && i != j) {
                            writer.write(textLines[i] + "\n");
                            break;
                        }
                    }
                }
            }
            else if(arguments[2] == 1) {
                boolean[] boolTextLines = new boolean[textLines.length];
                int strRepeatCount = 0;
                
                for(int i = 0; i < textLines.length; i++) {
                    if(!boolTextLines[i]) {
                        for(int j = 0; j < textLines.length; j++) {
                            if(isEqual(textLines[i], textLines[j], keyI)) {
                                boolTextLines[j] = true;
                                strRepeatCount++;
                            }
                        }
                        writer.write(strRepeatCount + " " + textLines[i] + "\n");
                        strRepeatCount = 0;
                    }
                }
            }
            else {
                for(int i = 0; i < textLines.length; i++) {
                    writer.write(textLines[i] + "\n");
                }
            }
        }
        catch(FileNotFoundException e) {
            System.out.println("Ошибка!\n" + e.getMessage());
        }
        catch(IOException e) {
            System.out.println("Ошибка!\n" + e.getMessage());
        }
    }
    
    static boolean isEqual(String first, String second, boolean lowerMode) {
        if(lowerMode == true) {
            return first.toLowerCase().equals(second.toLowerCase());
        }
        else {
            return first.equals(second);
        }
    }
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.09.2021, 00:18
Ответы с готовыми решениями:

Произвести запись программы в файл и при завершении подать звуковой сигнал
#include &lt;stdio.h&gt; #include &lt;time.h&gt; #include &lt;stdlib.h&gt; #include &lt;conio.h&gt; #define N 12 #define M 9 int main(void) { ...

Поток держит файл открытым при завершении
private void ButtonBase_OnClick(object sender, RoutedEventArgs e) { ((Button) sender).IsEnabled = false; ...

Остановить поток при успешном соединении TcpClient
Есть метод: public void connect() { try { TcpClient eClient = new...

2
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
29.09.2021, 00:35
Лучший ответ Сообщение было отмечено KaffLime как решение

Решение

Попробуй начать с изучения try with resources
Если не поможет - дебаггером посмотри, доходит ли вообще до записи
1
0 / 0 / 0
Регистрация: 05.05.2020
Сообщений: 227
29.09.2021, 01:17  [ТС]
Да, проблема действительно была в том, что я не закрыл файлы )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.09.2021, 01:17
Помогаю со студенческими работами здесь

Стандартный поток ввода и вывода в Objective-C
Я новичок в Objective-C. Мне необходимо ввести данные с клавиатуры в переменные а и b, а затем вывести сумму. Как это реализовать на...

Стандартный поток вывода - поправить код
Прочитать трехмерный массив из стандартного потока ввода. Массив может содержать элементы различных типов – целые, вещественные,...

Запустить программу, при ее успешном завершении запустить следующую
- запустить программу PRIM.exe, при успешном завершении запустить PRIM_1.exe, иначе выдать сообщение об аварийном завершении...

На стандартный поток вывода напечатайте сумму чисел
Сдать решение задачи A-Сумма чисел Ограничение времени: 1 с Ограничение реального времени: 5 с Ограничение памяти: 64M Сумма двух...

Как реализовать стандартный поток ввода-вывода (stream)?
Что даёт команду ОС считывать\отобразить какую-то информацию?


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru