FileDocCategorySizeDatePackage
ByteBufferAsIntBufferL.javaAPI DocJava SE 5 API2796Fri Aug 26 16:50:20 BST 2005java.nio

ByteBufferAsIntBufferL

public class ByteBufferAsIntBufferL extends IntBuffer

Fields Summary
protected final ByteBuffer
bb
protected final int
offset
Constructors Summary
ByteBufferAsIntBufferL(ByteBuffer bb)

	// package-private

	super(-1, 0,
	      bb.remaining() >> 2,
	      bb.remaining() >> 2);
	this.bb = bb;
	// enforce limit == capacity
	int cap = this.capacity();
	this.limit(cap);
	int pos = this.position();
	assert (pos <= cap);
	offset = pos;



    
ByteBufferAsIntBufferL(ByteBuffer bb, int mark, int pos, int lim, int cap, int off)


	super(mark, pos, lim, cap);
	this.bb = bb;
	offset = off;



    
Methods Summary
public java.nio.IntBufferasReadOnlyBuffer()


	return new ByteBufferAsIntBufferRL(bb,
						 this.markValue(),
						 this.position(),
						 this.limit(),
						 this.capacity(),
						 offset);



    
public java.nio.IntBuffercompact()


	int pos = position();
	int lim = limit();
	assert (pos <= lim);
	int rem = (pos <= lim ? lim - pos : 0);

	ByteBuffer db = bb.duplicate();
 	db.limit(ix(lim));
	db.position(ix(0));
	ByteBuffer sb = db.slice();
	sb.position(pos << 2);
	sb.compact();
 	position(rem);
	limit(capacity());
	return this;



    
public java.nio.IntBufferduplicate()

	return new ByteBufferAsIntBufferL(bb,
						    this.markValue(),
						    this.position(),
						    this.limit(),
						    this.capacity(),
						    offset);
    
public intget()

	return Bits.getIntL(bb, ix(nextGetIndex()));
    
public intget(int i)

	return Bits.getIntL(bb, ix(checkIndex(i)));
    
public booleanisDirect()

	return bb.isDirect();
    
public booleanisReadOnly()

	return false;
    
protected intix(int i)

	return (i << 2) + offset;
    
public java.nio.ByteOrderorder()





	return ByteOrder.LITTLE_ENDIAN;

    
public java.nio.IntBufferput(int i, int x)


	Bits.putIntL(bb, ix(checkIndex(i)), x);
	return this;



    
public java.nio.IntBufferput(int x)


	Bits.putIntL(bb, ix(nextPutIndex()), x);
	return this;



    
public java.nio.IntBufferslice()

	int pos = this.position();
	int lim = this.limit();
	assert (pos <= lim);
	int rem = (pos <= lim ? lim - pos : 0);
	int off = (pos << 2) + offset;
        assert (off >= 0);
	return new ByteBufferAsIntBufferL(bb, -1, 0, rem, rem, off);