public class

CursorWindow

extends SQLiteClosable
implements Parcelable
java.lang.Object
   ↳ android.database.sqlite.SQLiteClosable
     ↳ android.database.CursorWindow

Class Overview

A buffer containing multiple cursor rows.

A CursorWindow is read-write when created and used locally. When sent to a remote process (by writing it to a Parcel), the remote process receives a read-only view of the cursor window. Typically the cursor window will be allocated by the producer, filled with data, and then sent to the consumer for reading.

Summary

[Expand]
Inherited Constants
From interface android.os.Parcelable
Fields
public static final Creator<CursorWindow> CREATOR
Public Constructors
CursorWindow(boolean localWindow)
Creates a new empty cursor window.
Public Methods
boolean allocRow()
Allocates a new row at the end of this cursor window.
void clear()
Clears out the existing contents of the window, making it safe to reuse for new data.
void close()
Closes the cursor window and frees its underlying resources when all other remaining references have been released.
void copyStringToBuffer(int row, int column, CharArrayBuffer buffer)
Copies the text of the field at the specified row and column index into a CharArrayBuffer.
int describeContents()
Describe the kinds of special objects contained in this Parcelable's marshalled representation.
void freeLastRow()
Frees the last row in this cursor window.
byte[] getBlob(int row, int column)
Gets the value of the field at the specified row and column index as a byte array.
double getDouble(int row, int column)
Gets the value of the field at the specified row and column index as a double.
float getFloat(int row, int column)
Gets the value of the field at the specified row and column index as a float.
int getInt(int row, int column)
Gets the value of the field at the specified row and column index as an int.
long getLong(int row, int column)
Gets the value of the field at the specified row and column index as a long.
int getNumRows()
Gets the number of rows in this window.
short getShort(int row, int column)
Gets the value of the field at the specified row and column index as a short.
int getStartPosition()
Gets the start position of this cursor window.
String getString(int row, int column)
Gets the value of the field at the specified row and column index as a string.
int getType(int row, int column)
Returns the type of the field at the specified row and column index.
boolean isBlob(int row, int column)
This method is deprecated. Use getType(int, int) instead.
boolean isFloat(int row, int column)
This method is deprecated. Use getType(int, int) instead.
boolean isLong(int row, int column)
This method is deprecated. Use getType(int, int) instead.
boolean isNull(int row, int column)
This method is deprecated. Use getType(int, int) instead.
boolean isString(int row, int column)
This method is deprecated. Use getType(int, int) instead.
static CursorWindow newFromParcel(Parcel p)
boolean putBlob(byte[] value, int row, int column)
Copies a byte array into the field at the specified row and column index.
boolean putDouble(double value, int row, int column)
Puts a double-precision floating point value into the field at the specified row and column index.
boolean putLong(long value, int row, int column)
Puts a long integer into the field at the specified row and column index.
boolean putNull(int row, int column)
Puts a null value into the field at the specified row and column index.
boolean putString(String value, int row, int column)
Copies a string into the field at the specified row and column index.
boolean setNumColumns(int columnNum)
Sets the number of columns in this window.
void setStartPosition(int pos)
Sets the start position of this cursor window.
void writeToParcel(Parcel dest, int flags)
Flatten this object in to a Parcel.
Protected Methods
void finalize()
Invoked when the garbage collector has detected that this instance is no longer reachable.
void onAllReferencesReleased()
[Expand]
Inherited Methods
From class android.database.sqlite.SQLiteClosable
From class java.lang.Object
From interface android.os.Parcelable

Fields

public static final Creator<CursorWindow> CREATOR

Since: API Level 1

Public Constructors

public CursorWindow (boolean localWindow)

Since: API Level 1

Creates a new empty cursor window.

The cursor initially has no rows or columns. Call setNumColumns(int) to set the number of columns before adding any rows to the cursor.

Parameters
localWindow True if this window will be used in this process only, false if it might be sent to another processes.

Public Methods

public boolean allocRow ()

Since: API Level 1

Allocates a new row at the end of this cursor window.

Returns
  • True if successful, false if the cursor window is out of memory.

public void clear ()

Since: API Level 1

Clears out the existing contents of the window, making it safe to reuse for new data.

The start position (getStartPosition()), number of rows (getNumRows()), and number of columns in the cursor are all reset to zero.

public void close ()

Since: API Level 1

Closes the cursor window and frees its underlying resources when all other remaining references have been released.

public void copyStringToBuffer (int row, int column, CharArrayBuffer buffer)

Since: API Level 1

Copies the text of the field at the specified row and column index into a CharArrayBuffer.

The buffer is populated as follows:

  • If the buffer is too small for the value to be copied, then it is automatically resized.
  • If the field is of type FIELD_TYPE_NULL, then the buffer is set to an empty string.
  • If the field is of type FIELD_TYPE_STRING, then the buffer is set to the contents of the string.
  • If the field is of type FIELD_TYPE_INTEGER, then the buffer is set to a string representation of the integer in decimal, obtained by formatting the value with the printf family of functions using format specifier %lld.
  • If the field is of type FIELD_TYPE_FLOAT, then the buffer is set to a string representation of the floating-point value in decimal, obtained by formatting the value with the printf family of functions using format specifier %g.
  • If the field is of type FIELD_TYPE_BLOB, then a SQLiteException is thrown.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
buffer The CharArrayBuffer to hold the string. It is automatically resized if the requested string is larger than the buffer's current capacity.

public int describeContents ()

Since: API Level 1

Describe the kinds of special objects contained in this Parcelable's marshalled representation.

Returns
  • a bitmask indicating the set of special object types marshalled by the Parcelable.

public void freeLastRow ()

Since: API Level 1

Frees the last row in this cursor window.

public byte[] getBlob (int row, int column)

Since: API Level 1

Gets the value of the field at the specified row and column index as a byte array.

The result is determined as follows:

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • The value of the field as a byte array.

public double getDouble (int row, int column)

Since: API Level 1

Gets the value of the field at the specified row and column index as a double.

The result is determined as follows:

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • The value of the field as a double.

public float getFloat (int row, int column)

Since: API Level 1

Gets the value of the field at the specified row and column index as a float.

The result is determined by invoking getDouble(int, int) and converting the result to float.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • The value of the field as an float.

public int getInt (int row, int column)

Since: API Level 1

Gets the value of the field at the specified row and column index as an int.

The result is determined by invoking getLong(int, int) and converting the result to int.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • The value of the field as an int.

public long getLong (int row, int column)

Since: API Level 1

Gets the value of the field at the specified row and column index as a long.

The result is determined as follows:

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • The value of the field as a long.

public int getNumRows ()

Since: API Level 1

Gets the number of rows in this window.

Returns
  • The number of rows in this cursor window.

public short getShort (int row, int column)

Since: API Level 1

Gets the value of the field at the specified row and column index as a short.

The result is determined by invoking getLong(int, int) and converting the result to short.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • The value of the field as a short.

public int getStartPosition ()

Since: API Level 1

Gets the start position of this cursor window.

The start position is the zero-based index of the first row that this window contains relative to the entire result set of the Cursor.

Returns
  • The zero-based start position.

public String getString (int row, int column)

Since: API Level 1

Gets the value of the field at the specified row and column index as a string.

The result is determined as follows:

  • If the field is of type FIELD_TYPE_NULL, then the result is null.
  • If the field is of type FIELD_TYPE_STRING, then the result is the string value.
  • If the field is of type FIELD_TYPE_INTEGER, then the result is a string representation of the integer in decimal, obtained by formatting the value with the printf family of functions using format specifier %lld.
  • If the field is of type FIELD_TYPE_FLOAT, then the result is a string representation of the floating-point value in decimal, obtained by formatting the value with the printf family of functions using format specifier %g.
  • If the field is of type FIELD_TYPE_BLOB, then a SQLiteException is thrown.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • The value of the field as a string.

public int getType (int row, int column)

Since: API Level 11

Returns the type of the field at the specified row and column index.

The returned field types are:

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • The field type.

public boolean isBlob (int row, int column)

Since: API Level 1

This method is deprecated.
Use getType(int, int) instead.

