Método DoubleBuffer arrayOffset() en Java con ejemplos

El método arrayOffset() de la clase java.nio.DoubleBuffer se utiliza para devolver el desplazamiento dentro de la array de respaldo del búfer del primer elemento del búfer. Significa que si este búfer está respaldado por una array, entonces la posición del búfer p corresponde al índice de array p + arrayOffset().

Para verificar si este búfer tiene una array de respaldo, se puede usar el método hasArray(). Garantiza que este búfer tenga una array de respaldo accesible.

Sintaxis:

public final int arrayOffset()

Valor devuelto: este método devuelve el desplazamiento dentro de la array de este búfer del primer elemento del búfer.

Excepción: este método lanza ReadOnlyBufferException si este búfer está respaldado por una array pero es de solo lectura

El siguiente programa ilustra el método arrayOffset().

Ejemplos 1:

// Java program to demonstrate
// arrayOffset() method
  
import java.nio.*;
import java.util.*;
  
public class GFG {
    public static void main(String[] args)
    {
  
        // Declaring the capacity of the DoubleBuffer
        int capacity = 10;
  
        // Creating the DoubleBuffer
        try {
  
            // creating object of Doublebuffer
            // and allocating size capacity
            DoubleBuffer fb = DoubleBuffer.allocate(capacity);
  
            // putting the value in Doublebuffer
            fb.put(8.56F);
            fb.put(2, 9.61F);
  
            // print the DoubleBuffer
            System.out.println("DoubleBuffer: "
                               + Arrays.toString(fb.array()));
  
            // print the arrayOffset
            System.out.println("arrayOffset: "
                               + fb.arrayOffset());
        }
  
        catch (IllegalArgumentException e) {
            System.out.println("IllegalArgumentException catched");
        }
  
        catch (ReadOnlyBufferException e) {
            System.out.println("Exception throws" + e);
        }
    }
}
Producción:

DoubleBuffer: [8.5600004196167, 0.0, 9.609999656677246, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0]
arrayOffset: 0

Ejemplos 2: Para demostrar ReadOnlyBufferException

// Java program to demonstrate
// arrayOffset() method
  
import java.nio.*;
import java.util.*;
  
public class GFG {
    public static void main(String[] args)
    {
  
        // Declaring the capacity of the DoubleBuffer
        int capacity = 10;
  
        // Creating the DoubleBuffer
        try {
  
            // creating object of Doublebuffer
            // and allocating size capacity
            DoubleBuffer fb = DoubleBuffer.allocate(capacity);
  
            // putting the value in Doublebuffer
            fb.put(8.56F);
            fb.put(2, 9.61F);
            fb.rewind();
  
            // Creating a read-only copy of DoubleBuffer
            // using asReadOnlyBuffer() method
            DoubleBuffer fb1 = fb.asReadOnlyBuffer();
  
            // print the DoubleBuffer
            System.out.print("Read only buffer : ");
            while (fb1.hasRemaining())
                System.out.print(fb1.get() + ", ");
  
            // next line
            System.out.println("");
  
            // print the arrayOffset
            System.out.println("\nTry to print the array offset"
                               + " of read only buffer");
            System.out.println("arrayOffset: " + fb1.arrayOffset());
        }
  
        catch (IllegalArgumentException e) {
            System.out.println("Exception throws: " + e);
        }
  
        catch (ReadOnlyBufferException e) {
            System.out.println("Exception throws: " + e);
        }
    }
}
Producción:

Read only buffer : 8.5600004196167, 0.0, 9.609999656677246, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 

Try to print the array offset of read only buffer
Exception throws: java.nio.ReadOnlyBufferException

Publicación traducida automáticamente

Artículo escrito por pawan_asipu y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *