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.

Summary

Constants
Creator<CursorWindow> CREATOR
[Expand]
Inherited Constants
From interface android.os.Parcelable
Public Constructors
CursorWindow(boolean localWindow)
Creates a new empty window.
Public Methods
boolean allocRow()
Allocate a row in cursor window
void clear()
Clears out the existing contents of the window, making it safe to reuse for new data.
void close()
Cleans up the native resources associated with the window.
void copyStringToBuffer(int row, int col, CharArrayBuffer buffer)
copy the text for the given field in the provided char array.
int describeContents()
Describe the kinds of special objects contained in this Parcelable's marshalled representation.
void freeLastRow()
Free the last row
byte[] getBlob(int row, int col)
Returns a byte array for the given field.
double getDouble(int row, int col)
Returns a double for the given field.
float getFloat(int row, int col)
Returns a float for the given field.
int getInt(int row, int col)
Returns an int for the given field.
long getLong(int row, int col)
Returns a long for the given field.
int getNumRows()
Returns the number of rows in this window.
short getShort(int row, int col)
Returns a short for the given field.
int getStartPosition()
Returns the starting position of this window within the entire Cursor's result set.
String getString(int row, int col)
Returns a String for the given field.
boolean isBlob(int row, int col)
Checks if a field contains either a blob or is null.
boolean isNull(int row, int col)
Returns true if given field is NULL.
static CursorWindow newFromParcel(Parcel p)
boolean putBlob(byte[] value, int row, int col)
copy byte array to cursor window
boolean putDouble(double value, int row, int col)
Copy double to cursor window
boolean putLong(long value, int row, int col)
Copy integer to cursor window
boolean putNull(int row, int col)
Set the [row, col] value to NULL
boolean putString(String value, int row, int col)
Copy String to cursor window
boolean setNumColumns(int columnNum)
Set number of Columns
void setStartPosition(int pos)
Set the start position of cursor window
void writeToParcel(Parcel dest, int flags)
Flatten this object in to a Parcel.
Protected Methods
void finalize()
Is called before the object's memory is being reclaimed by the VM.
void onAllReferencesReleased()
[Expand]
Inherited Methods
From class android.database.sqlite.SQLiteClosable
From class java.lang.Object
From interface android.os.Parcelable

Constants

public static final Creator<CursorWindow> CREATOR

Since: API Level 1

Public Constructors

public CursorWindow (boolean localWindow)

Since: API Level 1

Creates a new empty window.

Parameters
localWindow true if this window will be used in this process only

Public Methods

public boolean allocRow ()

Since: API Level 1

Allocate a row in cursor window

Returns
  • false if 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. Note that the number of columns in the window may NOT change across a call to clear().

public void close ()

Since: API Level 1

Cleans up the native resources associated with the window.

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

Since: API Level 1

copy the text for the given field in the provided char array.

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
buffer the CharArrayBuffer to copy the text into, If the requested string is larger than the buffer a new char buffer will be created to hold the string. and assigne to CharArrayBuffer.data

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

Free the last row

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

Since: API Level 1

Returns a byte array for the given field.

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • a String value for the given field

public double getDouble (int row, int col)

Since: API Level 1

Returns a double for the given field. row is 0 based

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • a double value for the given field

public float getFloat (int row, int col)

Since: API Level 1

Returns a float for the given field. row is 0 based

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • a float value for the given field

public int getInt (int row, int col)

Since: API Level 1

Returns an int for the given field.

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • an int value for the given field

public long getLong (int row, int col)

Since: API Level 1

Returns a long for the given field. row is 0 based

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • a long value for the given field

public int getNumRows ()

Since: API Level 1

Returns the number of rows in this window.

Returns
  • the number of rows in this window.

public short getShort (int row, int col)

Since: API Level 1

Returns a short for the given field. row is 0 based

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • a short value for the given field

public int getStartPosition ()

Since: API Level 1

Returns the starting position of this window within the entire Cursor's result set.

Returns
  • the starting position of this window within the entire Cursor's result set.

public String getString (int row, int col)

Since: API Level 1

Returns a String for the given field.

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • a String value for the given field

public boolean isBlob (int row, int col)

Since: API Level 1

Checks if a field contains either a blob or is null.

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • true if given field is NULL or a blob

public boolean isNull (int row, int col)

Since: API Level 1

Returns true if given field is NULL.

Parameters
row the row to read from, row - getStartPosition() being the actual row in the window
col the column to read from
Returns
  • true if given field is NULL

public static CursorWindow newFromParcel (Parcel p)

Since: API Level 1

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

Since: API Level 1

copy byte array to cursor window

Returns
  • false if fail to copy

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

Since: API Level 1

Copy double to cursor window

Returns
  • false if fail to copy

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

Since: API Level 1

Copy integer to cursor window

Returns
  • false if fail to copy

public boolean putNull (int row, int col)

Since: API Level 1

Set the [row, col] value to NULL

Returns
  • false if fail to copy

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

Since: API Level 1

Copy String to cursor window

Returns
  • false if fail to copy

public boolean setNumColumns (int columnNum)

Since: API Level 1

Set number of Columns

Returns
  • true if success

public void setStartPosition (int pos)

Since: API Level 1

Set the start position of cursor window

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

Is called before the object's memory is being reclaimed by the VM. This can only happen once the VM has detected, during a run of the garbage collector, that the object is no longer reachable by any thread of the running application.

The method can be used to free system resources or perform other cleanup before the object is garbage collected. The default implementation of the method is empty, which is also expected by the VM, but subclasses can override finalize() as required. Uncaught exceptions which are thrown during the execution of this method cause it to terminate immediately but are otherwise ignored.

Note that the VM does guarantee that finalize() is called at most once for any object, but it doesn't guarantee when (if at all) finalize() will be called. For example, object B's finalize() can delay the execution of object A's finalize() method and therefore it can delay the reclamation of A's memory. To be safe, use a ReferenceQueue, because it provides more control over the way the VM deals with references during garbage collection.

protected void onAllReferencesReleased ()

Since: API Level 1