Returns true if the field at the specified row and column index has type FIELD_TYPE_BLOB or FIELD_TYPE_NULL.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns

public boolean isFloat (int row, int column)

Since: API Level 5

This method is deprecated.
Use getType(int, int) instead.

Returns true if the field at the specified row and column index has type FIELD_TYPE_FLOAT.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns

public boolean isLong (int row, int column)

Since: API Level 5

This method is deprecated.
Use getType(int, int) instead.

Returns true if the field at the specified row and column index has type FIELD_TYPE_INTEGER.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns

public boolean isNull (int row, int column)

Since: API Level 1

This method is deprecated.
Use getType(int, int) instead.

Returns true if the field at the specified row and column index has type FIELD_TYPE_NULL.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns

public boolean isString (int row, int column)

Since: API Level 5

This method is deprecated.
Use getType(int, int) instead.

Returns true if the field at the specified row and column index has type FIELD_TYPE_STRING or FIELD_TYPE_NULL.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns

public static CursorWindow newFromParcel (Parcel p)

Since: API Level 1

public boolean putBlob (byte[] value, int row, int column)

Since: API Level 1

Copies a byte array into the field at the specified row and column index.

Parameters
value The value to store.
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • True if successful.

public boolean putDouble (double value, int row, int column)

Since: API Level 1

Puts a double-precision floating point value into the field at the specified row and column index.

Parameters
value The value to store.
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • True if successful.

public boolean putLong (long value, int row, int column)

Since: API Level 1

Puts a long integer into the field at the specified row and column index.

Parameters
value The value to store.
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • True if successful.

public boolean putNull (int row, int column)

Since: API Level 1

Puts a null value into the field at the specified row and column index.

Parameters
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • True if successful.

public boolean putString (String value, int row, int column)

Since: API Level 1

Copies a string into the field at the specified row and column index.

Parameters
value The value to store.
row The zero-based row index, relative to the cursor window's start position (getStartPosition()).
column The zero-based column index.
Returns
  • True if successful.

public boolean setNumColumns (int columnNum)

Since: API Level 1

Sets the number of columns in this window.

This method must be called before any rows are added to the window, otherwise it will fail to set the number of columns if it differs from the current number of columns.

Parameters
columnNum The new number of columns.
Returns
  • True if successful.

public void setStartPosition (int pos)

Since: API Level 1

Sets the start position of this cursor window.

The start position is the zero-based index of the first row that this window contains relative to the entire result set of the Cursor.

Parameters
pos The new zero-based start position.

public void writeToParcel (Parcel dest, int flags)

Since: API Level 1

Flatten this object in to a Parcel.

Parameters
dest The Parcel in which the object should be written.
flags Additional flags about how the object should be written. May be 0 or PARCELABLE_WRITE_RETURN_VALUE.

Protected Methods

protected void finalize ()

Since: API Level 1

Invoked when the garbage collector has detected that this instance is no longer reachable. The default implementation does nothing, but this method can be overridden to free resources.

Note that objects that override finalize are significantly more expensive than objects that don't. Finalizers may be run a long time after the object is no longer reachable, depending on memory pressure, so it's a bad idea to rely on them for cleanup. Note also that finalizers are run on a single VM-wide finalizer thread, so doing blocking work in a finalizer is a bad idea. A finalizer is usually only necessary for a class that has a native peer and needs to call a native method to destroy that peer. Even then, it's better to provide an explicit close method (and implement Closeable), and insist that callers manually dispose of instances. This works well for something like files, but less well for something like a BigInteger where typical calling code would have to deal with lots of temporaries. Unfortunately, code that creates lots of temporaries is the worst kind of code from the point of view of the single finalizer thread.

If you must use finalizers, consider at least providing your own ReferenceQueue and having your own thread process that queue.

Unlike constructors, finalizers are not automatically chained. You are responsible for calling super.finalize() yourself.

Uncaught exceptions thrown by finalizers are ignored and do not terminate the finalizer thread. See Effective Java Item 7, "Avoid finalizers" for more.

Throws
Throwable

protected void onAllReferencesReleased ()

Since: API Level 1