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


Java FileInputStream.skip方法代碼示例

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


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

示例1: WriteFile

import java.io.FileInputStream; //導入方法依賴的package包/類
public void WriteFile(File outputFile, int startFrame, int numFrames)
        throws java.io.IOException {
    outputFile.createNewFile();
    FileInputStream in = new FileInputStream(mInputFile);
    FileOutputStream out = new FileOutputStream(outputFile);
    int maxFrameLen = 0;
    for (int i = 0; i < numFrames; i++) {
        if (mFrameLens[startFrame + i] > maxFrameLen)
            maxFrameLen = mFrameLens[startFrame + i];
    }
    byte[] buffer = new byte[maxFrameLen];
    int pos = 0;
    for (int i = 0; i < numFrames; i++) {
        int skip = mFrameOffsets[startFrame + i] - pos;
        int len = mFrameLens[startFrame + i];
        if (skip > 0) {
            in.skip(skip);
            pos += skip;
        }
        in.read(buffer, 0, len);
        out.write(buffer, 0, len);
        pos += len;
    }
    in.close();
    out.close();
}
 
開發者ID:smartbeng,項目名稱:PaoMovie,代碼行數:27,代碼來源:CheapMP3.java

示例2: skipBytes

import java.io.FileInputStream; //導入方法依賴的package包/類
/**
 *  Skip toSkip number of bytes and return the remaining bytes of the file.
 */
