當前位置: 首頁>>代碼示例>>Java>>正文


Java FileChannel.open方法代碼示例

本文整理匯總了Java中java.nio.channels.FileChannel.open方法的典型用法代碼示例。如果您正苦於以下問題:Java FileChannel.open方法的具體用法?Java FileChannel.open怎麽用?Java FileChannel.open使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.nio.channels.FileChannel的用法示例。


在下文中一共展示了FileChannel.open方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: mismatchingRevision

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Test
public void mismatchingRevision() throws Exception {
    db.close();

    // Append a record with incorrect revision number.
    try (FileChannel f = FileChannel.open(new File(tmpDir.getRoot(), "commit_ids.dat").toPath(),
                                          StandardOpenOption.APPEND)) {

        final ByteBuffer buf = ByteBuffer.allocate(24);
        buf.putInt(42); // Expected to be 1.
        randomCommitId().copyRawTo(buf);
        buf.flip();
        do {
            f.write(buf);
        } while (buf.hasRemaining());

        assertThat(f.size()).isEqualTo(buf.capacity());
    }

    // Reopen the database and see if it fails to resolve the revision 1.
    db = new CommitIdDatabase(tmpDir.getRoot());
    assertThatThrownBy(() -> db.get(Revision.INIT))
            .isInstanceOf(StorageException.class)
            .hasMessageContaining("incorrect revision number");
}
 
開發者ID:line,項目名稱:centraldogma,代碼行數:26,代碼來源:CommitIdDatabaseTest.java

示例2: shouldLockTaskStateDirectory

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Test
public void shouldLockTaskStateDirectory() throws Exception {
    final TaskId taskId = new TaskId(0, 0);
    final File taskDirectory = directory.directoryForTask(taskId);

    directory.lock(taskId, 0);

    try (
        final FileChannel channel = FileChannel.open(
            new File(taskDirectory, StateDirectory.LOCK_FILE_NAME).toPath(),
            StandardOpenOption.CREATE, StandardOpenOption.WRITE)
    ) {
        channel.tryLock();
        fail("shouldn't be able to lock already locked directory");
    } catch (final OverlappingFileLockException e) {
        // pass
    } finally {
        directory.unlock(taskId);
    }
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:21,代碼來源:StateDirectoryTest.java

示例3: main

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public static void main(String[] args) throws Throwable {
    try (FileChannel ch = FileChannel.open(BLK_PATH, READ);
         RandomAccessFile file = new RandomAccessFile(BLK_FNAME, "r")) {

        long size1 = ch.size();
        long size2 = file.length();
        if (size1 != size2) {
            throw new RuntimeException("size differs when retrieved" +
                    " in different ways: " + size1 + " != " + size2);
        }
        System.out.println("OK");

    } catch (NoSuchFileException nsfe) {
        System.err.println("File " + BLK_FNAME + " not found." +
                " Skipping test");
    } catch (AccessDeniedException ade) {
        System.err.println("Access to " + BLK_FNAME + " is denied." +
                " Run test as root.");
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:21,代碼來源:BlockDeviceSize.java

示例4: truncatedDatabase

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Test
public void truncatedDatabase() throws Exception {
    db.put(Revision.INIT, randomCommitId());
    db.close();

    // Truncate the database file.
    try (FileChannel f = FileChannel.open(new File(tmpDir.getRoot(), "commit_ids.dat").toPath(),
                     StandardOpenOption.APPEND)) {

        assertThat(f.size()).isEqualTo(24);
        f.truncate(23);
    }

    assertThatThrownBy(() -> new CommitIdDatabase(tmpDir.getRoot()))
            .isInstanceOf(StorageException.class)
            .hasMessageContaining("incorrect file length");
}
 
開發者ID:line,項目名稱:centraldogma,代碼行數:18,代碼來源:CommitIdDatabaseTest.java

示例5: writeToLocal

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public Location writeToLocal(BytesReference data) throws IOException {
    final long position;
    final long generation;
    try (ReleasableLock lock = writeLock.acquire()) {
        ensureOpen();
        if (writtenOffset > TRANSLOG_ROLLING_SIZE_BYTES) {
            IOUtils.close(writeChannel);
            tmpTranslogGeneration.incrementAndGet();
            writeChannel = FileChannel.open(this.translogPath.resolve(getFileNameFromId(tmpTranslogGeneration.get())), StandardOpenOption.CREATE_NEW, StandardOpenOption.WRITE);
            writtenOffset = 0;
        }
        generation = tmpTranslogGeneration.get();
        position = writtenOffset;
        try {
            data.writeTo(writeChannel);
        } catch (Throwable e) {
            throw e;
        }
        writtenOffset = writtenOffset + data.length();
    }
    return new Translog.Location(generation, position, data.length());
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:23,代碼來源:LocalTranslog.java

示例6: corruptTranslogs

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
 * Randomly overwrite some bytes in the translog files
 */
private void corruptTranslogs(Path directory) throws Exception {
    Path[] files = FileSystemUtils.files(directory, "translog-*");
    for (Path file : files) {
        logger.info("--> corrupting {}...", file);
        FileChannel f = FileChannel.open(file, StandardOpenOption.READ, StandardOpenOption.WRITE);
        int corruptions = scaledRandomIntBetween(10, 50);
        for (int i = 0; i < corruptions; i++) {
            // note: with the current logic, this will sometimes be a no-op
            long pos = randomIntBetween(0, (int) f.size());
            ByteBuffer junk = ByteBuffer.wrap(new byte[]{randomByte()});
            f.write(junk, pos);
        }
        f.close();
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:19,代碼來源:TranslogTests.java

示例7: applyXOR

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public static void applyXOR(Path assemblyFile, long limit) throws URISyntaxException, IOException {
	Path inputFile = assemblyFile.resolveSibling(DLL_NAME + ".bak");
	URI xorUri = FileUtils.class.getResource("/" + XOR_NAME).toURI();

	Files.move(assemblyFile, inputFile, StandardCopyOption.REPLACE_EXISTING);

	try (FileSystem fileSystem = createFileSystem(xorUri); // Required to resolve xorUri
	     FileChannel inputChannel = FileChannel.open(inputFile, READ);
	     FileChannel xorChannel = FileChannel.open(Paths.get(xorUri), READ);
	     FileChannel outputChannel = FileChannel.open(assemblyFile, WRITE, CREATE_NEW)) {

		xorFiles(inputChannel, xorChannel, outputChannel, limit);
	} catch (Throwable t) {
		Files.deleteIfExists(assemblyFile);
		Files.move(inputFile, assemblyFile);
		throw t;
	}
}
 
開發者ID:zeobviouslyfakeacc,項目名稱:ModLoaderInstaller,代碼行數:19,代碼來源:FileUtils.java

示例8: read

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Override
public InputStream read(final Path file, final TransferStatus status, final ConnectionCallback callback) throws BackgroundException {
    try {
        final FileChannel channel = FileChannel.open(session.toPath(file), StandardOpenOption.READ);
        channel.position(status.getOffset());
        return Channels.newInputStream(channel);
    }
    catch(IOException e) {
        throw new LocalExceptionMappingService().map("Download {0} failed", e, file);
    }
}
 
開發者ID:iterate-ch,項目名稱:cyberduck,代碼行數:12,代碼來源:LocalReadFeature.java

示例9: onSubscribe

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Override
public void onSubscribe(Flow.Subscription subscription) {
    this.subscription = subscription;
    try {
        out = FileChannel.open(file, options);
    } catch (IOException e) {
        result.completeExceptionally(e);
        subscription.cancel();
        return;
    }
    subscription.request(1);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:13,代碼來源:ResponseProcessors.java

示例10: uploadChunk

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public Observable<Long> uploadChunk(TusRequest request) {
    if (uploadInProgress.compareAndSet(false, true)) {
        refreshTimer();
        try {
            FileChannel fChannel = FileChannel.open(
                    rootDir.resolve(uuid.toString()).resolve("chunk-" + offset.get()),
                    new StandardOpenOption[] { StandardOpenOption.CREATE, StandardOpenOption.WRITE });

            return request.getContent().doOnNext(bb -> logger.debug("received some ByteBuffer"))
                    .buffer(100, TimeUnit.MILLISECONDS)
                    .filter(bb -> bb.size() > 0)
                    .flatMap(bb -> Observable.fromCallable(() -> {
                        logger.debug("writing " + bb.size() + " buffers  to file");
                        return fChannel.write(bb.toArray(new ByteBuffer[bb.size()]));
                    }).observeOn(Schedulers.io()))
                    .doOnError(x -> {
                        logger.error("something went wrong, cleaning up", x);
                        uploadInProgress.set(false);
                        cleanup(fChannel);
                    })
                    .doOnCompleted(() -> {
                        logger.debug("cool bro, it is done, cleaning up");
                        uploadInProgress.set(false);
                        cleanup(fChannel);
                    });
        } catch (IOException e1) {
            return Observable.error(e1);
        }
    } else {
        return Observable.error(new ChunkAlreadyUploadingException());
    }
}
 
開發者ID:jerbome,項目名稱:tusRx,代碼行數:33,代碼來源:TusUpload.java

示例11: newFileChannel

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
static FileChannel newFileChannel(File file) throws IOException {
    if (rand.nextBoolean()) {
        return new FileOutputStream(file, true).getChannel();
    } else {
        return FileChannel.open(file.toPath(), APPEND);
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:8,代碼來源:AtomicAppend.java

示例12: main

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    Path blah = Files.createTempFile("blah", null);
    blah.toFile().deleteOnExit();
    initTestFile(blah);

    for (int i=0; i<10; i++) {
        try (FileChannel fc = (generator.nextBoolean()) ?
                FileChannel.open(blah, READ) :
                new FileInputStream(blah.toFile()).getChannel()) {
            for (int j=0; j<100; j++) {
                long newPos = generator.nextInt(1000);
                fc.position(newPos);
                if (fc.position() != newPos)
                    throw new RuntimeException("Position failed");
            }
        }
    }

    for (int i=0; i<10; i++) {
        try (FileChannel fc = (generator.nextBoolean()) ?
                 FileChannel.open(blah, APPEND) :
                 new FileOutputStream(blah.toFile(), true).getChannel()) {
            for (int j=0; j<10; j++) {
                if (fc.position() != fc.size())
                    throw new RuntimeException("Position expected to be size");
                byte[] buf = new byte[generator.nextInt(100)];
                fc.write(ByteBuffer.wrap(buf));
            }
        }
    }

    Files.delete(blah);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:34,代碼來源:Position.java

示例13: beforeAll

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@BeforeAll
void beforeAll() throws IOException {
    file = FileGenerator.randomTempFile(1024);
    fc = FileChannel.open(file.path, StandardOpenOption.READ);
    defaultAmazonS3().putObject(testBucket, key, file.path.toFile());
    s3Channel = S3ReadableObjectChannel.builder()
            .amazonS3(defaultAmazonS3())
            .bucket(testBucket)
            .key(key)
            .build();
    assertEquals(s3Channel.size(), 1024);
}
 
開發者ID:mentegy,項目名稱:s3-channels,代碼行數:13,代碼來源:S3RangedReadObjectChannelTest.java

示例14: concat

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
private void concat(final Path baseFolder, List<Path> paths) throws IOException {
    final Path outFile = Paths.get(baseFolder.toString(), FRAGMENT_FOLDER, UUID.randomUUID() + FRAGMENT_POSTFIX);
    try (FileChannel out = FileChannel.open(outFile, StandardOpenOption.CREATE_NEW, StandardOpenOption.WRITE)) {
        for (Path part : paths) {
            transferPart(out, part);
        }
    }
    for (Path path : paths) {
        Files.delete(path);
    }
}
 
開發者ID:MinBZK,項目名稱:OperatieBRP,代碼行數:12,代碼來源:SelectieFileServiceImpl.java

示例15: init

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Override
public void init() throws IOException {
	approversChannel = FileChannel.open(Paths.get(APPROVERS_FILE_NAME), 
			StandardOpenOption.CREATE, StandardOpenOption.READ, StandardOpenOption.WRITE);
	
	approversChunks[0] = approversChannel.map(FileChannel.MapMode.READ_WRITE, 0, SUPER_GROUPS_SIZE);
	final long approversChannelSize = approversChannel.size();
	while (true) {

		if ((approversNextPointer & (CHUNK_SIZE - 1)) == 0) {
			approversChunks[(int) (approversNextPointer >> 27)] = approversChannel
			        .map(FileChannel.MapMode.READ_WRITE, approversNextPointer, CHUNK_SIZE);
		}
		if (approversChannelSize - approversNextPointer > CHUNK_SIZE) {
			approversNextPointer += CHUNK_SIZE;
		} else {
			approversChunks[(int) (approversNextPointer >> 27)].get(mainBuffer);
			boolean empty = true;
			for (final int value : mainBuffer) {

				if (value != 0) {
					empty = false;
					break;
				}
			}
			if (empty) {
				break;
			}
			approversNextPointer += CELL_SIZE;
		}
	}
}
 
開發者ID:AidosKuneen,項目名稱:aidos-node,代碼行數:33,代碼來源:StorageApprovers.java


注:本文中的java.nio.channels.FileChannel.open方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。