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


Java DataInputStream.skip方法代碼示例

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


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

示例1: deserializeFirstLastKey

import java.io.DataInputStream; //導入方法依賴的package包/類
/**
 * Deserializes the first and last key stored in the summary
 *
 * Only for use by offline tools like SSTableMetadataViewer, otherwise SSTable.first/last should be used.
 */
public Pair<DecoratedKey, DecoratedKey> deserializeFirstLastKey(DataInputStream in, IPartitioner partitioner, boolean haveSamplingLevel) throws IOException
{
    in.skipBytes(4); // minIndexInterval
    int offsetCount = in.readInt();
    long offheapSize = in.readLong();
    if (haveSamplingLevel)
        in.skipBytes(8); // samplingLevel, fullSamplingSummarySize

    in.skip(offsetCount * 4);
    in.skip(offheapSize - offsetCount * 4);

    DecoratedKey first = partitioner.decorateKey(ByteBufferUtil.readWithLength(in));
    DecoratedKey last = partitioner.decorateKey(ByteBufferUtil.readWithLength(in));
    return Pair.create(first, last);
}
 
開發者ID:Netflix,項目名稱:sstable-adaptor,代碼行數:21,代碼來源:IndexSummary.java

示例2: loadCodeAttributes

import java.io.DataInputStream; //導入方法依賴的package包/類
private void loadCodeAttributes(DataInputStream in, ConstantPool pool) 
    throws IOException {
      int count = in.readUnsignedShort();
      for (int i = 0; i < count; i++) {
          Object o = pool.get(in.readUnsignedShort());
          if (!(o instanceof CPUTF8Info))
              throw new InvalidClassFormatException();
          CPUTF8Info entry = (CPUTF8Info)o;
          int len = in.readInt();
          String name = entry.getName();
          if (name.equals("LineNumberTable")) //NOI18N
              loadLineNumberTable(in, pool);
          else if (name.equals("LocalVariableTable")) //NOI18N
              localVariableTable = 
                  LocalVariableTableEntry.loadLocalVariableTable(in, pool);
          else if (name.equals("LocalVariableTypeTable")) //NOI18N
              localVariableTypeTable = 
                  LocalVariableTypeTableEntry.loadLocalVariableTypeTable(in, pool);
          else if (name.equals("StackMapTable")) //NOI18N
              stackMapTable = StackMapFrame.loadStackMapTable(in, pool);
          else {
if (debug)
    System.out.println("skipped unknown code attribute: " + name);
              // ignore unknown attribute...
              int n;
while ((n = (int)in.skip(len)) > 0 && n < len)
    len -= n;
          }
      }
      if (lineNumberTable == null)
          lineNumberTable = new int[0];
      if (localVariableTable == null)
          localVariableTable = new LocalVariableTableEntry[0];
      if (localVariableTypeTable == null)
          localVariableTypeTable = new LocalVariableTypeTableEntry[0];
      if (stackMapTable == null)
          stackMapTable = new StackMapFrame[0];
  }
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:39,代碼來源:Code.java

示例3: decodeAvp

import java.io.DataInputStream; //導入方法依賴的package包/類
private Avp decodeAvp(byte[] in_b ) throws IOException, AvpDataException {
    DataInputStream in = new DataInputStream(new ByteArrayInputStream(in_b));
    int code = in.readInt();
    int tmp = in.readInt();
    int counter = 0;
    
    int flags = (tmp >> 24) & 0xFF;
    int length = tmp & 0xFFFFFF;
    if (length < 0 || counter + length > in_b.length) {
        throw new AvpDataException("Not enough data in buffer!");
    }
    long vendor = 0;
    boolean hasVendor = false;
    if ((flags & 0x80) != 0) {
        vendor = in.readInt();
        hasVendor = true;
    }
    // Determine body L = length - 4(code) -1(flags) -3(length) [-4(vendor)]
    byte[] rawData = new byte[length - (8 + (hasVendor ? 4 : 0))];
    in.read(rawData);
    // skip remaining.
    // TODO: Do we need to padd everything? Or on send stack should properly fill byte[] ... ?
    if (length % 4 != 0) {
        for (int i; length % 4 != 0; length += i) {
            i = (int) in.skip((4 - length % 4));
        }
    }
    AvpImpl avp = new AvpImpl(code, (short) flags, (int) vendor, rawData);
    return avp;
}
 
