/* * Copyright (c) 2000, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions.
*/
/** * Creates file blah: * 0000 * 0001 * 0002 * 0003 * . * . * . * 3999 * * Blah extends beyond a single page of memory so that the * ability to index into a file of multiple pages is tested.
*/ privatestaticvoid initTestFile(File blah) throws Exception { try (BufferedWriter writer = Files.newBufferedWriter(blah.toPath(), ISO_8859_1)) { for (int i=0; i<4000; i++) {
String number = new Integer(i).toString(); for (int h=0; h<4-number.length(); h++)
writer.write("0");
writer.write(""+i);
writer.newLine();
}
}
}
/** * Tests zero size file mapping
*/ privatestaticvoid testZero() throws Exception { try (FileInputStream fis = new FileInputStream(blah)) {
FileChannel fc = fis.getChannel();
MappedByteBuffer b = fc.map(MapMode.READ_ONLY, 0, 0);
}
}
/** * Maps blah file with a random offset and checks to see if read * from the ByteBuffer gets the right line number
*/ privatestaticvoid testRead() throws Exception {
StringBuilder sb = new StringBuilder();
sb.setLength(4);
for (int x=0; x<1000; x++) { try (FileInputStream fis = new FileInputStream(blah)) {
FileChannel fc = fis.getChannel();
long offset = generator.nextInt(10000); long expectedResult = offset / CHARS_PER_LINE;
offset = expectedResult * CHARS_PER_LINE;
MappedByteBuffer b = fc.map(MapMode.READ_ONLY,
offset, 100);
int result = Integer.parseInt(sb.toString()); if (result != expectedResult) {
err.println("I expected "+expectedResult);
err.println("I got "+result); thrownew Exception("Read test failed");
}
}
}
}
/** * Maps blah file with a random offset and checks to see if data * written out to the file can be read back in
*/ privatestaticvoid testWrite() throws Exception {
StringBuilder sb = new StringBuilder();
sb.setLength(4);
for (int x=0; x<1000; x++) { try (RandomAccessFile raf = new RandomAccessFile(blah, "rw")) {
FileChannel fc = raf.getChannel();
long offset = generator.nextInt(1000);
MappedByteBuffer b = fc.map(MapMode.READ_WRITE,
offset, 100);
for (int x=0; x<1000; x++) { try (RandomAccessFile raf = new RandomAccessFile(blah, "rw")) {
FileChannel fc = raf.getChannel(); long offset = 66000;
MappedByteBuffer b = fc.map(MapMode.READ_WRITE,
offset, 100);
}
}
}
/** * Maps blah file, writes some data and forcing writeback of * the data exercising various valid and invalid writeback ranges.
*/ privatestaticvoid testForce() throws Exception { try (RandomAccessFile raf = new RandomAccessFile(blah, "rw")) {
FileChannel fc = raf.getChannel(); finalint BLOCK_SIZE = 64; finalint BLOCK_COUNT = (4096 * 2)/ BLOCK_SIZE; int offset = 0;
MappedByteBuffer b = fc.map(MapMode.READ_WRITE,
0, BLOCK_SIZE * (BLOCK_COUNT + 1));
for (int blocks = 0; blocks < BLOCK_COUNT; blocks++) { for (int i = 0; i < BLOCK_SIZE; i++) {
b.put(offset + i, (byte)('0' + i));
}
b.force(offset, BLOCK_SIZE);
offset += BLOCK_SIZE;
}
Exception exc = null; try { // start and end are out of range
b.force(offset + BLOCK_SIZE, BLOCK_SIZE);
} catch (IndexOutOfBoundsException e) {
exc = e;
} if (exc == null) { thrownew RuntimeException("expected Exception for force beyond buffer extent");
}
exc = null; try { // start is in range but end is out of range
b.force(offset, 2 * BLOCK_SIZE);
} catch (IndexOutOfBoundsException e) {
exc = e;
} if (exc == null) { thrownew RuntimeException("expected Exception for force beyond write limit");
}
}
}
/** * Test exceptions specified by map method
*/ privatestaticvoid testExceptions() throws Exception { // check exceptions when channel opened for read access try (FileChannel fc = FileChannel.open(blah.toPath(), READ)) {
testExceptions(fc);
/* * implementation/spec mismatch, these tests disabled for now
*/ //checkException(fc, MapMode.READ_WRITE, 0L, fc.size(), // NonWritableChannelException.class); //checkException(fc, MapMode.PRIVATE, 0L, fc.size(), // NonWritableChannelException.class);
}
// check exceptions when channel opened for read and write access try (FileChannel fc = FileChannel.open(blah.toPath(), READ, WRITE)) {
testExceptions(fc);
}
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.