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


Java MapMode類代碼示例

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


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

示例1: SharedSystemData

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
/**
 * Constructor.
 * @throws IOException 
 */
public SharedSystemData(String path, boolean create) throws IOException {
	File f = new File(path);
	
	if (create) {
		if (f.exists()) {
			System.out.println("Existing system detected, deleting");
			f.delete(); // Delete if present.
		}
	} else {
		if (!f.exists()) {
			System.err.println("ERROR, system dont exist");
			System.exit(-1);
		}
	}
	channel = FileChannel.open(f.toPath(), StandardOpenOption.READ, StandardOpenOption.WRITE, StandardOpenOption.CREATE);
	buffer = channel.map(MapMode.READ_WRITE, 0, 4000);
	
	if (create) {
		setNextTaskId(0);
		setShutdownSignal(false);
	}
}
 
開發者ID:bizzard4,項目名稱:MpiTaskFramework,代碼行數:27,代碼來源:SharedSystemData.java

示例2: call

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
public ByteBuffer call() throws Exception {
    ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
    buff = ByteBuffer.allocate(bufferSize);
    serverSocketChannel.socket().bind(new InetSocketAddress(port));
    while (!stop.isLocked()) {
        RandomAccessFile temp = new RandomAccessFile(tempName, "rw");
        SocketChannel socketChannel = serverSocketChannel.accept();
        socketChannel.read(buff);
        FileChannel channel = temp.getChannel();
        channel.write(buff);
        if (!pause.isLocked()) {
            MappedByteBuffer b = channel.map(MapMode.READ_WRITE, 0, (long) bufferSize);
            b.clear();
        }
        temp.close();
        buff.clear();
    }

    return null;
}
 
開發者ID:EventHorizon27,項目名稱:dataset-lib,代碼行數:21,代碼來源:StreamThread.java

示例3: call

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
public ByteBuffer call() throws Exception {
    ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
    buff = ByteBuffer.allocate(bufferSize);
    serverSocketChannel.socket().bind(new InetSocketAddress(port));
    RandomAccessFile temp = new RandomAccessFile(tempName, "rw");
    MappedByteBuffer b;
    while (!stop.isLocked()) {
        sync=0;
        SocketChannel socketChannel = serverSocketChannel.accept();
        socketChannel.read(buff);
        FileChannel channel = temp.getChannel();
        channel.write(buff);
        if (!pause.isLocked()) {
            b = channel.map(MapMode.READ_WRITE, 0, (long) bufferSize);
            sync = 1;
            if(sync==2){
            b.clear();
            }
        }
        buff.clear();
    }
    temp.close();
    return null;
}
 
開發者ID:EventHorizon27,項目名稱:dataset-lib,代碼行數:25,代碼來源:StreamThread.java

示例4: map

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
/**
 * Maps the heapPointer and code sections of the boot image in a given file into memory.
 *
 * @param bootImageFile the file containing the heapPointer and code sections to map into memory
 * @return a {@link DataAccess} object that can be used to access the mapped sections
 * @throws IOException if an IO error occurs while performing the memory mapping
 */
private DataAccess map(File bootImageFile, BootImage bootImage) throws IOException {
    final RandomAccessFile randomAccessFile = new RandomAccessFile(bootImageFile, "rwd");
    final Header header = bootImage.header;
    int heapOffset = bootImage.heapOffset();
    int heapAndCodeSize = header.heapSize + header.codeSize;
    final MappedByteBuffer bootImageBuffer = randomAccessFile.getChannel().map(MapMode.PRIVATE, heapOffset, heapAndCodeSize);
    bootImageBuffer.order(platform().endianness().asByteOrder());
    randomAccessFile.close();

    if (heapPointer.isNotZero()) {
        long address = (Long) WithoutAccessCheck.getInstanceField(bootImageBuffer, "address");
        bootImage.relocate(address, heapPointer);
    }
    return new MappedByteBufferDataAccess(bootImageBuffer, heapPointer, header.wordWidth());
}
 
開發者ID:beehive-lab,項目名稱:Maxine-VM,代碼行數:23,代碼來源:ReadOnlyTeleProcess.java

示例5: checkVersion

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
private boolean checkVersion(FileChannel channel) throws IOException
{
    if (channel.size() > 0)
    {
        channel.position(0);
        ByteBuffer buffer;

        if (useNIOMemoryMapping)
        {
            MappedByteBuffer mbb = channel.map(MapMode.READ_ONLY, 0, 8);
            mbb.load();
            buffer = mbb;
        }
        else
        {
            buffer = ByteBuffer.wrap(new byte[8]);
            channel.read(buffer);
            buffer.position(0);
        }

        buffer.position(0);
        long onDiskVersion = buffer.getLong();
        return (version == onDiskVersion);
    }
    return (version == 0);
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:27,代碼來源:IndexInfo.java

示例6: StoreCheckpoint

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
public StoreCheckpoint(final String scpPath) throws IOException {
    File file = new File(scpPath);
    MappedFile.ensureDirOK(file.getParent());
    boolean fileExists = file.exists();

    this.randomAccessFile = new RandomAccessFile(file, "rw");
    this.fileChannel = this.randomAccessFile.getChannel();
    this.mappedByteBuffer = fileChannel.map(MapMode.READ_WRITE, 0, MappedFile.OS_PAGE_SIZE);

    if (fileExists) {
        log.info("store checkpoint file exists, " + scpPath);
        this.physicMsgTimestamp = this.mappedByteBuffer.getLong(0);
        this.logicsMsgTimestamp = this.mappedByteBuffer.getLong(8);
        this.indexMsgTimestamp = this.mappedByteBuffer.getLong(16);

        log.info("store checkpoint file physicMsgTimestamp " + this.physicMsgTimestamp + ", "
            + UtilAll.timeMillisToHumanString(this.physicMsgTimestamp));
        log.info("store checkpoint file logicsMsgTimestamp " + this.logicsMsgTimestamp + ", "
            + UtilAll.timeMillisToHumanString(this.logicsMsgTimestamp));
        log.info("store checkpoint file indexMsgTimestamp " + this.indexMsgTimestamp + ", "
            + UtilAll.timeMillisToHumanString(this.indexMsgTimestamp));
    } else {
        log.info("store checkpoint file not exists, " + scpPath);
    }
}
 
開發者ID:lirenzuo,項目名稱:rocketmq-rocketmq-all-4.1.0-incubating,代碼行數:26,代碼來源:StoreCheckpoint.java

示例7: testMap_readWrite

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
public void testMap_readWrite() throws IOException {
  // Test data
  int size = 1024;
  byte[] expectedBytes = new byte[size];
  byte[] bytes = newPreFilledByteArray(1024);

  // Setup
  File file = createTempFile();
  Files.write(bytes, file);

  Random random = new Random();
  random.nextBytes(expectedBytes);

  // Test
  MappedByteBuffer map = Files.map(file, MapMode.READ_WRITE);
  map.put(expectedBytes);

  // Verify
  byte[] actualBytes = Files.toByteArray(file);
  assertTrue(Arrays.equals(expectedBytes, actualBytes));
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:22,代碼來源:FilesTest.java

示例8: testMap_readWrite_creates

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
public void testMap_readWrite_creates() throws IOException {
  // Test data
  int size = 1024;
  byte[] expectedBytes = newPreFilledByteArray(1024);

  // Setup
  File file = createTempFile();
  boolean deleted = file.delete();
  assertTrue(deleted);
  assertFalse(file.exists());

  // Test
  MappedByteBuffer map = Files.map(file, MapMode.READ_WRITE, size);
  map.put(expectedBytes);

  // Verify
  assertTrue(file.exists());
  assertTrue(file.isFile());
  assertEquals(size, file.length());
  byte[] actualBytes = Files.toByteArray(file);
  assertTrue(Arrays.equals(expectedBytes, actualBytes));
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:23,代碼來源:FilesTest.java

示例9: StoreCheckpoint

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
public StoreCheckpoint(final String scpPath) throws IOException {
    File file = new File(scpPath);
    MapedFile.ensureDirOK(file.getParent());
    boolean fileExists = file.exists();

    this.randomAccessFile = new RandomAccessFile(file, "rw");
    this.fileChannel = this.randomAccessFile.getChannel();
    this.mappedByteBuffer = fileChannel.map(MapMode.READ_WRITE, 0, MapedFile.OS_PAGE_SIZE);

    if (fileExists) {
        log.info("store checkpoint file exists, " + scpPath);
        this.physicMsgTimestamp = this.mappedByteBuffer.getLong(0);
        this.logicsMsgTimestamp = this.mappedByteBuffer.getLong(8);
        this.indexMsgTimestamp = this.mappedByteBuffer.getLong(16);

        log.info("store checkpoint file physicMsgTimestamp " + this.physicMsgTimestamp + ", "
                + UtilAll.timeMillisToHumanString(this.physicMsgTimestamp));
        log.info("store checkpoint file logicsMsgTimestamp " + this.logicsMsgTimestamp + ", "
                + UtilAll.timeMillisToHumanString(this.logicsMsgTimestamp));
        log.info("store checkpoint file indexMsgTimestamp " + this.indexMsgTimestamp + ", "
                + UtilAll.timeMillisToHumanString(this.indexMsgTimestamp));
    }
    else {
        log.info("store checkpoint file not exists, " + scpPath);
    }
}
 
開發者ID:y123456yz,項目名稱:reading-and-annotate-rocketmq-3.4.6,代碼行數:27,代碼來源:StoreCheckpoint.java

示例10: insertTagAndShift

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
/**
 * Insert new metadata into file by using memory mapped file, and if fails write in chunks
 * <p>
 * But this is problematic on 32bit systems for large flac files may not be able to map a contiguous address space large enough
 * for a large audio size , so no longer used since better to go straight to using chunks
 *
 * @param tag
 * @param fc
 * @param blockInfo
 * @param flacStream
 * @param neededRoom
 * @param availableRoom
 * @throws IOException
 * @throws UnsupportedEncodingException
 */
private void insertTagAndShift(File file, Tag tag, FileChannel fc, MetadataBlockInfo blockInfo, FlacStreamReader flacStream, int neededRoom, int availableRoom) throws IOException, UnsupportedEncodingException {
    int headerLength = flacStream.getStartOfFlacInFile() + FlacStreamReader.FLAC_STREAM_IDENTIFIER_LENGTH + MetadataBlockHeader.HEADER_LENGTH // this should be the length of the block header for the stream info
            + MetadataBlockDataStreamInfo.STREAM_INFO_DATA_LENGTH;
    long targetSizeBeforeAudioData = headerLength + neededRoom + FlacTagCreator.DEFAULT_PADDING;
    long remainderTargetSize = fc.size() - (headerLength + availableRoom);
    long totalTargetSize = targetSizeBeforeAudioData + remainderTargetSize;

    MappedByteBuffer mappedFile = null;
    try {
        //Use ByteBuffer
        mappedFile = fc.map(MapMode.READ_WRITE, 0, totalTargetSize);
        insertTagAndShiftViaMappedByteBuffer(tag, mappedFile, fc, targetSizeBeforeAudioData, totalTargetSize, blockInfo, flacStream, neededRoom, availableRoom);
    } catch (IOException ioe) {
        //#175: Flac Map error on write
        if (mappedFile == null) {
            insertUsingChunks(file, tag, fc, blockInfo, flacStream, neededRoom + FlacTagCreator.DEFAULT_PADDING, availableRoom);
        } else {
            logger.log(Level.SEVERE, ioe.getMessage(), ioe);
            throw ioe;
        }
    }
}
 
開發者ID:GlennioTech,項目名稱:MetadataEditor,代碼行數:38,代碼來源:FlacTagWriter.java

示例11: load

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
/**
 * Load the block.
 *
 * mmap and mlock the block, and then verify its checksum.
 *
 * @param length         The current length of the block.
 * @param blockIn        The block input stream.  Should be positioned at the
 *                       start.  The caller must close this.
 * @param metaIn         The meta file input stream.  Should be positioned at
 *                       the start.  The caller must close this.
 * @param blockFileName  The block file name, for logging purposes.
 *
 * @return               The Mappable block.
 */
public static MappableBlock load(long length,
    FileInputStream blockIn, FileInputStream metaIn,
    String blockFileName) throws IOException {
  MappableBlock mappableBlock = null;
  MappedByteBuffer mmap = null;
  FileChannel blockChannel = null;
  try {
    blockChannel = blockIn.getChannel();
    if (blockChannel == null) {
      throw new IOException("Block InputStream has no FileChannel.");
    }
    mmap = blockChannel.map(MapMode.READ_ONLY, 0, length);
    NativeIO.POSIX.getCacheManipulator().mlock(blockFileName, mmap, length);
    verifyChecksum(length, metaIn, blockChannel, blockFileName);
    mappableBlock = new MappableBlock(mmap, length);
  } finally {
    IOUtils.closeQuietly(blockChannel);
    if (mappableBlock == null) {
      if (mmap != null) {
        NativeIO.POSIX.munmap(mmap); // unmapping also unlocks
      }
    }
  }
  return mappableBlock;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:40,代碼來源:MappableBlock.java

示例12: testWrite

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
/**
 * Maps blah file with a random offset and checks to see if data
 * written out to the file can be read back in
 */
private static void 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 i=0; i<4; i++) {
                b.put(i, (byte)('0' + i));
            }

            for (int i=0; i<4; i++) {
                byte aByte = b.get(i);
                sb.setCharAt(i, (char)aByte);
            }
            if (!sb.toString().equals("0123"))
                throw new Exception("Write test failed");
        }
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:30,代碼來源:MapTest.java

示例13: loadInformation

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
/**
 * load bio information;egg : chromosome or dbsnp
 */
protected void loadInformation(String path) throws IOException {
	RandomAccessFile raf = new RandomAccessFile(path, "r");
	FileChannel fc = raf.getChannel();
	fcSize = (int) (fc.size() & 0xffffffff);
	int blocks = (int) ((fcSize / Integer.MAX_VALUE) + 1);
	byteBuffer = new MappedByteBuffer[blocks];
	int start = 0;
	long remain = 0;
	int size = 0;
	for (int i = 0; i < blocks; i++) {
		start = Integer.MAX_VALUE * i;
		remain = (long) (fc.size() - start);
		size = (int) ((remain > Integer.MAX_VALUE) ? Integer.MAX_VALUE : remain);
		MappedByteBuffer mapedBB = fc.map(MapMode.READ_ONLY, start, size);
		byteBuffer[i] = mapedBB;
	}
	raf.close();
}
 
開發者ID:BGI-flexlab,項目名稱:SOAPgaea,代碼行數:22,代碼來源:BioMemoryShare.java

示例14: allocate

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
/**
 * on posix systems: allocates disk-backed bytebuffer and immediately unlinks the file
 * on others: simply returns a direct bytebuffer
 */
public static ByteBuffer allocate(int size) {
	if(MAP_AND_UNLINK_SUPPORTED) {
		try {
			Path p = Files.createTempFile("anon-mapping", ".tmp");
			ByteBuffer mapped;
			FileChannel chan = FileChannel.open(p, StandardOpenOption.READ, StandardOpenOption.WRITE);
			chan.position(size);
			chan.write(ByteBuffer.allocate(1));
			mapped = chan.map(MapMode.READ_WRITE, 0, size);
			chan.close();
			Files.delete(p);
			return mapped;
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	
	return ByteBuffer.allocateDirect(size);
}
 
開發者ID:atomashpolskiy,項目名稱:bt,代碼行數:24,代碼來源:AnonAllocator.java

示例15: BootFile

import java.nio.channels.FileChannel.MapMode; //導入依賴的package包/類
BootFile(Path bootPath)
  throws IOException
{
  Objects.requireNonNull(bootPath);
  
  _bootPath = bootPath;
  long bootSize = Files.size(bootPath);
  
  if (bootSize <= 0) {
    throw new IllegalStateException("Unexpected boot size for " + bootPath);
  }
  
  if (bootSize >= Integer.MAX_VALUE - 1) {
    throw new IllegalStateException("Mmapped file is too large for " + bootPath + " " + _bootSize);
  }
  
  _bootSize = (int) bootSize;
  
  _bootChannel = (FileChannel) Files.newByteChannel(_bootPath, StandardOpenOption.READ);
  
  _bootMap = _bootChannel.map(MapMode.READ_ONLY, 0, _bootSize);
  
  readJar();
  
  readManifest();
}
 
開發者ID:baratine,項目名稱:baratine,代碼行數:27,代碼來源:BootFile.java


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