開發者ID:P1sec,項目名稱:SigFW,代碼行數:31,代碼來源:DiameterFirewall.java

示例4: readBytes

import java.io.DataInputStream; //導入方法依賴的package包/類
@Override
public void readBytes(DataInputStream dataInputStream, int size)
{
    try
    {
        dataInputStream.skip(size);
    }
    catch (IOException e)
    {
        throw new RuntimeException(e);
    }
}
 
開發者ID:goldmansachs,項目名稱:jrpip,代碼行數:13,代碼來源:NullStreamProcessor.java

示例5: retrieve

import java.io.DataInputStream; //導入方法依賴的package包/類
@Override
public DataInputStream retrieve(String key, long startByteOffset)
    throws AzureException, IOException {
    try {
      // Check if a session exists, if not create a session with the
      // Azure storage server.
      if (null == storageInteractionLayer) {
        final String errMsg = String.format(
            "Storage session expected for URI '%s' but does not exist.",
            sessionUri);
        throw new AssertionError(errMsg);
      }
      checkContainer(ContainerAccessType.PureRead);

      // Get blob reference and open the input buffer stream.
      CloudBlobWrapper blob = getBlobReference(key);

      // Open input stream and seek to the start offset.
      InputStream in = blob.openInputStream(
        getDownloadOptions(), getInstrumentedContext(isConcurrentOOBAppendAllowed()));

      // Create a data input stream.
   DataInputStream inDataStream = new DataInputStream(in);
   
   // Skip bytes and ignore return value. This is okay
   // because if you try to skip too far you will be positioned
   // at the end and reads will not return data.
   inDataStream.skip(startByteOffset);
      return inDataStream;
  } catch (Exception e) {
    // Re-throw as an Azure storage exception.
    throw new AzureException(e);
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:35,代碼來源:AzureNativeFileSystemStore.java

示例6: skipFully

import java.io.DataInputStream; //導入方法依賴的package包/類
static void skipFully(DataInputStream stream, int n) throws IOException {
    long skipped = 0;
    do {
        long s = stream.skip(n - skipped);
        skipped += s;
        if (s == 0 && skipped != n) {
            // Check for EOF (i.e., truncated class file)
            if (stream.read() == -1) {
                throw new IOException("truncated stream");
            }
            skipped++;
        }
    } while (skipped != n);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:15,代碼來源:Classfile.java

示例7: GFSnapshotImporter

import java.io.DataInputStream; //導入方法依賴的package包/類
public GFSnapshotImporter(File in) throws IOException, ClassNotFoundException {
  pdx = new ExportedRegistry();

  // read header and pdx registry
  long entryPosition;

  FileInputStream fis = new FileInputStream(in);
  FileChannel fc = fis.getChannel();
  DataInputStream tmp = new DataInputStream(fis);
  try {
    // read the snapshot file header
    version = tmp.readByte();
    if (version == SNAP_VER_1) {
      throw new IOException(
          LocalizedStrings.Snapshot_UNSUPPORTED_SNAPSHOT_VERSION_0.toLocalizedString(SNAP_VER_1)
              + ": " + in);

    } else if (version == SNAP_VER_2) {
      // read format
      byte[] format = new byte[3];
      tmp.readFully(format);
      if (!Arrays.equals(format, SNAP_FMT)) {
        throw new IOException(LocalizedStrings.Snapshot_UNRECOGNIZED_FILE_TYPE_0
            .toLocalizedString(Arrays.toString(format)) + ": " + in);
      }

      // read pdx location
      long registryPosition = tmp.readLong();

      // read region
      region = tmp.readUTF();
      entryPosition = fc.position();

      // read pdx
      if (registryPosition != -1) {
        fc.position(registryPosition);
        pdx.fromData(tmp);
      }
    } else {
      throw new IOException(
          LocalizedStrings.Snapshot_UNRECOGNIZED_FILE_VERSION_0.toLocalizedString(version)
              + ": " + in);
    }
  } finally {
    tmp.close();
  }

  // check compatibility with the existing pdx types so we don't have to
  // do any translation...preexisting types or concurrent put ops may cause
  // this check to fail
  checkPdxTypeCompatibility();
  checkPdxEnumCompatibility();

  // open new stream with buffering for reading entries
  dis = new DataInputStream(new BufferedInputStream(new FileInputStream(in)));
  dis.skip(entryPosition);
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:58,代碼來源:GFSnapshot.java

示例8: deserializeFromPB

import java.io.DataInputStream; //導入方法依賴的package包/類
/**
 * Deserialize the file trailer as protobuf
 * @param inputStream
 * @throws IOException
 */
void deserializeFromPB(DataInputStream inputStream) throws IOException {
  // read PB and skip padding
  int start = inputStream.available();
  HFileProtos.FileTrailerProto trailerProto =
      HFileProtos.FileTrailerProto.PARSER.parseDelimitedFrom(inputStream);
  int size = start - inputStream.available();
  inputStream.skip(getTrailerSize() - NOT_PB_SIZE - size);

  // process the PB
  if (trailerProto.hasFileInfoOffset()) {
    fileInfoOffset = trailerProto.getFileInfoOffset();
  }
  if (trailerProto.hasLoadOnOpenDataOffset()) {
    loadOnOpenDataOffset = trailerProto.getLoadOnOpenDataOffset();
  }
  if (trailerProto.hasUncompressedDataIndexSize()) {
    uncompressedDataIndexSize = trailerProto.getUncompressedDataIndexSize();
  }
  if (trailerProto.hasTotalUncompressedBytes()) {
    totalUncompressedBytes = trailerProto.getTotalUncompressedBytes();
  }
  if (trailerProto.hasDataIndexCount()) {
    dataIndexCount = trailerProto.getDataIndexCount();
  }
  if (trailerProto.hasMetaIndexCount()) {
    metaIndexCount = trailerProto.getMetaIndexCount();
  }
  if (trailerProto.hasEntryCount()) {
    entryCount = trailerProto.getEntryCount();
  }
  if (trailerProto.hasNumDataIndexLevels()) {
    numDataIndexLevels = trailerProto.getNumDataIndexLevels();
  }
  if (trailerProto.hasFirstDataBlockOffset()) {
    firstDataBlockOffset = trailerProto.getFirstDataBlockOffset();
  }
  if (trailerProto.hasLastDataBlockOffset()) {
    lastDataBlockOffset = trailerProto.getLastDataBlockOffset();
  }
  if (trailerProto.hasComparatorClassName()) {
    // TODO this is a classname encoded into an  HFile's trailer. We are going to need to have 
    // some compat code here.
    setComparatorClass(getComparatorClass(trailerProto.getComparatorClassName()));
  }
  if (trailerProto.hasCompressionCodec()) {
    compressionCodec = Compression.Algorithm.values()[trailerProto.getCompressionCodec()];
  } else {
    compressionCodec = Compression.Algorithm.NONE;
  }
  if (trailerProto.hasEncryptionKey()) {
    encryptionKey = trailerProto.getEncryptionKey().toByteArray();
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:59,代碼來源:FixedFileTrailer.java

示例9: computeHash

import java.io.DataInputStream; //導入方法依賴的package包/類
public static String computeHash(InputStream stream, long length) throws IOException {

        int chunkSizeForFile = (int) Math.min(HASH_CHUNK_SIZE, length);

        // buffer that will contain the head and the tail chunk, chunks will overlap if length is smaller than two chunks
        byte[] chunkBytes = new byte[(int) Math.min(2 * HASH_CHUNK_SIZE, length)];

        DataInputStream in = new DataInputStream(stream);

        // first chunk
        in.readFully(chunkBytes, 0, chunkSizeForFile);

        long position = chunkSizeForFile;
        long tailChunkPosition = length - chunkSizeForFile;

        // seek to position of the tail chunk, or not at all if length is smaller than two chunks
        while (position < tailChunkPosition && (position += in.skip(tailChunkPosition - position)) >= 0) {
        }

        // second chunk, or the rest of the data if length is smaller than two chunks
        in.readFully(chunkBytes, chunkSizeForFile, chunkBytes.length - chunkSizeForFile);

        long head = computeHashForChunk(ByteBuffer.wrap(chunkBytes, 0, chunkSizeForFile));
        long tail = computeHashForChunk(ByteBuffer.wrap(chunkBytes, chunkBytes.length - chunkSizeForFile, chunkSizeForFile));

        return String.format("%016x", length + head + tail);
    }
 
開發者ID:atulgpt,項目名稱:SubtitleDownloader,代碼行數:28,代碼來源:OpenSubtitlesHasher.java


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