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

Https://Play.Golang.Org/P/BQya18EqqI5 Достаточно функционально?

10 ответов

32 просмотра

Посмотрел реализацию Split в strings.go: для самого распространённого случая с n==-1 оно творит какую-то дичь и делает двойной проход strings.Index'ом по строке! Сначала для Count, потом - для собственно Split. В принципе для распространённых случаев с одним байтом в Count есть fallback до bytealg.CountString, но всё равно двойной проход по строке даже в этом случае выглядит фиговато...

c- Автор вопроса
Андрей Коновалов
Посмотрел реализацию Split в strings.go: для самог...

это все равно дешевле, чем динамически увеличивать размер слайса строк

c
это все равно дешевле, чем динамически увеличивать...

Можно было запомнить смещения всех вхождений sep, отложив их в стек, это дало бы и количество вхождений, и возможность дальше пройти по строке, уже зная наперёд нужные смещения

c- Автор вопроса
c
тогда надо где-то хранить эти смещения

На стеке. В архитектуре x86 - берёшь push и просто фигачишь в процессорный стек

c- Автор вопроса
Андрей Коновалов
На стеке. В архитектуре x86 - берёшь push и просто...

У Go свои стеки (потому что в Go горутины исполняют код, а не треды), это вызовет совершенно бесполезные переаллокации стека горутины

c
У Go свои стеки (потому что в Go горутины исполняю...

В любом случае стек - это просто область памяти ограниченного размера. Особенность только в том, как она используется: растёт "вниз", нет произвольного доступа, только push/pop И не очень понятно, что мешает в этот стек горутины поместить хоть 100 чисел со смещениями. Если стек ограничен 4096 байт, то даже тогда туда можно засунуть 1000 смещений с лишним. Я только что прочитал, что slice'ы Golang'а в принципе до определённого размера в стек и попадают (вернее, массивы, а слайсы поверх них), так что append для массива смещений и должен бы добавлять в стек?

c- Автор вопроса
Андрей Коновалов
В любом случае стек - это просто область памяти ог...

4096 это без уже существующих на стеке структур, в обычном коде у вас там уже стек вызовов, где каждый что-то будет хранить на стеке Аллокация небольшого слайса дешевле На стеке аллоцируются только те массивы, что не утекают и их размер известен в compile time

c- Автор вопроса
c
4096 это без уже существующих на стеке структур, в...

В целом, при маленькой длине строки, разница скорее всего будет не велика А при большой хранить все равно все на стеке не получится

c
4096 это без уже существующих на стеке структур, в...

Ясно... Пока конечно тяжёло даётся Go, но понимание приходит постепенно. Очень рад, что в чате есть специалисты такого уровня, как Вы.

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта