Главная страница

ОглавлениеCore


Скачать 1.53 Mb.
НазваниеОглавлениеCore
Дата17.05.2023
Размер1.53 Mb.
Формат файлаpdf
Имя файлаpolnaya_metodichka (1).pdf
ТипДокументы
#1138113
страница11 из 25
1   ...   7   8   9   10   11   12   13   14   ...   25
CloneNotSupportedException.
Как создать глубокую копию объекта (2 способа)?
Глубокое клонирование требует выполнения следующих правил:

нет необходимости копировать отдельно примитивные данные;

все классы-члены в оригинальном классе должны поддерживать клонирование,
Для каждого члена класса должен вызываться super.clone() при переопределении метода clone();

если какой-либо член класса не поддерживает клонирование, то в методе клонирования необходимо создать новый экземпляр этого класса и скопировать каждый его член со всеми атрибутами в новый объект класса, по одному.
Сериализация – это еще один способ глубокого копирования. Просто сериализуем нужный объект и десериализуем его. При этом объект должен поддерживать интерфейс Serializable.
Сохраняем объект в массив байт и потом читаем из него.
Рефлексия
Рефлексия (Reflection) – это механизм получения данных о программе во время ее выполнения (runtime). В Java Reflection осуществляется с помощью Java Reflection API,
состоящего из классов пакетов java.lang и java.lang.reflect.
Возможности Java Reflection API:

определение класса объекта;

получение информации о модификаторах класса, полях, методах, конструкторах и суперклассах;

определение интерфейсов, реализуемых классом;

создание экземпляра класса;

получение и установка значений полей объекта;

вызов методов объекта;

создание нового массива.
Класс Optional
Опциональное значение Optional – это контейнер для объекта, который может содержать или не содержать значение null. Такая обертка является удобным средством предотвращения NullPointerException, т. к. имеет некоторые функции высшего порядка,
избавляющие от добавления повторяющихся проверок if null/notNull.

Core-2
Что такое generics?
Generics – это технический термин, обозначающий набор свойств языка, позволяющих определять и использовать обобщенные типы и методы. Обобщенные типы или методы отличаются от обычных тем, что имеют типизированные параметры.
Примером использования обобщенных типов может служить Java Collection Framework. Так,
класс LinkedList – типичный обобщенный тип. Он содержит параметр E, который представляет тип элементов, которые будут храниться в коллекции. Создание объектов обобщенных типов происходит посредством замены параметризированных типов реальными типами данных. Вместо того, чтобы просто использовать LinkedList, ничего не говоря о типе элемента в списке, предлагается использовать точное указание типа
LinkedList, LinkedList и т. п.
Что такое raw type (сырой тип)?
Это имя интерфейса без указания параметризованного типа:
List list = new ArrayList(); // raw type
List listIntgrs = new ArrayList<>(); // parameterized type
Что такое стирание типов?
Суть заключается в том, что внутри класса не хранится никакой информации о типе- параметре. Эта информация доступна только на этапе компиляции и стирается (становится недоступной) в runtime.
В чем заключается разница между IO и NIO?
Java IO (input-output) является потокоориентированным, а Java NIO (new/non-blocking io) –
буфер-ориентированным. Потокоориентированный ввод/вывод подразумевает чтение/запись из потока/в поток одного или нескольких байт в единицу времени поочередно. Данная информация нигде не кешируются. Таким образом, невозможно произвольно двигаться по потоку данных вперед или назад. В Java NIO данные сначала считываются в буфер, что дает больше гибкости при обработке данных.
Потоки ввода/вывода в Java IO являются блокирующими. Это значит, что когда в потоке выполнения вызывается read() или write() метод любого класса из пакета java.io.*,
происходит блокировка до тех пор, пока данные не будут считаны или записаны. Поток выполнения в данный момент не может делать ничего другого. Неблокирующий режим Java
NIO позволяет запрашивать считанные данные из канала (channel) и получать только то, что доступно на данный момент, или вообще ничего, если доступных данных пока нет. Вместо того, чтобы оставаться заблокированным, пока данные не станут доступными для считывания, поток выполнения может заняться чем-то другим. То же самое справедливо и для неблокирующего вывода. Поток выполнения может запросить запись в канал некоторых данных, но не дожидаться при этом, пока они не будут полностью записаны.
В Java NIO имеются селекторы, которые позволяют одному потоку выполнения мониторить несколько каналов ввода. Т. е. существует возможность зарегистрировать несколько каналов с селектором, а потом использовать один поток выполнения для обслуживания каналов,
имеющих доступные для обработки данные, или для выбора каналов, готовых для записи.

