java位元組字元
⑴ java中byte是什麼類型
java中byte是位元組型。
java byte作為最小的數字來處理的,因此它的值域被定義為-128~127,byte的用作計數的時間遠少於用表達基本內存單元的時間。
比如從stream里讀入一個雙位元組字元,我們先收到2個byte。為了把byte轉換成適當的形式,需要對byte值做一些比較,比如判斷字元集要比較其是否在某個編碼范圍內。
(1)java位元組字元擴展閱讀:
Java看起來設計得很像C++,但是為了使語言小和容易熟悉,設計者們把C++語言中許多可用的特徵去掉了,這些特徵是一般程序員很少使用的。
例如,Java不支持go to語句,代之以提供break和continue語句以及異常處理。Java還剔除了C++的操作符過載(overload)和多繼承特徵,並且不使用主文件,免去了預處理程序。
⑵ Java中 「字元類型」與「位元組類型」的區別
字元流處理的單元為2個位元組的unicode字元,分別操作字元、字元數組或字元串,而位元組流處理單元為1個位元組,
操作位元組和位元組數組。所以字元流是由java虛擬機將位元組轉化為2個位元組的unicode字元為單位的字元而成的,所以它對多國語言支持性比較好!如果是
音頻文件、圖片、歌曲,就用位元組流好點,如果是關繫到中文(文本)的,用字元流好點.
所有文件的儲存是都是位元組(byte)的儲存,在磁碟上保留的並不是文件的字元而是先把字元編碼成位元組,再儲存這些位元組到磁碟。在讀取文件(特別是文本文件)時,也是一個位元組一個位元組地讀取以形成位元組序列.
位元組流可用於任何類型的對象,包括二進制對象,而字元流只能處理字元或者字元串;
2.
位元組流提供了處理任何類型的io操作的功能,但它不能直接處理unicode字元,而字元流就可以。
⑶ java位元組流和字元流的區別
Java 字元流和位元組流的區別如下:
字元流處理的單元為 2 個位元組的 Unicode 字元,分別操作字元、字元數組或字元串。
而位元組流處理單元為 1 個位元組,操作位元組和位元組數組。
請採納,謝謝
⑷ JAVA中位元組和字元的區別
一個位元組(byte)=8bit,字元的話一個英文字元=一個位元組,一個中文字元(也就是漢字)=2個位元組,有一些特殊符號也會佔用兩個位元組,位元組流比字元流粒度更小
⑸ java中位元組和字元分別什麼時候用
位元組:byte 1位元組 8位 屬於整型 范圍-128到127
字元:char 2位元組 16位
位元組變數可保存整形的數據,范圍是-128到127,byte b = 45;
字元變數可保存字元形的數據,用''括起來,比如char c = 'C';
如果你編寫程序時,用到的數據是整形,且不超出范圍-128到127,就可用位元組。用到的數據是單個字元時,就可用字元char,如果用到很多連續的字元時,可用字元串String,比如String s ="ABC";
⑹ (java)如何獲取字元串的位元組數!
Java語言中,中文字元所佔的位元組數取決於字元的
編碼方式
,一般情況下,採用
ISO8859-1
編碼方式時,一個中文字元與一個英文字元一樣只佔1個位元組;採用GB2312或GBK編碼方式時,一個中文字元佔2個位元組;而採用UTF-8編碼方式時,一個中文字元會佔3個位元組。
public static void main(String []args) throws UnsupportedEncodingException {
// 運行結果:2
System.out.println("測試".getBytes("ISO8859-1").length);
// 運行結果:4
System.out.println("測試".getBytes("GB2312").length);
// 運行結果:4
System.out.println("測試".getBytes("GBK").length);
// 運行結果:6
System.out.println("測試".getBytes("UTF-8").length);
}
⑺ Java中一個字元到底多少個位元組
字元 不等於 位元組。
字元(char)是 Java 中的一種基本數據類型,由 2 個位元組組成,范圍從 0 開始,到 2^16-1。
位元組是一種數據量的單位,一個位元組等於 8 位。所有的數據所佔空間都可以用位元組數來衡量。例如一個字元占 2 個位元組,一個 int 占 4 個位元組,一個 double 占 8 個位元組 等等。
⑻ java中一個字元是幾個位元組字元和位元組是同等的嗎
字元
不等於
位元組。
字元(char)是
Java
中的一種基本數據類型,由
2
個位元組組成,范圍從
0
開始,到
2^16-1。
位元組是一種數據量的單位,一個位元組等於
8
位。所有的數據所佔空間都可以用位元組數來衡量。例如一個字元占
2
個位元組,一個
int
占
4
個位元組,一個
double
占
8
個位元組
等等。
⑼ Java中 「字元類型」與「位元組類型」的區別是什麼
byte位元組類型是JAVA中最小的數據類型,它在內存中佔8位,取值范圍從-128到127,
賦值:byte i = 127;註:byte型在賦值時,一旦超過127或小於-128,則會產生編譯錯誤。
char字元類型在內存中佔2個位元組。表示一個字元,也可以使用A SCII碼范圍內的值來給char型的變數賦值。由於字元在內存中的取值不存在負數范圍,所有取值范圍從0到655 35。
賦值:char i = 'a'; 或者 char i = 97;
註:在java中,字元的表現形式為單個字元加上一對單引號修飾。
首先得知道byte的概念和作用:
byte即位元組的意思,是java中的基本類型,用來申明位元組型的變數。
通常在讀取非文本文件時(如圖片,聲音,可執行文件)需要用位元組數組來保存文件的內容,在下載文件時,
也是用byte數組作臨時的緩沖器接收文件內容。所以說byte在文件操作時是必不可少的。不管是對文件寫入還是
讀取都要用到。byte在java中是一種是數據類型,代表一個位元組,一個位元組包含8個位,所以,byte類型的取值范
圍是-128到127。
在某些程序中(尤其是和硬體有關的程序)會將某些數據存儲到位元組類型的變數中,比如00110010,其中每個
位都代表一個參數,然後以位運算的方式對參數進行取值和賦值操作。
機器只知道位元組,而字元卻是語義上的單位,它是有編碼的,一個字元可能編碼成1個2個甚至3個4個位元組。這跟字
符集編碼有關系,英文字母和數字是單位元組,但漢字這些自然語言中的字元是多位元組的。一個位元組只能表示255個字
符,不可能用於全球那麼多種自然語言的處理,因此肯定需要多位元組的存儲方式。而InputStream, OutputStream
它們是處理位元組流的,就是說假設所有東西都是二進制的位元組,而 Reader, Writer 則是字元流,它涉及到字元集
的問題;按照ANSI編碼標准,標點符號、數字、大小寫字母都佔一個位元組,漢字佔2個位元組。按照UNICODE標准所有
字元都佔2個位元組。