」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > Java 字串佔用多少字節,為什麼答案取決於它的編碼?

Java 字串佔用多少字節,為什麼答案取決於它的編碼?

發佈於2024-11-08
瀏覽:392

How many bytes does a Java string occupy, and why does the answer depend on its encoding?

計算Java 中字串的位元組數

在Java 中,字串由字元組成,字元的位元組表示形式可能因字符而異所選的編碼。要確定字串中的位元組數,必須考慮將其轉換為位元組所使用的字元編碼。

編碼相關的位元組計數

理解的關鍵字節數是指不同的編碼會導致相同字串的位元組大小不同。例如,以 UTF-8 編碼的字串可能需要每個字元 1 個位元組,而以 UTF-16 編碼的字串可能需要每個字元 2 個位元組。

將字串轉換為位元組

要計算位元組數,我們可以使用getBytes() 方法將字串轉換為位元組數組:

byte[] utf8Bytes = string.getBytes("UTF-8");
byte[] utf16Bytes = string.getBytes("UTF-16");

結果位元組數組的長度提供了該特定編碼的位元組計數:

int utf8ByteCount = utf8Bytes.length;
int utf16ByteCount = utf16Bytes.length;

範例

考慮字串「Hello World」:

String string = "Hello World";

// Print the number of characters in the string
System.out.println(string.length()); // 11

// Calculate the byte count for different encodings
byte[] utf8Bytes = string.getBytes("UTF-8");
byte[] utf16Bytes = string.getBytes("UTF-16");
byte[] utf32Bytes = string.getBytes("UTF-32");

// Print the byte counts
System.out.println(utf8Bytes.length); // 11
System.out.println(utf16Bytes.length); // 24
System.out.println(utf32Bytes.length); // 44

注意事項

將字串轉換為位元組時,必須明確指定所需的字符編碼。依賴預設值可能會導致意外結果,尤其是在使用使用非 ASCII 字元的語言時。

此外,請注意,某些編碼(如 UTF-8)可能對字元使用可變長度編碼。這意味著單一字元可以由不同數量的位元組表示,進一步凸顯了編碼選擇的重要性。

最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3