getFloat()
java.nio.ByteBuffer类的getFloat()方法用于读取此缓冲区当前位置的下四个字节,根据当前字节顺序将其组成一个float值,然后将位置增加4。
用法:
public abstract float getFloat()
返回值:此方法返回缓冲区当前位置的浮点值。
异常:如果此缓冲区中剩余的字节数少于四个,则此方法将引发BufferUnderflowException。
下面是说明getFloat()方法的示例:
范例1:
// Java program to demonstrate
// getFloat() method
import java.nio.*;
import java.util.*;
public class GFG {
public static void main(String[] args)
{
// Declaring the capacity of the ByteBuffer
int capacity = 8;
// Creating the ByteBuffer
try {
// creating object of ByteBuffer
// and allocating size capacity
ByteBuffer bb = ByteBuffer.allocate(capacity);
// putting the double value in the bytebuffer
bb.asFloatBuffer()
.put(12.3f)
.put(28.44f);
// rewind the Bytebuffer
bb.rewind();
// print the ByteBuffer
System.out.println("Original ByteBuffer: ");
for (int i = 1; i <= capacity / 4; i++)
System.out.print(bb.getFloat() + " ");
// rewind the Bytebuffer
bb.rewind();
// Reads the Float at this buffer's current position
// using getFloat() method
float value = bb.getFloat();
// print the float value
System.out.println("\n\nByte Value: " + value);
// Reads the float at this buffer's next position
// using getFloat() method
float value1 = bb.getFloat();
// print the float value
System.out.print("\nNext Byte Value: " + value1);
}
catch (BufferUnderflowException e) {
System.out.println("\nException Thrown : " + e);
}
}
}
输出:
Original ByteBuffer: 12.3 28.44 Byte Value: 12.3 Next Byte Value: 28.44
范例2:
// Java program to demonstrate
// getFloat() method
import java.nio.*;
import java.util.*;
public class GFG {
public static void main(String[] args)
{
// Declaring the capacity of the ByteBuffer
int capacity = 8;
// Creating the ByteBuffer
try {
// creating object of ByteBuffer
// and allocating size capacity
ByteBuffer bb = ByteBuffer.allocate(capacity);
// putting the double value in the bytebuffer
bb.asFloatBuffer()
.put(12.3f)
.put(28.44f);
// rewind the Bytebuffer
bb.rewind();
// print the ByteBuffer
System.out.println("Original ByteBuffer: ");
for (int i = 1; i <= capacity / 4; i++)
System.out.print(bb.getFloat() + " ");
// rewind the Bytebuffer
bb.rewind();
// Reads the Float at this buffer's current position
// using getFloat() method
float value = bb.getFloat();
// print the float value
System.out.println("\n\nByte Value: " + value);
// Reads the float at this buffer's next position
// using getFloat() method
float value1 = bb.getFloat();
// print the float value
System.out.println("\nNext Byte Value: " + value1);
// Reads the float at this buffer's next position
// using getFloat() method
float value2 = bb.getFloat();
}
catch (BufferUnderflowException e) {
System.out.println("\nthere are fewer "
+ "than eight bytes remaining"
+ " in this buffer");
System.out.println("Exception Thrown : " + e);
}
}
}
输出:
Original ByteBuffer: 12.3 28.44 Byte Value: 12.3 Next Byte Value: 28.44 there are fewer than eight bytes remaining in this buffer Exception Thrown : java.nio.BufferUnderflowException
参考: https://docs.oracle.com/javase/9/docs/api/java/nio/ByteBuffer.html#getFloat–
getFloat(int索引)
java.nio.ByteBuffer的getFloat(int index)方法用于读取给定索引处的四个字节,并根据当前字节顺序将它们组成一个float值。
用法:
public abstract float getFloat(int index)
参数:此方法将index作为参数,即将从中读取Byte的索引。
返回值:此方法返回给定索引处的float值。
异常:如果index为负或不小于缓冲区的限制,则此方法将引发IndexOutOfBoundsException。
以下示例说明了getFloat(int index)方法:
范例1:
// Java program to demonstrate
// getFloat() method
import java.nio.*;
import java.util.*;
public class GFG {
public static void main(String[] args)
{
// Declaring the capacity of the ByteBuffer
int capacity = 8;
// Creating the ByteBuffer
try {
// creating object of ByteBuffer
// and allocating size capacity
ByteBuffer bb = ByteBuffer.allocate(capacity);
// putting the double value in the bytebuffer
bb.asFloatBuffer()
.put(12.3f)
.put(28.44f);
// rewind the Bytebuffer
bb.rewind();
// print the ByteBuffer
System.out.println("Original ByteBuffer: ");
for (int i = 1; i <= capacity / 4; i++)
System.out.print(bb.getFloat() + " ");
// rewind the Bytebuffer
bb.rewind();
// Reads the Float at this buffer's current position
// using getFloat() method
float value = bb.getFloat(0);
// print the float value
System.out.println("\n\nByte Value: " + value);
// Reads the float at this buffer's next position
// using getFloat() method
float value1 = bb.getFloat(4);
// print the float value
System.out.println("\nNext Byte Value: " + value1);
}
catch (IndexOutOfBoundsException e) {
System.out.println("\nindex is negative or smaller"
+ " than the buffer's limit, "
+ "minus seven");
System.out.println("Exception Thrown : " + e);
}
}
}
输出:
Original ByteBuffer: 12.3 28.44 Byte Value: 12.3 Next Byte Value: 28.44
范例2:
// Java program to demonstrate
// getFloat() method
import java.nio.*;
import java.util.*;
public class GFG {
public static void main(String[] args)
{
// Declaring the capacity of the ByteBuffer
int capacity = 8;
// Creating the ByteBuffer
try {
// creating object of ByteBuffer
// and allocating size capacity
ByteBuffer bb = ByteBuffer.allocate(capacity);
// putting the double value in the bytebuffer
bb.asFloatBuffer()
.put(12.3f)
.put(28.44f);
// rewind the Bytebuffer
bb.rewind();
// print the ByteBuffer
System.out.println("Original ByteBuffer: ");
for (int i = 1; i <= capacity / 4; i++)
System.out.print(bb.getFloat() + " ");
// rewind the Bytebuffer
bb.rewind();
// Reads the Float at this buffer's current position
// using getFloat() method
float value = bb.getFloat(0);
// print the float value
System.out.println("\n\nByte Value: " + value);
// Reads the float at this buffer's next position
// using getFloat() method
float value1 = bb.getFloat(6);
// print the float value
System.out.println("\nNext Byte Value: " + value1);
}
catch (IndexOutOfBoundsException e) {
System.out.println("\nindex is negative or"
+ " smaller than the buffer's "
+ "limit, minus seven");
System.out.println("Exception Thrown : " + e);
}
}
}
输出:
Original ByteBuffer: 12.3 28.44 Byte Value: 12.3 index is negative or smaller than the buffer's limit, minus seven Exception Thrown : java.lang.IndexOutOfBoundsException
参考: https://docs.oracle.com/javase/9/docs/api/java/nio/ByteBuffer.html#getFloat-int-
相关用法
- Java Field getFloat()用法及代码示例
- Java ByteBuffer get()用法及代码示例
- Java ByteBuffer duplicate()用法及代码示例
- Java ByteBuffer equals()用法及代码示例
- Java ByteBuffer getChar()用法及代码示例
- Java ByteBuffer hasArray()用法及代码示例
- Java ByteBuffer allocate()用法及代码示例
- Java ByteBuffer asCharBuffer()用法及代码示例
- Java ByteBuffer array()用法及代码示例
- Java ByteBuffer compact()用法及代码示例
- Java ByteBuffer asReadOnlyBuffer()用法及代码示例
- Java ByteBuffer slice()用法及代码示例
- Java ByteBuffer asIntBuffer()用法及代码示例
- Java ByteBuffer allocateDirect()用法及代码示例
- Java ByteBuffer asDoubleBuffer()用法及代码示例
注:本文由纯净天空筛选整理自RohitPrasad3大神的英文原创作品 ByteBuffer getFloat() method in Java with Examples。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。