Чтение онлайн

на главную - закладки

Жанры

Философия Java3

Эккель Брюс

Шрифт:

Класс MappedByteBuffer унаследован от буфера ByteBuffer, поэтому он содержит все методы последнего. Здесь представлены только простейшие вызовы методов put и get, но вы также можете использовать такие возможности, как метод asCharBuffer и т. п.

Программа напрямую создает файл размером 128 Мбайт; скорее всего, это превышает ограничения вашей операционной системы на размер блока данных, находящегося в памяти. Однако создается впечатление, что весь файл доступен сразу, поскольку только часть его подгружается

в память, в то время как остальные части выгружены. Таким образом можно работать с очень большими (размером до 2 Гбайт) файлами. Заметьте, что для достижения максимальной производительности используются низкоуровневые механизмы отображения файлов используемой операционной системы.

Производительность

Хотя быстродействие «старого» ввода/вывода было улучшено за счет переписывания его с учетом новых библиотек nio, техника отображения файлов качественно эффективнее. Следующая программа выполняет простое сравнение производительности:

//. io/MappedIO.java import java.nio.*. import java.nio.channels *; import java io.*,

public class MappedIO {

private static int numOflnts = 4000000, private static int numOfUbufflnts = 200000; private abstract static class Tester { private String name,

public Tester(String name) { this name = name. } public void runTestO {

System.out.print(name + ": "). try {

long start = System nanoTimeO; test;

double duration = System.nanoTimeO - start; System.out.formates 2f\n", duration/1.0e9); } catch(IOException e) {

throw new RuntimeException(e).

}

}

public abstract void testO throws IOException;

}

private static Tester[] tests = {

new Tester("Stream Write") {

public void testO throws IOException {

DataOutputStream dos = new DataOutputStream( new BufferedOutputStream(

new FileOutputStream(new

FileC temp, tmp"))));

for(int i = 0; i < numOflnts; i++) dos writelnt(i); dos.closeO;

}

}.

new Tester("Mapped Write") {

public void testO throws IOException { FileChannel fc =

new RandomAccessFile("temp.tmp". "rw") getChannel; IntBuffer ib = fc map(

FileChannel .MapMode READ_WRITE, 0. fc sizeO) .asIntBufferO; for(int i = 0; i < numOflnts; i++)

ib.putCi); fc.closeO;

}

}.

new Tester("Stream Read") {

public void testO throws IOException {

DatalnputStream dis = new DatalnputStreamC new BufferedlnputStreamC

new F i1eInputSt rearn("temp.tmp"))); for(int i = 0; i < numOflnts; i++)

dis.readlntO; dis.closeO;

}

}.

new Tester("Mapped Read") {

public void testO throws IOException {

FileChannel fc = new FileInputStream(

new File("temp.tmp")).getChannelО; IntBuffer ib = fc.map(

Fi 1 eChannel.MapMode.READ_0NLY, 0. fc.sizeO) .asIntBufferO; while(ib. hasRemainingO)

ib.getO; fc. closeO;

}

}.

new Tester("Stream Read/Write") {

public void testO throws IOException {

RandomAccessFile raf = new RandomAccessFile(

new FileC'temp.tmp"), "rw"); raf.writelnt(l);

for(int i = 0; i < numOfUbufflnts; i++) { raf.seek(raf.length - 4); raf,writelnt(raf.readlnt);

}

raf.closeO;

}

}.

new Tester("Mapped Read/Write") {

public void testO throws IOException {

FileChannel fc = new RandomAccessFile(

new FileC'temp.tmp"). "rw").getChannelО; IntBuffer ib e fc.map(

FileChannel.MapMode.READ_WRITE. 0. fc.sizeO) .asIntBufferO; ib.put(O);

for(int i = 1; i < numOfUbufflnts; i++)

ib.put(ib.get(i - 1)); fc.closeO;

}

}

}:

public static void main(String[] args) { for(Tester test ; tests) test.runTestO;

}

} /* Output; Stream Write; 0.56 Mapped Write; 0.12 Stream Read; 0.80

Mapped Read: 0.07 продолжение &

Stream Read/Write 5.32 Mapped Read/Write 0.02 */// ~

Как

уже было видно из предыдущих примеров книги, runTest — не что иное как метод шаблона, предоставляющий тестовую инфраструктуру для различных реализаций метода test, определенного в безымянных внутренних подклассах. Каждый из этих подклассов выполняет свой вид теста, таким образом, методы test также являются прототипами для выполнения различных действий, связанных с вводом/выводом.

Хотя кажется, что для отображаемой записи следует использовать поток FileOutputStream, на самом деле любые операции отображаемого вывода должны проходить через класс RandomAccessFile так же, как выполняется чтение/запись в рассмотренном примере.

Отметьте, что в методах test также учитывается инициализация различных объектов для работы с вводом/выводом, и, несмотря на то что настройка отображаемых файлов может быть затратной, общее преимущество по сравнению с потоковым вводом/выводом все равно получается весьма значительным.

Блокировка файлов

Блокировка файлов позволяет синхронизировать доступ к файлу как к совместно используемому ресурсу. Впрочем, потоки, претендующие на один и тот же файл, могут принадлежать различным виртуальным машинам JVM, или один поток может быть Java-потоком, а другой представлять собой обычный поток операционной системы. Блокированные файлы видны другим процессам операционной системы, поскольку механизм блокировки Java напрямую связан со средствами операционной системы. Вот простой пример блокировки файла:

Поделиться:
Популярные книги

Долгий путь домой

Русич Антон
Вселенная EVE Online
Фантастика:
космическая фантастика
попаданцы
6.20
рейтинг книги
Долгий путь домой

Убивать чтобы жить 6

Бор Жорж
6. УЧЖ
Фантастика:
боевая фантастика
космическая фантастика
рпг
5.00
рейтинг книги
Убивать чтобы жить 6

Возвышение Меркурия. Книга 3

Кронос Александр
3. Меркурий
Фантастика:
попаданцы
аниме
5.00
рейтинг книги
Возвышение Меркурия. Книга 3

Фиктивная жена

Шагаева Наталья
1. Братья Вертинские
Любовные романы:
современные любовные романы
5.00
рейтинг книги
Фиктивная жена

Здравствуй, 1985-й

Иванов Дмитрий
2. Девяностые
Фантастика:
альтернативная история
5.25
рейтинг книги
Здравствуй, 1985-й

Барон Дубов 4

Карелин Сергей Витальевич
4. Его Дубейшество
Фантастика:
юмористическое фэнтези
аниме
сказочная фантастика
фэнтези
5.00
рейтинг книги
Барон Дубов 4

Лекарь для захватчика

Романова Елена
Фантастика:
попаданцы
историческое фэнтези
фэнтези
5.00
рейтинг книги
Лекарь для захватчика

Идеальный мир для Лекаря 24

Сапфир Олег
24. Лекарь
Фантастика:
городское фэнтези
попаданцы
5.00
рейтинг книги
Идеальный мир для Лекаря 24

Ваше Сиятельство 9

Моури Эрли
9. Ваше Сиятельство
Фантастика:
боевая фантастика
попаданцы
стимпанк
аниме
фэнтези
5.00
рейтинг книги
Ваше Сиятельство 9

Господин следователь

Шалашов Евгений Васильевич
1. Господин следователь
Детективы:
исторические детективы
5.00
рейтинг книги
Господин следователь

Академия проклятий. Книги 1 - 7

Звездная Елена
Академия Проклятий
Фантастика:
фэнтези
8.98
рейтинг книги
Академия проклятий. Книги 1 - 7

Полковник Гуров. Компиляция (сборник)

Макеев Алексей Викторович
Полковник Гуров
Детективы:
криминальные детективы
шпионские детективы
полицейские детективы
боевики
крутой детектив
5.00
рейтинг книги
Полковник Гуров. Компиляция (сборник)

Первый среди равных. Книга V

Бор Жорж
5. Первый среди Равных
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Первый среди равных. Книга V

Землянка для двух нагов

Софи Ирен
Фантастика:
космическая фантастика
5.00
рейтинг книги
Землянка для двух нагов