Алексей Шипилёв - Катехизис java.lang.String

Поділитися
Вставка
  • Опубліковано 2 гру 2024

КОМЕНТАРІ • 35

  • @atomic.rabbit
    @atomic.rabbit 3 роки тому +4

    Смотришь Шипилева и настроение улучшается.

  • @НикитаСоколов-ъ7н
    @НикитаСоколов-ъ7н 8 років тому +15

    Шикарный доклад! Много нового узнал.

  • @НайманКопеев
    @НайманКопеев 4 роки тому +1

    Хороший доклад. Правильно говорит, что нельзя опираться на советы, нужно самим проводить проверки и на своих задачах.

  • @savar33
    @savar33 9 років тому +19

    а что его спросили на 46:20?
    :)

  • @ysparrow1
    @ysparrow1 8 років тому +5

    Очень!

  • @travacry
    @travacry 7 років тому +2

    отличный доклад.

  • @MrJavaNinja
    @MrJavaNinja 6 років тому +4

    хорошо рассказывает, не устаешь слушать как от некоторых

  • @wunm6249
    @wunm6249 5 років тому

    Шикарный доклад !

  • @9080artur
    @9080artur Рік тому

    Гений!

  • @MacIn173
    @MacIn173 8 років тому +2

    На 36 слайде минуса не хватает или a(n-1) и b(n-1) местами поменять надо.

  • @aljesco8338
    @aljesco8338 6 років тому

    На 19:50 начинается странная дичь. Я, конечно, со второго раза таки понял, что Алексей говорит о потере производительности при пересчёте хэшкода, если он как раз попадает на нуль, но при проверке у себя я такой аномалии не обнаружил. При первом расчёте хэшкода есть аномалия по времени его вычисления, но повторные расчёты хэшкода выполняются очень схоже. Вот данные:
    строка - хэшкод - время расчёта хэшкода, нс
    сверхинструментом пренебрегшая: 0, 56909
    сверхинструментом пренебрегшая: 0, 928
    пренебрегшая сверхинструментом: 462434972, 619

    • @garncev
      @garncev 3 роки тому

      Потеря производительности когда хеш случайно стал 0 заключается в том, что хеш будет вычисляться каждый раз когда вызывается hashCode() и не будет закеширован.
      У первой строки хеш-код 0. И будет каждый раз вычисляться.
      У второй строки хеш-код не равен 0 и будет закеширован. И получить его значение можно из кеша внутри строки.

  • @LeMenas
    @LeMenas 3 роки тому +1

    Ну булеан таки сделали да? :)

  • @strash1692
    @strash1692 3 роки тому

    20:31 Я так и не понял ответа, почему время получения кеша двух одинаковых по длине строк на порядок отличается? Может кто-нибудь пояснить, плз? Алексей сразу прыгнул на другую тему с аномалией кеша хешкода равному нулю.

    • @АдамСмит-ы7р
      @АдамСмит-ы7р 3 роки тому +1

      Так это не другая тема - у одной из этих строк hashCode() == 0, из-за этого и случается аномалия

    • @strash1692
      @strash1692 3 роки тому +2

      Ааааа... т.е., видимо, у первой строки анамальный хешкод и из-за этого тест очень длинный (т.к. много итераций прогоняется и каждый раз хешкод считался снова и снова), а у второй - обычный и поэтому хешкод один раз рассчитался, а потом просто возвращался - в среднем на много итераций время получилось очень малым. Верно? Спасибо.

  • @СергейСамойлов-м5т
    @СергейСамойлов-м5т 7 років тому +1

    Не понимаю. Если intern такой перегруженный, то почему в него кладутся ВСЕ литералы ???

  • @stokitko
    @stokitko 6 років тому +1

    Кешировать хешкод в строке вообще сомнительная затея как по мне. Из-за этого объект строки распух на 8 байт - 4 байта int хешкода и 4 байта на выравнивание (т.е. вообще неиспользуемое место). В результате 24 байта, а если убрать хешкод то строка будет занимать 16 байт. Это может показатся экономией на спичках, но нужно не забывать что кешлайн процессора всего 64 байта
    Всё таки большинство строк не участвуют как ключи для хешмапов. А даже если участвуют то это лучше заоптимизировать компилятором там.

  • @МатвейКоноплёв-б8ю

    Почему так похоже на пересказ главы про String’и в Эккеле?)

  • @АдамСмит-ы7р
    @АдамСмит-ы7р 4 роки тому +2

    Шипилёв: в String нет места для дополнительного флажка, распухнет на 8 байт
    Также Шипилёв, парой лет позже: а давайте кодер в String сохраним, вроде и место для него на всех мэйнстримных платформах есть!

    • @igorm.9845
      @igorm.9845 4 роки тому

      Да, тоже заметил. Но там вроде только в 64 битных VM место есть, если я правильно понял.

    • @Sulphuris
      @Sulphuris 6 місяців тому

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

  • @igorm.9845
    @igorm.9845 4 роки тому

    Я не понял, почему нельзя хешкод вычислить сразу при создании строки и брать его всегда готовым. Без этой свистопляски с кешированием.

    • @НайманКопеев
      @НайманКопеев 4 роки тому

      вычислять хэш дороговато, нужно пробежаться по всем символам строки. поэтому хэш вычисляется только если нужно сравнить эту строку с чем-то.

    • @igorm.9845
      @igorm.9845 4 роки тому

      @@НайманКопеев зато при каждом последующем сравнении быстрее работать будет, это важнее.

    • @strash1692
      @strash1692 3 роки тому +2

      Он и берётся всегда готовым, т.е. кешируется. Просто рассчитывается не сразу, а только при первом обращении.

    • @garncev
      @garncev 3 роки тому

      Не всегда хеш нужен.

  • @kalinkaou2767
    @kalinkaou2767 9 років тому

    А где слайды можно скачать?

    • @ВасяВ-ь5м
      @ВасяВ-ь5м 7 років тому

      раздвоение личности? )))

    • @kalinkaou2767
      @kalinkaou2767 7 років тому +2

      Нет, просто решил себя не утруждать поиском, но потом устал ждать ответа и решил взять инициативу в свои руки ;)

  • @russinwrshi9315
    @russinwrshi9315 8 років тому +4

    Глупец какой-та.

    • @ВасяВ-ь5м
      @ВасяВ-ь5м 7 років тому +20

      школота, ты каналом ошиблась )))

  • @jameswebb100
    @jameswebb100 6 років тому +1

    Целый час бред про стринг. Надо быть упоротым ,чтобы такое количество времени убить на это.

    • @iazarov
      @iazarov 5 років тому +6

      На самом деле не бред. В частности про методы работы с памятью. Хотя да 40% размышлений и методологим было изложено ещё в доке по jdk 1.1 - например рекомендации по быстрому конкату строчек.