Java Learning
18.7K subscribers
1.62K photos
1 video
3 files
998 links
№ 5079899194

Обучающий канал по Java

Ссылка для друга - https://t.iss.one/+ZEYYht6-46w5MDM6

По всем вопросам @mascarov_valentin

Реклама на бирже - https://telega.in/c/Java_per_month
Download Telegram
Forwarded from Ваня
DoubleAccumulator

DoubleAccumulator — это класс из пакета java.util.concurrent.atomic, который представляет собой атомарный аккумулятор для значений типа double. Он используется для накапливания значений типа double в потокобезопасном режиме.

DoubleAccumulator имеет следующий конструктор:

DoubleAccumulator(doubleBinaryOperator accumulatorFunction, double initialValue)


Первый аргумент конструктора — это функция, которая определяет, как будут накапливаться значения. Второй аргумент — это начальное значение аккумулятора.

#для_продвинутых
👍11
#Вопросы_с_собеседования
Чем Hashtable отличается от Hashmap?


Основное различие между Hashtable и HashMap заключается в том, что Hashtable синхронизирован, а HashMap нет. Это означает, что Hashtable безопасен для использования в многопоточных приложениях, где несколько потоков могут одновременно взаимодействовать с коллекцией. HashMap, с другой стороны, не является потокобезопасным, поэтому его следует использовать только в однопоточных приложениях.

Другое различие между Hashtable и HashMap заключается в том, что Hashtable не позволяет хранить null ключи или значения. HashMap, с другой стороны, позволяет хранить одно null значение ключа и любое количество null значений.

Наконец, Hashtable использует перечислитель (enumeration) для перебора значений, а HashMap использует итератор (iterator).
👍272
ByteBuffer и DirectByteBuffer

ByteBuffer — это абстракция, которая представляет собой последовательность байтов. Он может использоваться для хранения данных, чтения и записи данных в файлы, а также для сетевого взаимодействия.

DirectByteBuffer — это подкласс ByteBuffer, который хранит свои данные в памяти, выделенной операционной системой. Это отличается от обычного ByteBuffer, который хранит свои данные в куче Java.

Основное преимущество DirectByteBuffer заключается в том, что он может обеспечить более высокую производительность, чем обычный ByteBuffer. Это связано с тем, что операциям ввода-вывода не нужно копировать данные из кучи Java в память операционной системы.

Однако DirectByteBuffer также имеет некоторые недостатки. Во-первых, он может потреблять больше памяти, чем обычный ByteBuffer. Во-вторых, он может быть более сложным в использовании, чем обычный ByteBuffer.

#для_продвинутых
👍84
Класс Selector

Класс Selector относится к пакету java.nio.channels и играет важную роль в работе с асинхронным вводом-выводом (NIO). Он позволяет одновременно следить за несколькими каналами (например, сокетами) и получать уведомления, когда в каком-либо канале есть возможность выполнить операцию чтения, записи или подключения.

#для_продвинутых
👍11
#Вопросы_с_собеседования
В чем разница между внедрением конструктора и внедрением сеттера?

Ответ на картинке.
👍20😱6😢2
FileChannel

FileChannel — это класс в Java, который представляет собой канал для чтения, записи, отображения и манипулирования файлом. Он является подклассом интерфейса SeekableByteChannel, что означает, что он может читать и писать байты в файле в произвольном месте.

#для_начинающих
👍13
ArrayUtils

ArrayUtils - это статический класс в библиотеке java.util.Arrays, который предоставляет различные методы для работы с массивами. Эти методы упрощают и ускоряют выполнение многих задач, связанных с массивами.

Чтобы использовать методы класса ArrayUtils, необходимо импортировать его в свой проект. Это можно сделать следующим образом:

import java.util.Arrays;


#для_продвинутых
👍23
RandomAccessFile

RandomAccessFile — это класс в пакете java.io, который позволяет выполнять произвольный доступ к файлу. Это означает, что вы можете читать и писать данные в файл в любом месте, а не только в начале или конце.

Для создания объекта RandomAccessFile необходимо передать два параметра: имя файла и режим доступа. Режим доступа может быть «r» для чтения, «w» для записи или «rw» для чтения и записи.

#для_продвинутых
👍13
#Вопросы_с_собеседования
В Java, как реализуется принцип "fail-fast" в контексте коллекций и как это отличается от подхода "fail-safe"?

В Java, "fail-fast" система немедленно выдает ConcurrentModificationException, если обнаруживает, что коллекция была изменена во время итерации, кроме изменений через сам итератор. Напротив, "fail-safe" коллекции используют механизмы, такие как копирование коллекции или блокировки, чтобы обеспечить безопасное поведение во время итераций, даже если коллекция изменяется, предотвращая ConcurrentModificationException.
👍161
Кастинг

Кастинг (приведение типов) — это операция, которая позволяет присвоить значение переменной одного типа переменной другого типа.

Существует два типа кастинга:

Расширение типа (widening casting) — это преобразование типа данных меньшей разрядности в тип данных большей разрядности. Например, преобразование типа byte в тип int, short в тип long или char в тип int.

Сужение типа (narrowing casting) — это преобразование типа данных большей разрядности в тип данных меньшей разрядности. Например, преобразование типа int в тип byte, long в тип short или double в тип float.

