allocate
public static CharBuffer allocate(int capacity)
Allocates a new CharBuffer object with a given capacity.
array
public final char[] array()
Returns the char array that backs this buffer.
arrayOffset
public final int arrayOffset()
Returns the offset within this buffer's backing array of the first element.
asReadOnlyBuffer
public abstract CharBuffer asReadOnlyBuffer()
Creates a new read-only CharBuffer that shares this
buffer's content.
charAt
public final char charAt(int index)
Returns the character at position() + index.
- Specified by:
- charAt in interface CharSequence
duplicate
public abstract CharBuffer duplicate()
Creates a new CharBuffer that shares this buffer's
content.
get
public abstract char get()
Reads the char at this buffer's current position,
and then increments the position.
get
public CharBuffer get(char[] dst)
This method transfers chars from this buffer into the given
destination array.
- Parameters:
dst - The byte array to write into.
get
public CharBuffer get(char[] dst,
int offset,
int length)
This method transfers chars from this buffer into the given
destination array. Before the transfer, it checks if there are fewer than
length chars remaining in this buffer.
- Parameters:
dst - The destination arrayoffset - The offset within the array of the first char
to be written; must be non-negative and no larger than dst.length.length - The maximum number of bytes to be written to the given array;
must be non-negative and no larger than dst.length - offset.
get
public abstract char get(int index)
Absolute get method.
hasArray
public final boolean hasArray()
Tells whether ot not this buffer is backed by an accessible
char array.
hashCode
public int hashCode()
Calculates a hash code for this buffer.
This is done with int arithmetic,
where ** represents exponentiation, by this formula:
s[position()] + 31 + (s[position()+1] + 30)*31**1 + ... +
(s[limit()-1]+30)*31**(limit()-1).
Where s is the buffer data. Note that the hashcode is dependent
on buffer content, and therefore is not useful if the buffer
content may change.
- Overrides:
- hashCode in interface Object
isDirect
public abstract boolean isDirect()
Tells wether or not this buffer is direct.
length
public final int length()
Returns the length of the remaining chars in this buffer.
- Specified by:
- length in interface CharSequence
order
public abstract ByteOrder order()
Returns the byte order of this buffer.
put
public abstract CharBuffer put(char b)
Writes the char at this buffer's current position,
and then increments the position.
put
public final CharBuffer put(char[] src)
Writes the content of the the char array src
into the buffer.
- Parameters:
src - The array to copy into the buffer.
put
public CharBuffer put(char[] src,
int offset,
int length)
Writes the content of the the char array src
into the buffer. Before the transfer, it checks if there is fewer than
length space remaining in this buffer.
- Parameters:
src - The array to copy into the buffer.offset - The offset within the array of the first byte to be read;
must be non-negative and no larger than src.length.length - The number of bytes to be read from the given array;
must be non-negative and no larger than src.length - offset.
put
public abstract CharBuffer put(int index,
char b)
Absolute put method.
put
public CharBuffer put(CharBuffer src)
Writes the content of the the CharBUFFER src
into the buffer. Before the transfer, it checks if there is fewer than
src.remaining() space remaining in this buffer.
- Parameters:
src - The source data.
slice
public abstract CharBuffer slice()
Creates a new CharBuffer whose content is a shared
subsequence of this buffer's content.
subSequence
public abstract CharSequence subSequence(int start,
int length)
Creates a new character buffer that represents the specified subsequence
of this buffer, relative to the current position.
- Specified by:
- subSequence in interface CharSequence
wrap
public static final CharBuffer wrap(char[] array)
Wraps a char array into a CharBuffer
object.
- Parameters:
array - the array to wrap
- Returns:
- a new
CharBuffer object
wrap
public static final CharBuffer wrap(char[] array,
int offset,
int length)
Wraps a char array into a CharBuffer
object.
- Parameters:
array - the array to wrapoffset - the offset of the region in the array to wraplength - the length of the region in the array to wrap
- Returns:
- a new
CharBuffer object
wrap
public static final CharBuffer wrap(CharSequence seq)
Wraps a character sequence into a CharBuffer object.
- Parameters:
seq - the sequence to wrap
- Returns:
- a new
CharBuffer object
wrap
public static final CharBuffer wrap(CharSequence seq,
int start,
int end)
Wraps a character sequence into a CharBuffer object.
- Parameters:
seq - the sequence to wrapstart - the index of the first character to wrapend - the index of the first character not to wrap
- Returns:
- a new
CharBuffer object
CharBuffer.java --
Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
This file is part of GNU Classpath.
GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Classpath is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING. If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
Linking this library statically or dynamically with other modules is
making a combined work based on this library. Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.
As a special exception, the copyright holders of this library give you
permission to link this library with independent modules to produce an
executable, regardless of the license terms of these independent
modules, and to copy and distribute the resulting executable under
terms of your choice, provided that you also meet, for each linked
independent module, the terms and conditions of the license of that
module. An independent module is a module which is not derived from
or based on this library. If you modify this library, you may extend
this exception to your version of the library, but you are not
obligated to do so. If you do not wish to do so, delete this
exception statement from your version.