LongDataBuffer

interfaccia pubblica LongDataBuffer

Un DataBuffer di long.

Metodi pubblici

astratto LongDataBuffer
copyTo ( DataBuffer <Long> dst, dimensione lunga)
astratto lungo
getLong (indice lungo)
Legge il long all'indice specificato.
astratto lungo
getObject (indice lungo)
Legge il valore dell'indice specificato.
astratto LongDataBuffer
stretto (taglia lunga)
Crea un nuovo buffer il cui contenuto è una sottosequenza condivisa del contenuto di questo buffer, la cui dimensione è impostata sul valore specificato.
astratto LongDataBuffer
offset (indice lungo)
Crea un nuovo buffer il cui contenuto è una sottosequenza condivisa del contenuto di questo buffer, a partire dall'indice specificato.
astratto LongDataBuffer
leggi (long[] dst)
Metodo di acquisizione in blocco, utilizzando array lunghi.
astratto LongDataBuffer
leggi (long[] dst, int offset, int lunghezza)
Metodo di acquisizione in blocco, utilizzando array lunghi.
astratto LongDataBuffer
setLong (valore lungo, indice lungo)
Scrive il long specificato in questo buffer in corrispondenza dell'indice specificato.
astratto LongDataBuffer
setObject (valore lungo, indice lungo)
astratto LongDataBuffer
slice (indice lungo, dimensione lunga)
Crea un nuovo buffer il cui contenuto è una sottosequenza condivisa del contenuto di questo buffer, a partire dall'indice e dalla dimensione specificati.
abstract DataBufferWindow < LongDataBuffer >
finestra (formato lungo)
Crea un DataBufferWindow che fornisce una visualizzazione parziale di questo buffer.
astratto LongDataBuffer
scrivi (long[] src, int offset, int lunghezza)
Metodo di immissione in blocco, utilizzando array lunghi.
astratto LongDataBuffer
scrivere (lungo[] src)
Metodo di immissione in blocco, utilizzando array lunghi.

Metodi ereditati

Metodi pubblici

public abstract LongDataBuffer copyTo ( DataBuffer <Long> dst, dimensione lunga)

public abstract long getLong (indice lungo)

Legge il long all'indice specificato.

Parametri
indice l'indice da cui verrà letto il float
ritorna
  • il long al dato indice
Lancia
IndexOutOfBoundsException se l'indice è negativo o non inferiore alla dimensione del buffer

public abstract Long getObject (indice lungo)

Legge il valore dell'indice specificato. Importante: l'utilizzo di questo metodo deve essere limitato ai buffer di tipi non primitivi o quando il tipo di dati non è conosciuto in modo deterministico dal chiamante. In ogni altro caso, preferisci l'utilizzo della sua variante primitiva che migliorerà significativamente le prestazioni (ad esempio IntDataBuffer.getInt(idx)

Parametri
indice l'indice da cui verrà letto il float
ritorna
  • il valore dell'indice dato

public abstract LongDataBuffer stretto (dimensione lunga)

Crea un nuovo buffer il cui contenuto è una sottosequenza condivisa del contenuto di questo buffer, la cui dimensione è impostata sul valore specificato.

La nuova dimensione non deve essere maggiore della dimensione del buffer. Le modifiche al contenuto di questo buffer saranno visibili nel nuovo buffer e viceversa. Il nuovo buffer sarà di sola lettura se, e solo se, questo buffer è di sola lettura.

Questa chiamata è equivalente a slice(0, size)

Parametri
misurare dimensione di questo nuovo buffer
ritorna
  • il nuovo tampone

offset pubblico LongDataBuffer (indice lungo)

Crea un nuovo buffer il cui contenuto è una sottosequenza condivisa del contenuto di questo buffer, a partire dall'indice specificato.

L'indice non deve essere maggiore della dimensione del buffer. Le modifiche al contenuto di questo buffer saranno visibili nel nuovo buffer e viceversa. Il nuovo buffer sarà di sola lettura se, e solo se, questo buffer è di sola lettura.

Questa chiamata è equivalente a slice(index, size() - index)

Parametri
indice indice del primo valore del nuovo buffer creato, non deve essere maggiore di size()
ritorna
  • il nuovo tampone

lettura astratta pubblica LongDataBuffer (long[] dst)

Metodo di acquisizione in blocco, utilizzando array lunghi.

Questo metodo trasferisce i valori da questo buffer nell'array di destinazione specificato. Se nel buffer sono presenti meno valori di quelli necessari per soddisfare la richiesta, ovvero se dst.length > size() , non viene trasferito alcun valore e viene generata un'eccezione BufferUnderflowException.

Altrimenti, questo metodo copia i valori n = dst.length da questo buffer nell'array specificato.

Parametri
dst l'array in cui devono essere scritti i valori
ritorna
  • questo buffer
Lancia
BufferUnderflowException se non ci sono abbastanza valori da copiare da questo buffer

public abstract LongDataBuffer lettura (long[] dst, int offset, int length)

Metodo di acquisizione in blocco, utilizzando array lunghi.