Какие классы поддерживают чтение и запись потоков в сжатом формате?

DeflaterOutputStream – компрессия данных в формате deflate;

Deflater – компрессия данных в формат ZLIB;

ZipOutputStream – потомок DeflaterOutputStream для компрессии данных в формате
Zip;

GZIPOutputStream – потомок DeflaterOutputStream для компрессии данных в формат
GZIP;

InflaterInputStream – декомпрессия данных в формате deflate;

Inflater – декомпрессия данных в формате ZLIB;

ZipInputStream – потомок InflaterInputStream для декомпрессии данных в формате Zip;

GZIPInputStream – потомок InflaterInputStream для декомпрессии данных в формате
GZIP.
Что такое «каналы»?
Каналы (channels) – это логические (не физические) порталы, абстракции объектов более низкого уровня файловой системы (например, отображенные в памяти файлы и блокировки файлов), через которые осуществляется ввод/вывод данных, а буферы являются источниками или приемниками этих переданных данных. При организации вывода данные,
которые необходимо отправить, помещаются в буфер, который затем передается в канал.
При вводе данные из канала помещаются в заранее предоставленный буфер.
Каналы напоминают трубопроводы, по которым эффективно транспортируются данные между буферами байтов и сущностями по ту сторону каналов. Каналы – это шлюзы, которые позволяют получить доступ к сервисам ввода/вывода операционной системы с минимальными накладными расходами, а буферы – внутренние конечные точки этих шлюзов, используемые для передачи и приема данных.
Назовите основные классы потоков ввода/вывода?
Разделяют два вида потоков ввода/вывода:

байтовые – java.io.InputStream, java.io.OutputStream;

символьные – java.io.Reader, java.io.Writer.
В каких пакетах расположены классы потоков ввода/вывода?
java.io, java.nio. Для работы с потоками сжатых данных используются классы из пакета java.util.zip.
Какие подклассы класса InputStream вы знаете, для чего они предназначены?

InputStream – абстрактный класс, описывающий поток ввода;

BufferedInputStream – буферизованный входной поток;

ByteArrayInputStream позволяет использовать буфер в памяти (массив байтов) в качестве источника данных для входного потока;

DataInputStream – входной поток для байтовых данных, включающий методы для чтения стандартных типов данных Java;


FileInputStream – входной поток для чтения информации из файла;

FilterInputStream – абстрактный класс, предоставляющий интерфейс для классов- надстроек, которые добавляют к существующим потокам полезные свойства;

ObjectInputStream – входной поток для объектов;

StringBufferInputStream превращает строку (String) во входной поток данных
InputStream;

PipedInputStream реализует понятие входного канала;

PrintStream – выходной поток, включающий методы print() и println();

PushbackInputStream – разновидность буферизации, обеспечивающая чтение байта с последующим его возвратом в поток, позволяет «заглянуть» во входной поток и увидеть, что оттуда поступит в следующий момент, не извлекая информации;

SequenceInputStream используется для слияния двух или более потоков InputStream в единый.
Для чего используется PushbackInputStream?
Разновидность буферизации, обеспечивающая чтение байта с последующим его возвратом в поток. Класс PushbackInputStream позволяет «заглянуть» во входной поток и увидеть, что оттуда поступит в следующий момент, не извлекая информации.
У класса есть дополнительный метод unread().
Для чего используется SequenceInputStream?
Класс SequenceInputStream позволяет сливать вместе несколько экземпляров класса
InputStream. Конструктор принимает в качестве аргумента либо пару объектов класса
InputStream, либо интерфейс Enumeration.
Во время работы класс выполняет запросы на чтение из первого объекта класса InputStream и до конца, а затем переключается на второй. При использовании интерфейса работа продолжится по всем объектам класса InputStream. По достижении конца связанный с ним поток закрывается. Закрытие потока, созданного объектом класса SequenceInputStream,
приводит к закрытию всех открытых потоков.
Какой класс позволяет читать данные из входного байтового потока в
формате примитивных типов данных?
Класс DataInputStream представляет поток ввода и предназначен для записи данных примитивных типов, таких, как int, double и т. д. Для каждого примитивного типа определен свой метод для считывания:

boolean readBoolean(): считывает из потока булевое однобайтовое значение;

byte readByte(): считывает из потока 1 байт;

char readChar(): считывает из потока значение char;

double readDouble(): считывает из потока 8-байтовое значение double;

float readFloat(): считывает из потока 4-байтовое значение float;

int readInt(): считывает из потока целочисленное значение int;


long readLong(): считывает из потока значение long;

short readShort(): считывает значение short;

String readUTF(): считывает из потока строку в кодировке UTF-8.
Какие подклассы класса OutputStream вы знаете, для чего они
предназначены?

OutputStream – это абстрактный класс, определяющий потоковый байтовый вывод;

BufferedOutputStream – буферизированный выходной поток;

ByteArrayOutputStream – все данные, посылаемые в этот поток, размещаются в предварительно созданном буфере;

DataOutputStream – выходной поток байт, включающий методы для записи стандартных типов данных Java;

FileOutputStream – запись данных в файл на физическом носителе;

FilterOutputStream – абстрактный класс, предоставляющий интерфейс для классов- надстроек, которые добавляют к существующим потокам полезные свойства;

ObjectOutputStream – выходной поток для записи объектов;

PipedOutputStream реализует понятие выходного канала.
Какие подклассы класса Reader вы знаете, для чего они предназначены?

Reader – абстрактный класс, описывающий символьный ввод;

BufferedReader – буферизованный входной символьный поток;

CharArrayReader – входной поток, который читает из символьного массива;

FileReader – входной поток, читающий файл;

FilterReader – абстрактный класс, предоставляющий интерфейс для классов- надстроек;

InputStreamReader – входной поток, транслирующий байты в символы;

LineNumberReader – входной поток, подсчитывающий строки;

PipedReader – входной канал;

PushbackReader – входной поток, позволяющий возвращать символы обратно в поток;

StringReader – входной поток, читающий из строки.
Какие подклассы класса Writer вы знаете, для чего они предназначены?

Writer – абстрактный класс, описывающий символьный вывод;

BufferedWriter – буферизованный выходной символьный поток;

CharArrayWriter – выходной поток, который пишет в символьный массив;

FileWriter – выходной поток, пишущий в файл;

FilterWriter – абстрактный класс, предоставляющий интерфейс для классов- надстроек;


OutputStreamWriter – выходной поток, транслирующий байты в символы;

PipedWriter – выходной канал;

PrintWriter – выходной поток символов, включающий методы print() и println();

StringWriter – выходной поток, пишущий в строку;
В чем отличие класса PrintWriter от PrintStream?
В классе PrintWriter применен усовершенствованный способ работы с символами Unicode и другой механизм буферизации вывода. В классе PrintStream буфер вывода сбрасывался всякий раз, когда вызывался метод print() или println(), а при использовании класса PrintWriter существует возможность отказаться от автоматического сброса буферов, выполняя его явным образом при помощи метода flush().
Кроме того, методы класса PrintWriter никогда не создают исключений. Для проверки ошибок необходимо явно вызвать метод checkError().
Чем отличаются и что общего у InputStream, OutputStream, Reader, Writer?

InputStream и его наследники – совокупность для получения байтовых данных из различных источников;

OutputStream и его наследники – набор классов определяющих потоковый байтовый вывод;

Reader и его наследники определяют потоковый ввод символов Unicode;

Writer и его наследники определяют потоковый вывод символов Unicode.
Какие классы позволяют преобразовать байтовые потоки в символьные и
обратно?

OutputStreamWriter – «мост» между классом OutputStream и классом Writer, символы,
записанные в поток, преобразовываются в байты;

InputStreamReader – аналог для чтения, при помощи методов класса Reader читаются байты из потока InputStream и далее преобразуются в символы.
Какие классы позволяют ускорить чтение/запись за счет использования
буфера?

