Назовите основные интерфейсы коллекций и их имплементации.
Чем отличается ArrayList от LinkedList? В каких случаях лучше использовать первый, а в каких второй?
Чем отличается HashMap от Hashtable?
Чем отличается ArrayList от Vector?
Как сравниваются елементы коллекций?
Расположите в виде иерархии следующие интерфейсы: List, Set, Map, SortedSet, SortedMap, Collection,Iterable, Iterator, NavigableSet, NavigableMap.
Почему Map - это не Collection, в то время как List и Set являются Collection?
Дайте определение понятию "iterator".
Что вы знаете об интерфейсе Iterable?
Как одной строчкой преобразовать HashSet в ArrayList?
Как одной строчкой преобразовать ArrayList в HashSet?
Как перебрать все ключи Map учитывая, что Map - это не Iterable?
Как перебрать все значения Map учитывая, что Map - это не Iterable?
Как перебрать все пары ключ-значение в Map учитывая, что Map - это не Iterable?
В чем проявляется "сортированность" SortedMap, кроме того, что toString() выводит все по порядку?
Как одним вызовом копировать элементы из любой Collection в массив?
Реализуйте симметрическую разность двух коллекций используя методы Collection (addAll(), removeAll(), retainAll()).
Сравните Enumeration и Iterator.
Как между собой связаны Iterable и Iterator?
Как между собой связаны Iterable, Iterator и "for-each " введенный в Java 5?
Сравните Iterator и ListIterator.
Что произойдет, если я вызову Iterator.next() не "спросив" Iterator.hasNext()?
Что произойдет, если я вызову Iterator.next() перед этим 10 раз вызвав Iterator.hasNext()? Я пропущу 9 элементов?
Если у меня есть коллекция и порожденный итератор, изменится ли коллекция, если я вызову iterator.remove()?
Если у меня есть коллекция и порожденный итератор, изменится ли итератор, если я вызову collection.remove(..)?
Зачем добавили ArrayList, если уже был Vector?
В реализации класса ArrayList есть следующие поля: Object[] elementData, int size. Объясните, зачем хранить отдельно size, если всегда можно взять elementData.length?
LinkedList - это односвязный, двусвязный или четырехсвязный список?
Какое худшее время работы метода contain() для элемента, который есть в LinkedList (O(1), O(log(N)), O(N), O(N*log(N)), O(N*N))?
Какое худшее время работы метода contain() для элемента, который есть в ArrayList (O(1), O(log(N)), O(N), O(N*log(N)), O(N*N))?
Какое худшее время работы метода add() для LinkedList (O(1), O(log(N)), O(N), O(N*log(N)), O(N*N))?
Какое худшее время работы метода add() для ArrayList (O(1), O(log(N)), O(N), O(N*log(N)), O(N*N))?
Сколько выделяется элементов в памяти при вызове ArrayList.add()?
Сколько выделяется элементов в памяти при вызове LinkedList.add()?
Оцените количество памяти на хранение одного примитива типа byte в LinkedList?
Оцените количество памяти на хранение одного примитива типа byte в ArrayList?
Я добавляю элемент в середину List-а: list.add(list.size()/2, newElem). Для кого эта операция медленнее - для ArrayList или для LinkedList?
Как перебрать элементы LinkedList в обратном порядке, не используя медленный get(index)?
Как одним вызовом из List получить List со всеми элементами, кроме первых и последних 3-х?
Могут ли у разных объектов в памяти (ref0 != ref1) быть ref0.hashCode() == ref1.hashCode()?
Могут ли у разных объектов в памяти (ref0 != ref1) быть ref0.equals(ref1) == true?
Могут ли у разных ссылок на один объект в памяти (ref0 == ref1) быть ref0.equals(ref1) == false?
Есть класс Point{int x, y;}. Почему хэш-код в виде 31 * x + y предпочтительнее чем x + y?
Если у класса Point{int x, y;} "правильно " реализовать метод equals (return ref0.x == ref1.x && ref0.y == ref1.y), но сделать хэш-код в виде int hashCode() {return x;}, то будут ли корректно такие точки помещаться и извлекаться из HashSet?
equals() порождает отношение эквивалентности. Какими из свойств обладает такое отношение: коммутативность, симметричность, рефлексивность, дистрибутивность, ассоциативность, транзитивность?
Можно ли так реализовать equals(Object that) {return this.hashCode() == that.hashCode()}?
В equals требуется проверять, что аргумент (equals(Object that)) такого же типа как и сам объект. В чем разница между this.getClass() == that.getClass() и that instanceof MyClass?
Можно ли реализовать метод equals класса MyClass вот так: class MyClass {public boolean equals(MyClass that) {return this == that;}}?
Будет ли работать HashMap, если все ключи будут возвращать int hashCode() {return 42;}?
Зачем добавили HashMap, если уже был Hashtable?
Согласно Кнуту и Кормену существует две основных реализации хэш-таблицы: на основе открытой адресацией и на основе метода цепочек. Как реализована HashMap? Почему так сделали (по вашему мнению)? В чем минусы и плюсы каждого подхода?
Сколько переходов по ссылкам происходит, когда вы делаете HashMap.get(key) по ключу, который есть в таблице?
Сколько создается новых объектов, когда вы добавляете новый элемент в HashMap?
Как работает HashMap при попытке сохранить в нее два элемента по ключам с одинаковым hashCode, но для которых equals == false?
HashMap может выродиться в список даже для ключей с разным hashCode. Как это возможно?
Какое худшее время работы метода get(key) для ключа, которого нет в таблице (O(1), O(log(N)), O(N), O(N*log(N)), O(N*N))?
Какое худшее время работы метода get(key) для ключа, который есть в таблице (O(1), O(log(N)), O(N), O(N*log(N)), O(N*N))?
Объясните смысл параметров в конструкторе HashMap(int initialCapacity, float loadFactor).
В чем разница между HashMap и IdentityHashMap? Для чего нужна IdentityHashMap? Как может быть полезна для реализации сериализации или клонирования?
В чем разница между HashMap и WeakHashMap? Для чего нужна WeakHashMap?
В WeakHashMap используются WeakReferences. А почему бы не создать SoftHashMap на SoftReferences?
В WeakHashMap используются WeakReferences. А почему бы не создать PhantomHashMap на PhantomReferences?
Сделайте HashSet из HashMap (используйте только множество ключей, но не множество значений).
Сделайте HashMap из HashSet (HashSet<Map.Entry<K, V>>).
Сравните интерфейсы java.util.Queue и java.util.Deque.
Кто кого расширяет: Queue расширяет Deque, или Deque расширяет Queue?
Почему LinkedList реализует и List, и Deque?
В чем разница между классами java.util.Arrays и java.lang.reflect.Array?
В чем разница между классами java.util.Collection и java.util.Collections?
Напишите НЕмногопоточную программу, которая заставляет коллекцию выбросить ConcurrentModificationException.
Что такое "fail-fast поведение"?
Для множеств еnum-ов есть специальный класс java.util.EnumSet? Зачем? Чем авторов не устраивал HashSet или TreeSet?
java.util.Stack - считается "устаревшим". Чем его рекомендуют заменять? Почему?
Честно говоря, после увиденного перечня вопросов опустились руки. Я представлял что надо знать очень много, но такой объем - это просто удар по я… Ну что ж, раз так, значит надо ввязаться в драку, а там посмотрим. Спасибо за Ваш труд.
Невозможно знать все и сразу. Эти вопросы всего лишь возможность укрепить свои знания и закрыть некоторые пробелы. Читайте статью и проходите тесты на quizful и все будет хорошо ))
Если будете знать ответы на все эти вопросы и корректную общую картину по ним (а не дискретные ответы), то приправьте хотя бы годом опыта и можете пытаться идти уже на Seniour Java Dev. (субъективно)
Список крутой, но такого набора знаний хватает максимум на мидла. Дальше понадобятся более общие знания приходящие с опытом. Необходимо понимать стуктуру приложений, дизайн и архитектурные паттерны, понимать устройство/стандарты/спецификации необходимых вам областей работы. В какой-то дженерик список это уже не уместить
Круто, автору отдельное спасибо! Сам являюсь Middle Java Developer (в программировании ровно 2 года), но был занят лишь в одном проекте, хотел освежить память, создать более четкую структуру в мозгу, и в конспекте. По Вашим вопросам в течение месяца буду укреплять знания.
"Как работает гебедж коллектор?" - такое ощущение что вопросы взяты из англо-язычного ресурса и переведены гуглом. Почему нельзя нормально написать либо сборщик мусора, либо тоже самое но оставить на английском. А так список вопросов хороший, правда не понятно зачем делать запрет на использование правой кнопки мыши? Копировать и гуглить проще нежели перепечатывать
Хотел распечатку сделать вопросов + ответы, но не могу скопировать, а в исходном коде столько треша, что волосы дыбом. Киньте, пожалуйста, на мыло список, чтобы работать с ним можно было (если не западло) :) Спасибо! nickhaz1981 (et) gmail.com
Здравствуйте. Я Не отправляю вопросы и ответы, так как я постоянно обновляю их. Актуальные данные есть на сайте, где вы можете посмотреть их в любое удобное для Вас время.
Шановний адміне, ось ви заблокували окрім можливості скопіювати вашу роботу (на що, безумовно, маєте право) і можливість використовувати на вашому сайті праву кнопку миші, не підкажете, яким чином можна перейти за будь-яким посиланням (наприклад на ваш профіль) не закриваючи основну сторінку (інтернет у людей не гумовий, бігати туди-сюди замість переключатись поміж вкладками браузера не зручно,принаймні мені, як думаю і багатьом іншим). Тим більше, що якщо людина схоче щось вкрасти - вона вкраде, можливості є різні.
Java junior? Вы серьёзно? Если всё это знать, то спокойно на мидла можно идти, если не выше. Приходишь ты такой на собеседование на МЛАДШЕГО разработчика, без оптыа, без твёрдых знаний. Садишься в кабинет, тебя спрашивают пару вопросов "за жизнь". А потом так невзначай, "Давайте перейдём к технической части, вот скажите мне. В WeakHashMap используются WeakReferences. А почему бы не создать PhantomHashMap на PhantomReferences?" И ты такой подумал немного, встал, попращался и пошел в макдональдс работать=)
Может кому-то будет интересно, есть ресурс с тестами по разным языкам программирования, в том числе и java. https://proghub.ru тут можно после прохождения тестов увидеть свои ошибки, правильные ответы и объяснения. И вопросов огромная туча, как утверждают авторы уже более 6000
А по-моему правильно, что закрыта возможность копирования. Берите и сам ручками набивай в отдельном файле вопросы и ответы к ним, а то мозги совсем атрофируются, господа негодующие!
Это точно не лучший список для джуна! На позицию джуна от сюда подойдет 10% от всего. А если знать все + опыт работы это уже синьер! Ну а так, Материал для последующей подготовке в общем плане хороший.
По моему опыту собесы это во многом удача, так как часто: 1) Задают абстрактный и спорный вопрос, ожидая на него конкретный ответ. Например: "когда методы объявлять final? когда классы объявлять final?"
Мой ответ: суперкостыли, магию и data-классы объявлять final, остальное пусть наследуют на свой страх и риск. Зачем ограничивать пользователя кода? В том же свинге сколько проблем с private/final
Ожидаемый ответ: Так как в джава нет контрактов на несколько методов, т.е. мы не можем заставить человека переопределить два метода сохранив поведение, то такие классы/методы надо делать final. Например класс String с его методами распознавания целых, которые может сломать наследование
Ответ компании JetBrains в kotlin для jvm - все классы по умолчанию final. Только специально расчитанные на наследование классы должны быть open. Но при этом куче фреймворков нужны open классы и в итоге появился плагин компилятора делающий классы по умолчанию "open"
2) Задают морально устаревшие вопросы. Про wait/notify, StringBuffer и им подобные
3) Задают просто не нужные вопросы "на эрудицию" про устройство JDK, кучи
4) Задают вопросы о том, что время от времени используешь в работе но память не держит, так как есть автодополнение кода, гугл и гитхабы с шаблонами Какие методы у класса Object? Как в Spring авторизировать по куки? Какой минимальный web-xml?
5) Вопросы о реализации алгоритмов и структур данных. Интересуют всегда характеристики и интерфейс. Как оно внутри устроено не важно, так как сам ты никогда не будешь писать дерево, фильтр блума или perfect hash map: если они нужны, то они уже есть в проекте и/или фреймворках. Если нет - гугл и имплементация на относительно знакомом языке лучший друг
6) Программирование на бумажке и анкетирование без комментариев
Чтобы свободно выделять и копировать текст нужно удалить вот этот код (убрать пробелы из тегов): < s cript> document.ondragstart = noselect; // запрет на перетаскивание document.onselectstart = noselect; // запрет на выделение элементов страницы //document.oncontextmenu = noselect; // запрет на выведение контекстного меню function noselect() {return false;} < / s cript> < s tyle> .post blockquote { -webkit-user-select: text !important; -moz-user-select: text !important; -ms-user-select: text !important; user-select: text !important; } body { -webkit-user-select: none !important; -moz-user-select: -moz-none !important; -ms-user-select: none !important; user-select: none !important; } < / s tyle>
В Java меньше месяца, после прочтения Шилдта ответил разве что на треть вопросов. Может сюда заглянет кто-то из собеседователей и приоткроет наконец завесу тайны: это просто набор вопросов для самосовершенствования независимо от уровня, или же всё таки то, что действительно могут спросить у Jun'а?
спасибо, думаю поможет.
ОтветитьУдалитьЧестно говоря, после увиденного перечня вопросов опустились руки. Я представлял что надо знать очень много, но такой объем - это просто удар по я… Ну что ж, раз так, значит надо ввязаться в драку, а там посмотрим. Спасибо за Ваш труд.
ОтветитьУдалитьНевозможно знать все и сразу. Эти вопросы всего лишь возможность укрепить свои знания и закрыть некоторые пробелы. Читайте статью и проходите тесты на quizful и все будет хорошо ))
УдалитьЕсли будете знать ответы на все эти вопросы и корректную общую картину по ним (а не дискретные ответы), то приправьте хотя бы годом опыта и можете пытаться идти уже на Seniour Java Dev.
Удалить(субъективно)
++
УдалитьС 1 годом опыта работы на Senior? вы наверное про middle имели ввиду?
Удалитьда нет. тут как раз таки про Senior
УдалитьДа чего прибеднятся, с такими знаниями можно сразу архитектором становится, лол)
УдалитьСписок крутой, но такого набора знаний хватает максимум на мидла. Дальше понадобятся более общие знания приходящие с опытом. Необходимо понимать стуктуру приложений, дизайн и архитектурные паттерны, понимать устройство/стандарты/спецификации необходимых вам областей работы. В какой-то дженерик список это уже не уместить
УдалитьКруто, автору отдельное спасибо!
ОтветитьУдалитьСам являюсь Middle Java Developer (в программировании ровно 2 года), но был занят лишь в одном проекте, хотел освежить память, создать более четкую структуру в мозгу, и в конспекте.
По Вашим вопросам в течение месяца буду укреплять знания.
"Как работает гебедж коллектор?" - такое ощущение что вопросы взяты из англо-язычного ресурса и переведены гуглом. Почему нельзя нормально написать либо сборщик мусора, либо тоже самое но оставить на английском.
ОтветитьУдалитьА так список вопросов хороший, правда не понятно зачем делать запрет на использование правой кнопки мыши? Копировать и гуглить проще нежели перепечатывать
Всегда можно вызвать отладочную консоль в браузере и скопировать из html кода
УдалитьКак вариант, можно и так.
УдалитьВсегда можно распарсить картинку в текст...
УдалитьВопросы нашел. А где ответы?
ОтветитьУдалитьА ответы ты сам должен найти
УдалитьVerb.en.: to google - найти ответ
УдалитьОткрываешь "содержание", и выбираешь раздел который тебя интересует. Или справа в архиве блога.
ОтветитьУдалитьХотел распечатку сделать вопросов + ответы, но не могу скопировать, а в исходном коде столько треша, что волосы дыбом. Киньте, пожалуйста, на мыло список, чтобы работать с ним можно было (если не западло) :) Спасибо! nickhaz1981 (et) gmail.com
ОтветитьУдалитьP. S. Классный список! Спасибо.
turn off the java-script in your browser and finally copy questions !
УдалитьБлагодарю)
ОтветитьУдалитьДоброго времени суток! Прошу так же сбросить мне на мейл вопросы-ответы. Спасибо!
ОтветитьУдалитьartem.malitsa@gmail.com
Здравствуйте. Я Не отправляю вопросы и ответы, так как я постоянно обновляю их. Актуальные данные есть на сайте, где вы можете посмотреть их в любое удобное для Вас время.
УдалитьЗная всё это, думаю, можно спокойно идти на мида
ОтветитьУдалитьКрутой список. Больше добавить нечего.
ОтветитьУдалитьСпасибо за список вопросов! Очень полезно.
ОтветитьУдалитьОчень полезный список и толковые ответы!! спасибо большое!!
ОтветитьУдалитьСпасибо!
УдалитьШановний адміне, ось ви заблокували окрім можливості скопіювати вашу роботу (на що, безумовно, маєте право) і можливість використовувати на вашому сайті праву кнопку миші, не підкажете, яким чином можна перейти за будь-яким посиланням (наприклад на ваш профіль) не закриваючи основну сторінку (інтернет у людей не гумовий, бігати туди-сюди замість переключатись поміж вкладками браузера не зручно,принаймні мені, як думаю і багатьом іншим). Тим більше, що якщо людина схоче щось вкрасти - вона вкраде, можливості є різні.
ОтветитьУдалитьІ пробачте, за вашу роботу - Велика подяка й шана.
ОтветитьУдалитьВ закладки, спасибо!
ОтветитьУдалитьСпасибо большое! но разблокировать удалось за 5 мин. и за этот опыт спасибо...
ОтветитьУдалитьJava junior? Вы серьёзно? Если всё это знать, то спокойно на мидла можно идти, если не выше.
ОтветитьУдалитьПриходишь ты такой на собеседование на МЛАДШЕГО разработчика, без оптыа, без твёрдых знаний. Садишься в кабинет, тебя спрашивают пару вопросов "за жизнь". А потом так невзначай, "Давайте перейдём к технической части, вот скажите мне. В WeakHashMap используются WeakReferences. А почему бы не создать PhantomHashMap на PhantomReferences?"
И ты такой подумал немного, встал, попращался и пошел в макдональдс работать=)
)))
УдалитьКакой мудак запретил выделять текст?
ОтветитьУдалитьНу тут форум программыстов. Через код элемента копируй)))
Удалитькаша из вопросов. какой смысл держать в голове хаотичный справочник.
ОтветитьУдалитьМожет кому-то будет интересно, есть ресурс с тестами по разным языкам программирования, в том числе и java. https://proghub.ru
ОтветитьУдалитьтут можно после прохождения тестов увидеть свои ошибки, правильные ответы и объяснения. И вопросов огромная туча, как утверждают авторы уже более 6000
А по-моему правильно, что закрыта возможность копирования. Берите и сам ручками набивай в отдельном файле вопросы и ответы к ним, а то мозги совсем атрофируются, господа негодующие!
ОтветитьУдалитьАдмин, добавь вопросы про блоки инициализации)
ОтветитьУдалитьСпецом весь Adblock выключил, спасибо автор!!! Кормись за счёт меня :)
ОтветитьУдалитьЛучший список, который я нашел.
ОтветитьУдалитьЭто точно не лучший список для джуна! На позицию джуна от сюда подойдет 10% от всего. А если знать все + опыт работы это уже синьер! Ну а так, Материал для последующей подготовке в общем плане хороший.
ОтветитьУдалитьПо моему опыту собесы это во многом удача, так как часто:
ОтветитьУдалить1) Задают абстрактный и спорный вопрос, ожидая на него конкретный ответ. Например: "когда методы объявлять final? когда классы объявлять final?"
Мой ответ: суперкостыли, магию и data-классы объявлять final, остальное пусть наследуют на свой страх и риск. Зачем ограничивать пользователя кода? В том же свинге сколько проблем с private/final
Ожидаемый ответ: Так как в джава нет контрактов на несколько методов, т.е. мы не можем заставить человека переопределить два метода сохранив поведение, то такие классы/методы надо делать final. Например класс String с его методами распознавания целых, которые может сломать наследование
Ответ компании JetBrains в kotlin для jvm - все классы по умолчанию final. Только специально расчитанные на наследование классы должны быть open. Но при этом куче фреймворков нужны open классы и в итоге появился плагин компилятора делающий классы по умолчанию "open"
2) Задают морально устаревшие вопросы. Про wait/notify, StringBuffer и им подобные
3) Задают просто не нужные вопросы "на эрудицию" про устройство JDK, кучи
4) Задают вопросы о том, что время от времени используешь в работе но память не держит, так как есть автодополнение кода, гугл и гитхабы с шаблонами
Какие методы у класса Object?
Как в Spring авторизировать по куки?
Какой минимальный web-xml?
5) Вопросы о реализации алгоритмов и структур данных. Интересуют всегда характеристики и интерфейс. Как оно внутри устроено не важно, так как сам ты никогда не будешь писать дерево, фильтр блума или perfect hash map: если они нужны, то они уже есть в проекте и/или фреймворках. Если нет - гугл и имплементация на относительно знакомом языке лучший друг
6) Программирование на бумажке и анкетирование
без комментариев
Чтобы свободно выделять и копировать текст нужно удалить вот этот код (убрать пробелы из тегов):
ОтветитьУдалить< s cript>
document.ondragstart = noselect;
// запрет на перетаскивание
document.onselectstart = noselect;
// запрет на выделение элементов страницы
//document.oncontextmenu = noselect;
// запрет на выведение контекстного меню
function noselect() {return false;}
< / s cript>
< s tyle>
.post blockquote {
-webkit-user-select: text !important;
-moz-user-select: text !important;
-ms-user-select: text !important;
user-select: text !important;
}
body {
-webkit-user-select: none !important;
-moz-user-select: -moz-none !important;
-ms-user-select: none !important;
user-select: none !important;
}
< / s tyle>
В Java меньше месяца, после прочтения Шилдта ответил разве что на треть вопросов. Может сюда заглянет кто-то из собеседователей и приоткроет наконец завесу тайны: это просто набор вопросов для самосовершенствования независимо от уровня, или же всё таки то, что действительно могут спросить у Jun'а?
ОтветитьУдалитьfunction allowedCopy() {
ОтветитьУдалитьvar aTags = document.getElementsByTagName('style');
var searchText = '.post blockquote';
var found;
for (var i = 0; i < aTags.length; i++) {
if (aTags[i].textContent.search(searchText) + 1) {
found = aTags[i];
break;
}
}
found?.remove()
document.onselectstart = Function.prototype
var el = document.body,
elClone = el.cloneNode(true);
elClone.oncopy = undefined
el.parentNode.replaceChild(elClone, el);
}
allowedCopy()
Для 2022 года вопросы-ответы актуальны?
ОтветитьУдалитьОни и в 2202 будут актуальны )
ОтветитьУдалитьЭто просто шедевр, сам еще джун или стажер не знаю, но могу сказать что благодаря вашим вопросам и ответам я могу улучшить свои знания по теории.
ОтветитьУдалить