#для_продвинутых
👍9🔥1
Что такое BufferedInputStream?

BufferedInputStream — это класс ввода-вывода Java, который добавляет буферизацию к базовому потоку ввода. Это означает, что он хранит данные из базового потока в памяти, чтобы их можно было читать большими порциями. Это может повысить производительность ввода-вывода, особенно при чтении из больших файлов.

Как работает BufferedInputStream?

Когда создается BufferedInputStream, он создает внутренний буфер, размер которого можно указать при создании. Затем он читает данные из базового потока в буфер. Когда приложение запрашивает чтение данных из BufferedInputStream, он сначала читает их из буфера. Если буфер пуст, BufferedInputStream читает данные из базового потока и сохраняет их в буфере.

#для_продвинутых
👍121
Класс ByteArrayOutputStream

Класс ByteArrayOutputStream представляет собой поток вывода, в котором данные пишутся в байтовый массив. Буфер автоматически растет, поскольку данные пишутся ему. Поток класса ByteArrayOutputStream создает буфер в памяти, и все данные, отправленные в поток, хранятся в буфере.

#для_продвинутых
👍9
Ключевое слово new

Ключевое слово new используется для создания нового объекта. Оно всегда используется в сочетании с именем класса, к которому принадлежит создаваемый объект. Например, чтобы создать новый объект класса String, мы можем написать код, как на картинке.

В этом примере переменная str будет ссылаться на новый объект класса String. По умолчанию, новый объект будет инициализирован значениями по умолчанию для своего типа. Например, объект класса String будет содержать пустую строку.

#для_начинающих
👍19🔥1
Интерфейс Function

Функциональный интерфейс Function представляет собой интерфейс, который используется для представления функции, принимающей один аргумент и возвращающей результат. Он является частью пакета java.util.function и был введен в Java 8 для поддержки функционального программирования.

#для_продвинутых
👍13
#Вопросы_с_собеседования
Что такое цепочка конструкторов?

Цепочка конструкторов – это процесс вызова одного конструктора из другого по отношению к текущему объекту. Цепочка конструкторов возможна только в устаревших версиях, когда конструктор подкласса отвечает за вызов конструктора суперкласса первым. В цепочке конструкторов может быть любое количество классов. Цепочка конструкторов может быть достигнута двумя способами:

1) В том же классе, используя this().
2) Из базового класса с использованием super().
👍122
#Вопросы_с_собеседования
Чем отличается переопределение от перегрузки?


Переопределение — это возможность наследника предоставить свою реализацию метода, который уже предоставлен в родительском классе. При переопределении сигнатура метода (имя и параметры) в суперклассе и дочернем классе должны совпадать.

Перегрузка — это возможность определить несколько методов с одинаковым именем, но разными параметрами. При перегрузке сигнатура методов должна различаться по количеству, типу или порядку параметров.
👍251
DelayQueue

DelayQueue — это очередь, которая хранит элементы в порядке их задержки. Элементы в очереди извлекаются только после истечения их задержки.

DelayQueue реализует интерфейс BlockingQueue, поэтому элементы могут извлекаться из нее только блокирующими методами take() или poll(long timeout, TimeUnit unit).

Элементы DelayQueue должны реализовывать интерфейс Delayed. Интерфейс Delayed определяет два метода:

getDelay(): возвращает оставшуюся задержку элемента в миллисекундах.
isExpired(): возвращает true, если задержка элемента истекла.

#для_продвинутых
👍11
Что такое интерфейс Cloneable?

Это маркерный интерфейс, то есть он не содержит никаких методов, а только сигнализирует о том, что объекты класса, реализующего этот интерфейс, могут быть клонированы.
Клонирование объекта означает создание его независимой копии.

Как работает клонирование в Java?

1. Реализация интерфейса Cloneable: Класс, объекты которого вы хотите клонировать, должен реализовывать интерфейс Cloneable.
2. Переопределение метода clone(): Вам необходимо переопределить метод clone() из класса Object в вашем классе. Этот метод возвращает копию объекта.
3. Вызов метода clone(): Чтобы создать копию объекта, вызовите метод clone() у этого объекта.

#для_продвинутых
👍15
Атомарные переменные в Java.util.concurrent

Пакет java.util.concurrent.atomic определяет классы, которые поддерживают атомарные операции над отдельными переменными. Все классы имеют методы get и set, которые работают как чтение и запись волатильных переменных. То есть set имеет отношение happens-before с любым последующим get на той же переменной.

Ниже перечислены все переменные, определенные в пакете: AtomicBoolean, AtomicInteger, AtomicLong, AtomicReference.


В этом примере создается AtomicInteger со значением 0. Затем значение инкрементируется с помощью метода incrementAndGet(). В конце значение получается с помощью метода get().
👍11
Даны 3 потока Т1, Т2 и Т3? Как реализовать выполнение в последовательности Т1, Т2, Т3?

Такой последовательности выполнения можно достичь многими способами, например просто воспользоваться методом join(), чтобы запустить поток в момент, когда другой уже закончит своё выполнение. Для реализации заданной последовательности, нужно запустить последний поток первым, и затем вызывать метод join() в обратном порядке, то есть Т3 вызывает Т2.join, а Т2 вызывает Т1.join, таким образом Т1 закончит выполнение первым, а Т3 последним.
👍22