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

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

10 ответов

15 просмотров

Посмотрел реализацию 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, но понимание приходит постепенно. Очень рад, что в чате есть специалисты такого уровня, как Вы.

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

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

А как старый хаскел с новым стыковать ? потому как тут работает https://play.haskell.org/saved/C3xpMzcd, а вот тут https://stepik.org/lesson/7602/step/9?unit=1473 нет ошибка C...
Fedor
131
что насчет пагинга? на осдеве непонятно(
Vi Chapmann 🪙
26
Вопрос я правильно понимаю что в коде newtype ArrowMap k v = ArrowMap { getArrowMap :: k -> Maybe v } getArrowMap есть функция типа k -> Maybe v, если да, то не понимаю задач...
Fedor
64
Ребят, что лучше для реверса: гидра или ида?
En Vind Av Sorg
26
Делаю велосипед логгер. К сообщению хочу прикрутить некоторую информацию, типа, кем отправлено, какой уровень, и всякое такое. И тут подумалось мне, почему бы не хранить весь...
Serjone
24
Как Вы считаете нормально ли в двадцатых годах 21 века в ВУЗах Российской Федерации обучать студентов работе с TASM? Не слишком ли это "архаично"? (Если оффтоп или флейм для э...
Spiker01
52
Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
48
Продолжая диалог про свифт в проде – сейчас возник вопрос в активном наборе бекендеров. В основном в нашей компании мы фанаты Java Spring и полностью ей довольны. Однако найм ...
Guseyn
27
Читаю сейчас [нет, уже больше не читаю!] курсовую о Булгакове, написанную, похоже, с помощью ChatGPT. Это удивительный психоделический опыт. Текст в основном написан в стиле б...
✨ Uni [🌊 В отпуске]
1
если загрузчик efi? если сама PML4 PDPT PDT PT лежит в неудобном для меня месте?
Vi Chapmann 🪙
8
Карта сайта