private static long skipBytes(FileInputStream fis, int toSkip, long space)
        throws IOException {
    long skip = fis.skip(toSkip);
    if (skip != toSkip) {
        throw new RuntimeException("skip() returns " + skip
                                   + " but expected " + toSkip);
    }
    long newSpace = space - toSkip;
    long remaining = newSpace > 0 ? newSpace : 0;
    int avail = fis.available();
    if (avail != remaining) {
        throw new RuntimeException("available() returns " + avail
                                   + " but expected " + remaining);
    }

    System.out.println("Skipped " + skip + " bytes "
                       + " available() returns " + avail);
    return newSpace;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:23,代碼來源:NegativeAvailable.java

示例3: read

import java.io.FileInputStream; //導入方法依賴的package包/類
private static byte[] read(String inputFileName, int start, int end)
    throws FileNotFoundException, IOException {
  File theFile = new File(inputFileName);
  FileInputStream input = new FileInputStream(theFile);
  int skipped = 0;
  while (skipped < start) {
    skipped += input.skip(start - skipped);
  }
  int length = (int) (Math.min(end, theFile.length()) - start);
  byte[] bytes = new byte[length];
  int bytesRead = 0;
  while (bytesRead < bytes.length) {
    bytesRead = input.read(bytes, bytesRead, bytes.length - bytesRead);
    if (bytesRead == -1) {
      break;
    }
  }
  return bytes;
}
 
開發者ID:nccgroup,項目名稱:Decoder-Improved,代碼行數:20,代碼來源:HexDump.java

示例4: InputStreamAdapter

import java.io.FileInputStream; //導入方法依賴的package包/類
InputStreamAdapter(final File file, final long pos,
                   final long length)
                   throws FileNotFoundException, IOException {

    if (file == null) {
        throw new NullPointerException("file");
    }

    if (pos < 0) {
        throw new IllegalArgumentException("pos: " + pos);
    }

    if (length < 0) {
        throw new IllegalArgumentException("length: " + length);
    }

    final FileInputStream fis = new FileInputStream(file);

    if (pos > 0) {
        final long actualPos = fis.skip(pos);
    }

    final BufferedInputStream  bis = new BufferedInputStream(fis);
    final CountdownInputStream cis = new CountdownInputStream(bis);

    cis.setCount(length);

    m_countdownInputStream = cis;
}
 
開發者ID:tiweGH,項目名稱:OpenDiabetes,代碼行數:30,代碼來源:JDBCBlobFile.java

示例5: open

import java.io.FileInputStream; //導入方法依賴的package包/類
@Override
public long open(DataSpec dataSpec) throws ContentDataSourceException {
  try {
    uriString = dataSpec.uri.toString();
    AssetFileDescriptor assetFd = resolver.openAssetFileDescriptor(dataSpec.uri, "r");
    inputStream = new FileInputStream(assetFd.getFileDescriptor());
    long skipped = inputStream.skip(dataSpec.position);
    if (skipped < dataSpec.position) {
      // We expect the skip to be satisfied in full. If it isn't then we're probably trying to
      // skip beyond the end of the data.
      throw new EOFException();
    }
    if (dataSpec.length != C.LENGTH_UNBOUNDED) {
      bytesRemaining = dataSpec.length;
    } else {
      bytesRemaining = inputStream.available();
      if (bytesRemaining == 0) {
        // FileInputStream.available() returns 0 if the remaining length cannot be determined, or
        // if it's greater than Integer.MAX_VALUE. We don't know the true length in either case,
        // so treat as unbounded.
        bytesRemaining = C.LENGTH_UNBOUNDED;
      }
    }
  } catch (IOException e) {
    throw new ContentDataSourceException(e);
  }

  opened = true;
  if (listener != null) {
    listener.onTransferStart();
  }

  return bytesRemaining;
}
 
開發者ID:MLNO,項目名稱:airgram,代碼行數:35,代碼來源:ContentDataSource.java

示例6: WriteFile

import java.io.FileInputStream; //導入方法依賴的package包/類
public void WriteFile(File outputFile, int startFrame, int numFrames)
        throws java.io.IOException {
    outputFile.createNewFile();
    FileInputStream in = new FileInputStream(mInputFile);
    FileOutputStream out = new FileOutputStream(outputFile);

    byte[] header = new byte[6];
    header[0] = '#';
    header[1] = '!';
    header[2] = 'A';
    header[3] = 'M';
    header[4] = 'R';
    header[5] = '\n';
    out.write(header, 0, 6);

    int maxFrameLen = 0;
    for (int i = 0; i < numFrames; i++) {
        if (mFrameLens[startFrame + i] > maxFrameLen)
            maxFrameLen = mFrameLens[startFrame + i];
    }
    byte[] buffer = new byte[maxFrameLen];
    int pos = 0;
    for (int i = 0; i < numFrames; i++) {
        int skip = mFrameOffsets[startFrame + i] - pos;
        int len = mFrameLens[startFrame + i];
        if (skip < 0) {
            continue;
        }
        if (skip > 0) {
            in.skip(skip);
            pos += skip;
        }
        in.read(buffer, 0, len);
        out.write(buffer, 0, len);
        pos += len;
    }

    in.close();
    out.close();
}
 
開發者ID:smartbeng,項目名稱:PaoMovie,代碼行數:41,代碼來源:CheapAMR.java

示例7: computeMd5OfFirst10Frames

import java.io.FileInputStream; //導入方法依賴的package包/類
public String computeMd5OfFirst10Frames()
        throws java.io.FileNotFoundException,
               java.io.IOException,
               java.security.NoSuchAlgorithmException {
    int[] frameOffsets = getFrameOffsets();
    int[] frameLens = getFrameLens();
    int numFrames = frameLens.length;
    if (numFrames > 10) {
        numFrames = 10;
    }

    MessageDigest digest = java.security.MessageDigest.getInstance("MD5");
    FileInputStream in = new FileInputStream(mInputFile);
    int pos = 0;
    for (int i = 0; i < numFrames; i++) {
        int skip = frameOffsets[i] - pos;
        int len = frameLens[i];
        if (skip > 0) {
            in.skip(skip);
            pos += skip;
        }
        byte[] buffer = new byte[len];
        in.read(buffer, 0, len);
        digest.update(buffer);
        pos += len;
    }
    in.close();
    byte[] hash = digest.digest();
    return bytesToHex(hash);
}
 
開發者ID:smartbeng,項目名稱:PaoMovie,代碼行數:31,代碼來源:CheapSoundFile.java

示例8: verifyMac

import java.io.FileInputStream; //導入方法依賴的package包/類
private static void verifyMac(MasterSecret masterSecret, File file) throws IOException {
  Mac             mac        = initializeMac(masterSecret.getMacKey());
  FileInputStream macStream  = new FileInputStream(file);
  InputStream     dataStream = new LimitedInputStream(new FileInputStream(file), file.length() - MAC_LENGTH);
  byte[]          theirMac   = new byte[MAC_LENGTH];

  if (macStream.skip(file.length() - MAC_LENGTH) != file.length() - MAC_LENGTH) {
    throw new IOException("Unable to seek");
  }

  readFully(macStream, theirMac);

  byte[] buffer = new byte[4096];
  int    read;

  while ((read = dataStream.read(buffer)) != -1) {
    mac.update(buffer, 0, read);
  }

  byte[] ourMac = mac.doFinal();

  if (!MessageDigest.isEqual(ourMac, theirMac)) {
    throw new IOException("Bad MAC");
  }

  macStream.close();
  dataStream.close();
}
 
開發者ID:CableIM,項目名稱:Cable-Android,代碼行數:29,代碼來源:DecryptingPartInputStream.java

示例9: open

import java.io.FileInputStream; //導入方法依賴的package包/類
@Override
public long open(DataSpec dataSpec) throws ContentDataSourceException {
  try {
    uri = dataSpec.uri;
    assetFileDescriptor = resolver.openAssetFileDescriptor(uri, "r");
    inputStream = new FileInputStream(assetFileDescriptor.getFileDescriptor());
    long skipped = inputStream.skip(dataSpec.position);
    if (skipped < dataSpec.position) {
      // We expect the skip to be satisfied in full. If it isn't then we're probably trying to
      // skip beyond the end of the data.
      throw new EOFException();
    }
    if (dataSpec.length != C.LENGTH_UNSET) {
      bytesRemaining = dataSpec.length;
    } else {
      bytesRemaining = inputStream.available();
      if (bytesRemaining == 0) {
        // FileInputStream.available() returns 0 if the remaining length cannot be determined, or
        // if it's greater than Integer.MAX_VALUE. We don't know the true length in either case,
        // so treat as unbounded.
        bytesRemaining = C.LENGTH_UNSET;
      }
    }
  } catch (IOException e) {
    throw new ContentDataSourceException(e);
  }

  opened = true;
  if (listener != null) {
    listener.onTransferStart(this, dataSpec);
  }

  return bytesRemaining;
}
 
開發者ID:sanjaysingh1990,項目名稱:Exoplayer2Radio,代碼行數:35,代碼來源:ContentDataSource.java

示例10: serveFile

import java.io.FileInputStream; //導入方法依賴的package包/類
/**
 * Serves file from homeDir and its' subdirectories (only). Uses only URI,
 * ignores all headers and HTTP parameters.
 */
private Response serveFile(Map<String, String> header, File file, String mime) {
    Response res;
    try {
        // Calculate etag
        String etag = Integer
                .toHexString((file.getAbsolutePath() + file.lastModified() + String.valueOf(file.length()))
                        .hashCode());

        // Support (simple) skipping:
        long startFrom = 0;
        long endAt = -1;
        String range = header.get("range");
        if (range != null && range.startsWith("bytes=")) {
            range = range.substring("bytes=".length());
            int minus = range.indexOf('-');
            try {
                if (minus > 0) {
                    startFrom = Long.parseLong(range.substring(0, minus));
                    endAt = Long.parseLong(range.substring(minus + 1));
                }
            } catch (NumberFormatException ignored) {
            }
        }

        // Change return code and add Content-Range header when skipping is
        // requested
        long fileLen = file.length();
        if (range != null && startFrom >= 0) {
            if (startFrom >= fileLen) {
                res = createResponse(Response.Status.RANGE_NOT_SATISFIABLE,
                        NanoHTTPD.MIME_PLAINTEXT, "");
                res.addHeader("Content-Range", "bytes 0-0/" + fileLen);
                res.addHeader("ETag", etag);
            } else {
                if (endAt < 0) {
                    endAt = fileLen - 1;
                }
                long newLen = endAt - startFrom + 1;
                if (newLen < 0) {
                    newLen = 0;
                }

                final long dataLen = newLen;
                FileInputStream fis = new FileInputStream(file) {
                    @Override
                    public int available() throws IOException {
                        return (int) dataLen;
                    }
                };
                long skipped = fis.skip(startFrom);
                if (skipped != startFrom) {
                    throw new IOException("unable to skip the required " + startFrom + " bytes.");
                }

                res = createResponse(Response.Status.PARTIAL_CONTENT, mime, fis);
                res.addHeader("Content-Length", String.valueOf(dataLen));
                res.addHeader("Content-Range", "bytes " + startFrom + "-" + endAt + "/"
                        + fileLen);
                res.addHeader("ETag", etag);
            }
        } else {
            if (etag.equals(header.get("if-none-match"))) {
                res = createResponse(Response.Status.NOT_MODIFIED, mime, "");
            } else {
                res = createResponse(Response.Status.OK, mime, new FileInputStream(file));
                res.addHeader("Content-Length", String.valueOf(fileLen));
                res.addHeader("ETag", etag);
            }
        }
    } catch (IOException ioe) {
        res = createResponse(Response.Status.FORBIDDEN, NanoHTTPD.MIME_PLAINTEXT,
                "FORBIDDEN: Reading file failed.");
    }

    return res;
}
 
開發者ID:uhuru-mobile,項目名稱:mobile-store,代碼行數:81,代碼來源:LocalHTTPD.java

示例11: serveFile

import java.io.FileInputStream; //導入方法依賴的package包/類
/**
 * Serves file from homeDir and its' subdirectories (only). Uses only URI,
 * ignores all headers and HTTP parameters.
 */
Response serveFile(String uri, Map<String, String> header, File file, String mime) {
    Response res;
    try {
        // Calculate etag
        String etag = Integer
                .toHexString((file.getAbsolutePath() + file.lastModified() + String.valueOf(file.length()))
                        .hashCode());

        // Support (simple) skipping:
        long startFrom = 0;
        long endAt = -1;
        String range = header.get("range");
        if (range != null && range.startsWith("bytes=")) {
            range = range.substring("bytes=".length());
            int minus = range.indexOf('-');
            try {
                if (minus > 0) {
                    startFrom = Long.parseLong(range.substring(0, minus));
                    endAt = Long.parseLong(range.substring(minus + 1));
                }
            } catch (NumberFormatException ignored) {
            }
        }

        // Change return code and add Content-Range header when skipping is
        // requested
        long fileLen = file.length();
        if (range != null && startFrom >= 0) {
            if (startFrom >= fileLen) {
                res = createResponse(NanoHTTPD.Response.Status.RANGE_NOT_SATISFIABLE,
                        NanoHTTPD.MIME_PLAINTEXT, "");
                res.addHeader("Content-Range", "bytes 0-0/" + fileLen);
                res.addHeader("ETag", etag);
            } else {
                if (endAt < 0) {
                    endAt = fileLen - 1;
                }
                long newLen = endAt - startFrom + 1;
                if (newLen < 0) {
                    newLen = 0;
                }

                final long dataLen = newLen;
                FileInputStream fis = new FileInputStream(file) {
                    @Override
                    public int available() throws IOException {
                        return (int) dataLen;
                    }
                };
                long skipped = fis.skip(startFrom);
                if (skipped != startFrom) {
                    throw new IOException("unable to skip the required " + startFrom + " bytes.");
                }

                res = createResponse(NanoHTTPD.Response.Status.PARTIAL_CONTENT, mime, fis);
                res.addHeader("Content-Length", String.valueOf(dataLen));
                res.addHeader("Content-Range", "bytes " + startFrom + "-" + endAt + "/"
                        + fileLen);
                res.addHeader("ETag", etag);
            }
        } else {
            if (etag.equals(header.get("if-none-match"))) {
                res = createResponse(NanoHTTPD.Response.Status.NOT_MODIFIED, mime, "");
            } else {
                res = createResponse(NanoHTTPD.Response.Status.OK, mime, new FileInputStream(file));
                res.addHeader("Content-Length", String.valueOf(fileLen));
                res.addHeader("ETag", etag);
            }
        }
    } catch (IOException ioe) {
        res = createResponse(NanoHTTPD.Response.Status.FORBIDDEN, NanoHTTPD.MIME_PLAINTEXT,
                "FORBIDDEN: Reading file failed.");
    }

    return res;
}
 
開發者ID:uhuru-mobile,項目名稱:mobile-store,代碼行數:81,代碼來源:BluetoothServer.java

示例12: ReadFile

import java.io.FileInputStream; //導入方法依賴的package包/類
public void ReadFile(File inputFile)
        throws java.io.FileNotFoundException,
        java.io.IOException {
    super.ReadFile(inputFile);
    mNumFrames = 0;
    mMaxFrames = 64;  // This will grow as needed
    mFrameOffsets = new int[mMaxFrames];
    mFrameLens = new int[mMaxFrames];
    mFrameGains = new int[mMaxFrames];
    mMinGain = 1000000000;
    mMaxGain = 0;
    mBitRate = 10;
    mOffset = 0;

    // No need to handle filesizes larger than can fit in a 32-bit int
    mFileSize = (int)mInputFile.length();

    if (mFileSize < 128) {
        throw new java.io.IOException("File too small to parse");
    }

    FileInputStream stream = new FileInputStream(mInputFile);
    byte[] header = new byte[12];
    stream.read(header, 0, 6);
    mOffset += 6;
    if (header[0] == '#' &&
        header[1] == '!' &&
        header[2] == 'A' &&
        header[3] == 'M' &&
        header[4] == 'R' &&
        header[5] == '\n') {
        parseAMR(stream, mFileSize - 6);
    }

    stream.read(header, 6, 6);
    mOffset += 6;

    if (header[4] == 'f' &&
        header[5] == 't' &&
        header[6] == 'y' &&
        header[7] == 'p' &&
        header[8] == '3' &&
        header[9] == 'g' &&
        header[10] == 'p' &&
        header[11] == '4') {

        int boxLen =
            ((0xff & header[0]) << 24) |
            ((0xff & header[1]) << 16) |
            ((0xff & header[2]) << 8) |
            ((0xff & header[3]));

        if (boxLen >= 4 && boxLen <= mFileSize - 8) {
            stream.skip(boxLen - 12);
            mOffset += boxLen - 12;
        }

        parse3gpp(stream, mFileSize - boxLen);
    }
}
 
開發者ID:smartbeng,項目名稱:PaoMovie,代碼行數:61,代碼來源:CheapAMR.java

示例13: testPrototypeInflaterGzip

import java.io.FileInputStream; //導入方法依賴的package包/類
/**
 * Test using the raw Inflater codec for reading gzip files.
 */
@Test
public void testPrototypeInflaterGzip() throws IOException {
  CompressionCodec gzip = new GzipCodec();  // used only for file extension
  localFs.delete(workDir, true);            // localFs = FileSystem instance

  System.out.println(COLOR_BR_BLUE + "testPrototypeInflaterGzip() using " +
    "non-native/Java Inflater and manual gzip header/trailer parsing" +
    COLOR_NORMAL);

  // copy prebuilt (correct!) version of concat.gz to HDFS
  final String fn = "concat" + gzip.getDefaultExtension();
  Path fnLocal = new Path(System.getProperty("test.concat.data", "/tmp"), fn);
  Path fnHDFS  = new Path(workDir, fn);
  localFs.copyFromLocalFile(fnLocal, fnHDFS);

  final FileInputStream in = new FileInputStream(fnLocal.toString());
  assertEquals("concat bytes available", 148, in.available());

  // should wrap all of this header-reading stuff in a running-CRC wrapper
  // (did so in BuiltInGzipDecompressor; see below)

  byte[] compressedBuf = new byte[256];
  int numBytesRead = in.read(compressedBuf, 0, 10);
  assertEquals("header bytes read", 10, numBytesRead);
  assertEquals("1st byte", 0x1f, compressedBuf[0] & 0xff);
  assertEquals("2nd byte", 0x8b, compressedBuf[1] & 0xff);
  assertEquals("3rd byte (compression method)", 8, compressedBuf[2] & 0xff);

  byte flags = (byte)(compressedBuf[3] & 0xff);
  if ((flags & 0x04) != 0) {   // FEXTRA
    numBytesRead = in.read(compressedBuf, 0, 2);
    assertEquals("XLEN bytes read", 2, numBytesRead);
    int xlen = ((compressedBuf[1] << 8) | compressedBuf[0]) & 0xffff;
    in.skip(xlen);
  }
  if ((flags & 0x08) != 0) {   // FNAME
    while ((numBytesRead = in.read()) != 0) {
      assertFalse("unexpected end-of-file while reading filename",
                  numBytesRead == -1);
    }
  }
  if ((flags & 0x10) != 0) {   // FCOMMENT
    while ((numBytesRead = in.read()) != 0) {
      assertFalse("unexpected end-of-file while reading comment",
                  numBytesRead == -1);
    }
  }
  if ((flags & 0xe0) != 0) {   // reserved
    assertTrue("reserved bits are set??", (flags & 0xe0) == 0);
  }
  if ((flags & 0x02) != 0) {   // FHCRC
    numBytesRead = in.read(compressedBuf, 0, 2);
    assertEquals("CRC16 bytes read", 2, numBytesRead);
    int crc16 = ((compressedBuf[1] << 8) | compressedBuf[0]) & 0xffff;
  }

  // ready to go!  next bytes should be start of deflated stream, suitable
  // for Inflater
  numBytesRead = in.read(compressedBuf);

  // Inflater docs refer to a "dummy byte":  no clue what that's about;
  // appears to work fine without one
  byte[] uncompressedBuf = new byte[256];
  Inflater inflater = new Inflater(true);

  inflater.setInput(compressedBuf, 0, numBytesRead);
  try {
    int numBytesUncompressed = inflater.inflate(uncompressedBuf);
    String outString =
      new String(uncompressedBuf, 0, numBytesUncompressed, "UTF-8");
    System.out.println("uncompressed data of first gzip member = [" +
                       outString + "]");
  } catch (java.util.zip.DataFormatException ex) {
    throw new IOException(ex.getMessage());
  }

  in.close();
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:82,代碼來源:TestConcatenatedCompressedInput.java

示例14: main

import java.io.FileInputStream; //導入方法依賴的package包/類
public static void
main(
	String[]	args )
{
	try{
		final FileInputStream fis = new FileInputStream( "C:\\temp\\mp.part6.rar" );

		RARTOCDecoder decoder =
			new RARTOCDecoder(
				new DataProvider()
				{
					@Override
					public int
					read(
						byte[]		buffer )

						throws IOException
					{
						return( fis.read( buffer ));
					}

					@Override
					public void
					skip(
						long		bytes )

						throws IOException
					{
						fis.skip( bytes );
					}
				});

		decoder.analyse(
			new TOCResultHandler()
			{
				@Override
				public void
				entryRead(
					String		name,
					long		size,
					boolean		password )
				{
					System.out.println( name + ": " + size + (password?" protected":""));
				}

				@Override
				public void
				complete()
				{
					System.out.println( "complete" );
				}

				@Override
				public void
				failed(
					IOException error )
				{
					System.out.println( "failed: " + Debug.getNestedExceptionMessage( error ));
				}
			});

	}catch( Throwable e ){

		e.printStackTrace();
	}
}
 
開發者ID:BiglySoftware,項目名稱:BiglyBT,代碼行數:67,代碼來源:RARTOCDecoder.java

示例15: jumpChunk

import java.io.FileInputStream; //導入方法依賴的package包/類
/**
 * jumps the current chunk
 * @param e	FileInputStream
 * @return	false - always
 * @throws IOException error in FileInputStream
 */
public boolean jumpChunk(FileInputStream e) throws IOException {
	e.skip(length-6);
	return false;
}
 
開發者ID:ZetzmannM,項目名稱:CGL,代碼行數:11,代碼來源:GL3DSChunk.java


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