FloatBuffer compact() 方法於 Java 中


緩衝區可以使用 java.nio.FloatBuffer 類中的 compact() 方法進行壓縮。此方法不需要引數,並返回一個新的壓縮 FloatBuffer,其中包含與原始緩衝區相同的內容。如果緩衝區是隻讀的,則會丟擲 ReadOnlyBufferException。

展示此過程的程式如下 −

示例

 即時演示

import java.nio.*;
import java.util.*;
public class Demo {
   public static void main(String[] args) {
      int n = 5;
      try {
         FloatBuffer buffer = FloatBuffer.allocate(n);
         buffer.put(1.2F);
         buffer.put(3.9F);
         buffer.put(7.5F);
         System.out.println("The Original FloatBuffer is: " + Arrays.toString(buffer.array()));
         System.out.println("The position is: " + buffer.position());
         System.out.println("The limit is: " + buffer.limit());
         FloatBuffer bufferCompact = buffer.compact();
         System.out.println("
The Compacted FloatBuffer is: " + Arrays.toString(bufferCompact.array()));          System.out.println("The position is: " + bufferCompact.position());          System.out.println("The limit is: " + bufferCompact.limit());       } catch (IllegalArgumentException e) {          System.out.println("Error!!! IllegalArgumentException");       } catch (ReadOnlyBufferException e) {          System.out.println("Error!!! ReadOnlyBufferException");       }    } }

以上程式的輸出如下 −

輸出

The Original FloatBuffer is: [1.2, 3.9, 7.5, 0.0, 0.0]
The position is: 3
The limit is: 5

The Compacted FloatBuffer is: [0.0, 0.0, 7.5, 0.0, 0.0]
The position is: 2
The limit is: 5

更新時間: 2019 年 7 月 30 日

71 次檢視

啟動您的事業

完成課程以獲取認證

開始
廣告
© . All rights reserved.