170 похожих чатов

»Besides that, it is obvious that the second script runs

in O(1) space, while the first one executes in O(n). This is the consequence of our procedural approach to data in the first script.

void transform(File in, File out) {
Collection<String> src = FileUtils.readLines(in, "UTF-8");
Collection<String> dest = new ArrayList<>(src.size());
for (String line : src) {
dest.add(line.trim());
}
FileUtils.writeLines(out, dest, "UTF-8");
}

- Твоя собака кусается? - Нет, она делает больно иначе:

void transform(File in, File out) {
try (FileReader fr = new FileReader(in), BufferedReader sr = new BufferedReader(fr), FileWriter fw = new FileWriter(fw), BufferedWriter sw = new BufferedWriter(fw)) {
String line;
while ((line = sr.readLine()) != null) {
sw.write(line);
}
}
}

1 ответов

8 просмотров

да чето не очень пример то, он показывается что в первом случае не применяется никаких оптимизаций. Там вместо Collection<String> мог быть полноценный тип с lazy итератором по underlying коллекции были бы те же самые O(C) space

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Ребят в СИ можно реализовать ООП?
Николай
33
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
у вас два процесса. один посылает другому сигнал. у вас есть код обоих процессов? если всё не так - расскажите как оно на самом деле. а именно кто кому чего, есть-ли консоли,...
Karagy
6
Карта сайта