Questo metodo trasferisce i valori da questo buffer nell'array di destinazione specificato. Se nel buffer sono presenti meno valori di quelli necessari per soddisfare la richiesta, ovvero se length > size() , non viene trasferito alcun valore e viene generata un'eccezione BufferUnderflowException.

Altrimenti, questo metodo copia n = length da questo buffer nell'array specificato a partire dall'offset specificato.

Parametri
dst l'array in cui devono essere scritti i valori
compensare l'offset all'interno dell'array del primo valore da scrivere; deve essere non negativo e non maggiore di dst.length
lunghezza il numero massimo di valori da scrivere nell'array specificato; deve essere non negativo e non maggiore di dst.length - offset
ritorna
  • questo buffer
Lancia
BufferUnderflowException se in questo buffer rimangono meno valori di lunghezza
IndexOutOfBoundsException se le precondizioni sui parametri offset e lunghezza non valgono

public abstract LongDataBuffer setLong (valore lungo, indice lungo)

Scrive il long specificato in questo buffer in corrispondenza dell'indice specificato.

Parametri
valore il tempo da scrivere
indice l'indice in cui verrà scritto il valore
ritorna
  • questo buffer
Lancia
IndexOutOfBoundsException se l'indice è negativo o non inferiore alla dimensione del buffer
ReadOnlyBufferException se questo buffer è di sola lettura

public abstract LongDataBuffer setObject (valore lungo, indice lungo)

porzione astratta pubblica di LongDataBuffer (indice lungo, dimensione lunga)

Crea un nuovo buffer il cui contenuto è una sottosequenza condivisa del contenuto di questo buffer, a partire dall'indice e dalla dimensione specificati.

L'indice più la nuova dimensione non devono essere maggiori della dimensione del buffer. Le modifiche al contenuto di questo buffer saranno visibili nel nuovo buffer e viceversa. Il nuovo buffer sarà di sola lettura se, e solo se, questo buffer è di sola lettura.

Parametri
indice indice del primo valore del nuovo buffer creato
misurare la dimensione di questo nuovo buffer non deve essere maggiore di size()
ritorna
  • il nuovo tampone

public abstract DataBufferWindow < LongDataBuffer > finestra (dimensione lunga)

Crea un DataBufferWindow che fornisce una visualizzazione parziale di questo buffer.

La finestra creata ha una dimensione fissa e può "slide" lungo questo buffer per fornire diverse visualizzazioni dei dati senza allocare una nuova istanza del buffer, come fa offset(long) . Ciò migliora le prestazioni generali quando questa operazione viene ripetuta frequentemente. Ad esempio:

IntDataBuffer bufferA = DataBuffers.ofInts(1024);
 // ... init buffer data
 IntDataBuffer bufferB = DataBuffers.ofInts(1, 2, 3, 4);

 // Return the index of the first occurrence of bufferB in bufferA using a sliding window
 DataBufferWindow<IntDataBuffer> windowA = bufferA.window(4);
 for (int i = 0; i < bufferA.size() - bufferB.size(); ++i) {
     if (windowA.slideTo(i).buffer().equals(bufferB)) {
         return i;
     
 }
 }

L'oggetto restituito è con stato e non è thread-safe.

Parametri
misurare dimensione della finestra
ritorna
  • una nuova finestra che inizia dall'indice 0 di questo buffer

scrittura astratta pubblica LongDataBuffer (long[] src, int offset, int length)

Metodo di immissione in blocco, utilizzando array lunghi.

Questo metodo trasferisce i valori nell'array di origine specificato in questo buffer. Se sono presenti più valori nell'array di origine che in questo buffer, ovvero se length > size() , non viene trasferito alcun valore e viene generata un'eccezione BufferOverflowException.

Altrimenti, questo metodo copia n = length dall'array specificato in questo buffer, a partire dall'offset specificato.

Parametri
src l'array di origine da cui leggere i valori
compensare l'offset all'interno dell'array del primo valore da leggere; deve essere non negativo e non maggiore di src.length
lunghezza il numero di valori da leggere dall'array specificato; deve essere non negativo e non maggiore di src.length - offset
ritorna
  • questo buffer
Lancia
BufferOverflowException se lo spazio in questo buffer non è sufficiente per i valori nell'array di origine
IndexOutOfBoundsException se le precondizioni sui parametri offset e lunghezza non valgono
ReadOnlyBufferException se questo buffer è di sola lettura

abstract pubblico LongDataBuffer scrittura (long[] src)

Metodo di immissione in blocco, utilizzando array lunghi.

Questo metodo trasferisce i valori nell'array di origine specificato in questo buffer. Se sono presenti più valori nell'array di origine che in questo buffer, ovvero se src.length > size() , non viene trasferito alcun valore e viene generata un'eccezione BufferOverflowException.

Altrimenti, questo metodo copia i valori n = src.length dall'array specificato.

Parametri
src l'array di origine da cui leggere i valori
ritorna
  • questo buffer
Lancia
BufferOverflowException se lo spazio in questo buffer non è sufficiente per i valori nell'array di origine
ReadOnlyBufferException se questo buffer è di sola lettura