DataBuffer
podwójnych.
Metody publiczne
abstrakcyjny bufor DoubleDataBuffer | copyTo ( DataBuffer <Double> dst, długi rozmiar) |
abstrakcyjny dublet | getDouble (długi indeks) Odczytuje wartość double pod podanym indeksem. |
streszczenie podwójne | getObject (długi indeks) Odczytuje wartość o podanym indeksie. |
abstrakcyjny bufor DoubleDataBuffer | wąski (długi rozmiar) Tworzy nowy bufor, którego zawartość jest współdzielonym podciągiem zawartości tego bufora, którego rozmiar jest ustawiony na podaną wartość. |
abstrakcyjny bufor DoubleDataBuffer | przesunięcie (długi indeks) Tworzy nowy bufor, którego zawartość jest współdzielonym podciągiem zawartości tego bufora, zaczynając od podanego indeksu. |
abstrakcyjny bufor DoubleDataBuffer | czytaj (podwójne [] dst) Metoda pobierania zbiorczego przy użyciu podwójnych tablic. |
abstrakcyjny bufor DoubleDataBuffer | czytaj (double[] dst, int przesunięcie, int długość) Metoda pobierania zbiorczego przy użyciu podwójnych tablic. |
abstrakcyjny bufor DoubleDataBuffer | setDouble (podwójna wartość, długi indeks) Zapisuje daną wartość double do tego bufora pod podanym indeksem. |
abstrakcyjny bufor DoubleDataBuffer | setObject (podwójna wartość, długi indeks) |
abstrakcyjny bufor DoubleDataBuffer | plasterek (długi indeks, długi rozmiar) Tworzy nowy bufor, którego zawartość jest współdzielonym podciągiem zawartości tego bufora, zaczynając od podanego indeksu i o podanym rozmiarze. |
streszczenie DataBufferWindow < DoubleDataBuffer > | okno (długie) Tworzy DataBufferWindow , który zapewnia częściowy widok tego buforu. |
abstrakcyjny bufor DoubleDataBuffer | napisz (podwójne [] src) Metoda umieszczania zbiorczego przy użyciu podwójnych tablic. |
abstrakcyjny bufor DoubleDataBuffer | napisz (double[] src, int przesunięcie, int długość) Metoda umieszczania zbiorczego przy użyciu podwójnych tablic. |
Metody dziedziczone
Metody publiczne
publiczna abstrakcja double getDouble (długi indeks)
Odczytuje wartość double pod podanym indeksem.
Parametry
indeks | indeks, z którego będzie odczytywany float |
---|
Powroty
- double przy danym indeksie
Rzuca
Wyjątek IndexOutOfBounds | jeśli indeks jest ujemny lub nie mniejszy niż rozmiar bufora |
---|
public streszczenie Podwójny getObject (długi indeks)
Odczytuje wartość o podanym indeksie. Ważne: użycie tej metody powinno być ograniczone do buforów typów innych niż pierwotne lub gdy typ danych nie jest deterministycznie znany wywołującemu. W każdym innym przypadku preferuj użycie jego prymitywnego wariantu, który znacznie poprawi wydajność (np. IntDataBuffer.getInt(idx)
Parametry
indeks | indeks, z którego będzie odczytywany float |
---|
Powroty
- wartość przy danym indeksie
publiczna abstrakcja DoubleDataBuffer wąski (długi rozmiar)
Tworzy nowy bufor, którego zawartość jest współdzielonym podciągiem zawartości tego bufora, którego rozmiar jest ustawiony na podaną wartość.
Nowy rozmiar nie może być większy niż rozmiar bufora. Zmiany w zawartości tego bufora będą widoczne w nowym buforze i odwrotnie. Nowy bufor będzie tylko do odczytu wtedy i tylko wtedy, gdy ten bufor będzie tylko do odczytu.
To wywołanie jest równoważne slice(0, size)
Parametry
rozmiar | rozmiar tego nowego bufora |
---|
Powroty
- nowy bufor
publiczna abstrakcja DoubleDataBuffer offset (długi indeks)
Tworzy nowy bufor, którego zawartość jest współdzielonym podciągiem zawartości tego bufora, zaczynając od podanego indeksu.
Indeks nie może być większy niż rozmiar bufora. Zmiany w zawartości tego bufora będą widoczne w nowym buforze i odwrotnie. Nowy bufor będzie tylko do odczytu wtedy i tylko wtedy, gdy ten bufor będzie tylko do odczytu.
To wywołanie jest równoważne z slice(index, size() - index)
Parametry
indeks | indeks pierwszej wartości nowo utworzonego bufora nie może być większy niż size() |
---|
Powroty
- nowy bufor
publiczny odczyt DoubleDataBuffer streszczenie (double[] dst)
Metoda pobierania zbiorczego przy użyciu podwójnych tablic.
Ta metoda przenosi wartości z tego bufora do podanej tablicy docelowej. Jeśli w buforze znajduje się mniej wartości, niż jest to wymagane do zaspokojenia żądania, to znaczy, jeśli dst.length > size()
, wówczas żadne wartości nie są przesyłane i zgłaszany jest wyjątek BufferUnderflowException.
W przeciwnym razie ta metoda kopiuje wartości n = dst.length
z tego bufora do podanej tablicy.
Parametry
dst | tablica, do której mają zostać zapisane wartości |
---|
Powroty
- ten bufor
Rzuca
Wyjątek BufferUnderflow | jeśli nie ma wystarczającej liczby wartości do skopiowania z tego bufora |
---|
publiczny odczyt DoubleDataBuffer streszczenie (double[] dst, int przesunięcie, int długość)
Metoda pobierania zbiorczego przy użyciu podwójnych tablic.
Ta metoda przenosi wartości z tego bufora do podanej tablicy docelowej. Jeśli w buforze znajduje się mniej wartości, niż jest to wymagane do zaspokojenia żądania, to znaczy, jeśli length > size()
, wówczas nie są przesyłane żadne wartości i zgłaszany jest wyjątek BufferUnderflowException.
W przeciwnym razie ta metoda kopiuje wartości n = length
z tego bufora do danej tablicy, zaczynając od danego przesunięcia.
Parametry
dst | tablica, do której mają zostać zapisane wartości |
---|---|
zrównoważyć | przesunięcie w tablicy pierwszej wartości do zapisania; musi być nieujemna i nie większa niż dst.length |
długość | maksymalna liczba wartości do zapisania do danej tablicy; musi być nieujemna i nie większa niż dst.length - offset |
Powroty
- ten bufor
Rzuca
Wyjątek BufferUnderflow | jeśli w tym buforze pozostało mniej niż długość wartości |
---|---|
Wyjątek IndexOutOfBounds | jeśli warunki wstępne dotyczące parametrów przesunięcia i długości nie są spełnione |
public streszczenie DoubleDataBuffer setDouble (podwójna wartość, długi indeks)
Zapisuje daną wartość double do tego bufora pod podanym indeksem.
Parametry
wartość | podwójne do zapisania |
---|---|
indeks | indeks, pod którym wartość zostanie zapisana |
Powroty
- ten bufor
Rzuca
Wyjątek IndexOutOfBounds | jeśli indeks jest ujemny lub nie mniejszy niż rozmiar bufora |
---|---|
Wyjątek ReadOnlyBufferException | jeśli ten bufor jest tylko do odczytu |
publiczna abstrakcja DoubleDataBuffer plasterek (długi indeks, duży rozmiar)
Tworzy nowy bufor, którego zawartość jest współdzielonym podciągiem zawartości tego bufora, zaczynając od podanego indeksu i o podanym rozmiarze.
Indeks plus nowy rozmiar nie może być większy niż rozmiar bufora. Zmiany w zawartości tego bufora będą widoczne w nowym buforze i odwrotnie. Nowy bufor będzie tylko do odczytu wtedy i tylko wtedy, gdy ten bufor będzie tylko do odczytu.
Parametry
indeks | indeks pierwszej wartości utworzonego nowego bufora |
---|---|
rozmiar | rozmiar tego nowego bufora nie może być większy niż size() |
Powroty
- nowy bufor
publiczne streszczenie DataBufferWindow < DoubleDataBuffer > okno (długi rozmiar)
Tworzy DataBufferWindow
, który zapewnia częściowy widok tego buforu.
Utworzone okno ma stały rozmiar i może "slide"
wzdłuż tego bufora, aby zapewnić różne widoki danych bez przydzielania nowej instancji bufora, tak jak robi to offset(long)
. Poprawia to ogólną wydajność, gdy ta operacja jest często powtarzana. Na przykład:
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;
}
}
Zwrócony obiekt jest stanowy i nie jest bezpieczny dla wątków.
Parametry
rozmiar | wielkość okna |
---|
Powroty
- nowe okno rozpoczynające się od indeksu 0 tego bufora
publiczny zapis streszczenia DoubleDataBuffer (double[] src)
Metoda umieszczania zbiorczego przy użyciu podwójnych tablic.
Ta metoda przenosi wartości z danej tablicy źródłowej do tego bufora. Jeśli w tablicy źródłowej znajduje się więcej wartości niż w tym buforze, to znaczy, jeśli src.length > size()
, wówczas żadne wartości nie są przesyłane i zgłaszany jest wyjątek BufferOverflowException.
W przeciwnym razie ta metoda kopiuje wartości n = src.length
z podanej tablicy.
Parametry
źródło | tablica źródłowa, z której mają zostać odczytane wartości |
---|
Powroty
- ten bufor
Rzuca
Wyjątek BufferOverflow | jeśli w tym buforze nie ma wystarczającej ilości miejsca na wartości w tablicy źródłowej |
---|---|
Wyjątek ReadOnlyBufferException | jeśli ten bufor jest tylko do odczytu |
publiczny zapis abstrakcyjnego DoubleDataBuffer (double[] src, int przesunięcie, int długość)
Metoda umieszczania zbiorczego przy użyciu podwójnych tablic.
Ta metoda przenosi wartości z danej tablicy źródłowej do tego bufora. Jeśli w tablicy źródłowej znajduje się więcej wartości niż w tym buforze, to znaczy, jeśli length > size()
, wówczas nie są przesyłane żadne wartości i zgłaszany jest wyjątek BufferOverflowException.
W przeciwnym razie ta metoda kopiuje wartości n = length
z podanej tablicy do tego bufora, zaczynając od danego przesunięcia.
Parametry
źródło | tablica źródłowa, z której mają zostać odczytane wartości |
---|---|
zrównoważyć | przesunięcie w tablicy pierwszej wartości do odczytania; musi być nieujemna i nie większa niż src.length |
długość | liczba wartości do odczytania z danej tablicy; musi być nieujemna i nie większa niż src.length - offset |
Powroty
- ten bufor
Rzuca
Wyjątek BufferOverflow | jeśli w tym buforze nie ma wystarczającej ilości miejsca na wartości w tablicy źródłowej |
---|---|
Wyjątek IndexOutOfBounds | jeśli warunki wstępne dotyczące parametrów przesunięcia i długości nie są spełnione |
Wyjątek ReadOnlyBufferException | jeśli ten bufor jest tylko do odczytu |