BufferedInputStream(InputStream in)/BufferedInputStream(InputStream in, int size);

BufferedOutputStream(OutputStream out)/BufferedOutputStream(OutputStream out, int size);

BufferedReader(Reader r)/BufferedReader(Reader in, int sz);

BufferedWriter(Writer out)/BufferedWriter(Writer out, int sz).
Существует ли возможность перенаправить потоки стандартного
ввода/вывода?
Класс System позволяет вам перенаправлять стандартный ввод, вывод и поток вывода ошибок, используя простой вызов статического метода:

setIn(InputStream) – для ввода;


setOut(PrintStream) – для вывода;

setErr(PrintStream) – для вывода ошибок.
Какой класс предназначен для работы с элементами файловой системы?
File работает непосредственно с файлами и каталогами. Данный класс позволяет создавать новые элементы и получать информацию существующих: размер, права доступа, время и дату создания, путь к родительскому каталогу.
Какие методы класса File вы знаете?
Наиболее используемые методы класса File:

boolean createNewFile(): делает попытку создать новый файл;

boolean delete(): делает попытку удалить каталог или файл;

boolean mkdir(): делает попытку создать новый каталог;

boolean renameTo(File dest): делает попытку переименовать файл или каталог;

boolean exists(): проверяет, существует ли файл или каталог;

String getAbsolutePath(): возвращает абсолютный путь для пути, переданного в конструктор объекта;

String getName(): возвращает краткое имя файла или каталога;

String getParent(): возвращает имя родительского каталога;

boolean isDirectory(): возвращает значение true, если по указанному пути располагается каталог;

boolean isFile(): возвращает значение true, если по указанному пути находится файл;

boolean isHidden(): возвращает значение true, если каталог или файл являются скрытыми;

long length(): возвращает размер файла в байтах;

long lastModified(): возвращает время последнего изменения файла или каталога;

String[] list(): возвращает массив файлов и подкаталогов, которые находятся в определенном каталоге;

File[] listFiles(): возвращает массив файлов и подкаталогов, которые находятся в определенном каталоге.
Что вы знаете об интерфейсе FileFilter?
Интерфейс FileFilter применяется для проверки, попадает ли объект File под некоторое условие. Этот интерфейс содержит единственный метод boolean accept(File pathName). Этот метод необходимо переопределить и реализовать. Например:
public boolean accept(final File file) {
return file.isExists() && file.isDirectory();
}

Как выбрать все элементы определенного каталога по критерию
(например, с определенным расширением)?
Метод File.listFiles() возвращает массив объектов File, содержащихся в каталоге. Метод может принимать в качестве параметра объект класса, реализующего FileFilter. Это позволяет включить в список только те элементы, для которых метод accept возвращает true
(критерием может быть длина имени файла или его расширение).
Что вы знаете о RandomAccessFile?
Класс java.io.RandomAccessFile обеспечивает чтение и запись данных в произвольном месте файла. Он не является частью иерархии InputStream или OutputStream. Это полностью отдельный класс, имеющий собственные (в большинстве своем native) методы.
Объяснением этого может быть то, что RandomAccessFile имеет во многом отличающееся поведение по сравнению с остальными классами ввода/вывода, так как позволяет в пределах файла перемещаться вперед и назад.
RandomAccessFile имеет такие специфические методы как:

getFilePointer() для определения текущего местоположения в файле;

seek() для перемещения на новую позицию в файле;

length() для выяснения размера файла;

setLength() для установки размера файла;

skipBytes() для того, чтобы попытаться пропустить определенное число байт;

getChannel() для работы с уникальным файловым каналом, ассоциированным с заданным файлом;

методы для выполнения обычного и форматированного вывода из файла (read(),
readInt(), readLine(), readUTF() и т.п .);

методы для обычной или форматированной записи в файл с прямым доступом
(write(), writeBoolean(), writeByte() и т. п.).
Следует отметить, что конструкторы RandomAccessFile требуют второй аргумент,
указывающий необходимый режим доступа к файлу – только чтение ("r"), чтение и запись
("rw") или иную их разновидность.
1   ...   7   8   9   10   11   12   13   14   ...   25


написать администратору сайта