站長資訊網
最全最豐富的資訊網站

char類型要占幾個字節

char類型在C或C++中占1個字節,在java中占2個字節。char用于C或C++中是定義字符型變量的,而char數據類型是一種整數類型,只會占據1個字節。而在java中char類型占2個字節是因為Java編譯器默認使用Unicode編碼,因此2字節(16位)可以表示所有字符。

char類型要占幾個字節

本教程操作環境:windows7系統、Dell G3電腦。

我百度搜索“char占幾個字節”,得到下面的答案:

char類型要占幾個字節

char用于C或C++中定義字符型變量,是一種整數類型,只占一個字節,取值范圍為 -128 ~ +127(-27~27-1)。

char類型占1字節,就是8位,所能存儲的正整數是 0111 1111,即127。

顯然這不是我們想要的結果,于是我繼續搜索“java中的char占幾個字節”

char類型要占幾個字節

Java中的char用于存放字符的數據類型,占用2個字節,采用unicode編碼,它的前128字節編碼與ASCII兼容,只不過有些字符需要兩個char來表示。

為什么C或C++和java中的char占用字節數不相同?

有些字符需要兩個char來表示又是什么意思?

編碼

在討論這個問題之前,我們先對部分知識點做一下普及。

首先我們都知道計算機中儲存的信息都是用二進制數表示的,那怎么樣讓計算機存儲我們人類用的漢字或英文呢?

比如如何將'a'轉換為二進制存儲到計算機中,稱為編碼

而將存儲在計算機中的二進制數解析顯示出來,稱為解碼

字符集

字符(Character)是各種文字和符號的總稱,包括各國家文字、標點符號、圖形符號、數字等。字符集(Character set)是多個字符的集合,字符集種類較多,每個字符集包含的字符個數不同,常見字符集名稱:ASCII字符集、GB2312字符集、BIG5字符集、 GB18030字符集、Unicode字符集等。這是百度百科給的解釋,反正就是字符集是一些字符的集合,字符集種類多,字符集中的字符數量也各不相同。計算機要準確的處理各種字符集文字,需要進行字符編碼,以便計算機能夠識別和存儲各種文字。

unicode

它的名字叫統一碼, 也叫萬國碼,符號數量在不斷增加,已超百萬 。

在創造Unicode之前,有數百種編碼系統。沒有一個編碼可以包含足夠的字符,從它的名字就可以看出這是一種所有符號的編碼,每一個符號都給予一個獨一無二的編碼,那么各個不同編碼導致的亂碼問題就會消失。

大多數計算機采用ASCII碼(美國標準信息交換碼),它是表示所有大小寫字母、數字、標點符號和控制字符的7位編碼方案。統一碼(Unicode)包含ASCII碼,'u0000'到'u007F'對應全部128個ACSII字符。

不禁讓我感慨,有實力的人才能制定標準。 Unicode 只是一個符號集,它只規定了符號的二進制代碼,僅僅提供字符與編號間映射,卻沒有規定這個二進制代碼應該如何存儲。 我們知道英文字母的編號特別小,用一個字節就完全能夠表示,而unicode中的中文符號的編號就很大了,一個字節根本不行。 于是后面出現了unicode字符存儲的多種實現方式,比如UTF-8,UTF-16等。 UTF-8 是在互聯網上使用最廣的一種 Unicode 的實現方式。

內碼和外碼

我們常說的java中的char占幾個字節,應該是java中內碼中的char。

內碼是指java運行時,其char和string在內存中的編碼方式;外碼是程序與外部交互時外部使用的字符編碼,比如序列化技術。 外碼可以理解為:只要不是內碼,那就是外碼。 要注意的是,源代碼編譯產生的目標代碼文件(可執行文件或class文件)中的編碼方式屬于外碼。 JVM中內碼采用UTF16。 UTF-16 的 16 指的就是最小為 16 位一個單元,也即兩字節為一個單元。早期,UTF16采用固定長度2字節的方式編碼,兩個字節可以表示65536種符號(其實真正能表示要比這個少),足以表示當時unicode中所有字符。但是隨著unicode中字符的增加,2個字節無法表示所有的字符,UTF16采用了2字節或4字節的方式來完成編碼。Java為應對這種情況,考慮到向前兼容的要求,Java用一對char來表示那些需要4字節的字符。所以,java中的char是占用兩個字節,只不過有些字符需要兩個char來表示。 這里就解釋了為什么有些字符需要兩個char來表示的問題。

另外:Java的class文件采用UTF8來存儲字符,也就是說,class中字符占1~6個字節。 Java序列化時,字符也采用UTF8編碼,占1~6個字符。

length()

那再來一個問題:Java中的一個字符的String.length()是多少?

看過前面的知識點不能再張嘴就來回答是1吧…… 寫個demo看一下:虎年就用虎來測試吧,tigerUTF對對應unicode編碼表示。

         String tiger = "?";          String tigerUTF = "uD83DuDC05";          System.out.println(tigerUTF);          System.out.println(tiger.length());           System.out.println(tiger.codePointCount(0,tiger.length()));
登錄后復制

char類型要占幾個字節char類型要占幾個字節

可以得出調用String.length()得到的結果為2,表示的是stirng的char數組占UTF-16格式的2個代碼單元(即4個字節),而不是有多少個字符。 當然我們想要獲取多少個字符,可以使用codePointCount方法來獲取。

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
国产精品成人va在线观看入口| 国产麻豆精品原创| 精品国产国产综合精品| 中文字幕日韩精品无码内射| 国内精品国语自产拍在线观看91| 精品少妇ay一区二区三区| 久久久午夜精品理论片| 亚洲精品蜜桃久久久久久| 精品人妻伦九区久久AAA片69| 日韩中文有码高清| 亚洲日韩中文在线精品第一| 国产精品特黄毛片| 好吊操这里只有精品| 久久精品国产亚洲AV未满十八| 国产福利91精品一区二区三区| 2021国产精品自产拍在线观看| 久久久久久夜精品精品免费啦| 久久久久久久99精品国产片| 麻豆精品久久精品色综合| 日韩精品亚洲aⅴ在线影院| 久久久久九国产精品| 国产三级精品三级在专区| 国产精品国产三级国产潘金莲| 亚洲äv永久无码精品天堂久久 | 亚洲第一永久AV网站久久精品男人的天堂AV | 国产精品亚洲一区二区麻豆| 99久久精品日本一区二区免费| 国产99视频精品一区| 国产精品福利一区二区久久| 成人三级精品视频在线观看| 2021国内精品久久久久久影院| 99久久做夜夜爱天天做精品| 亚洲爆乳精品无码一区二区 | 欧美日韩色另类综合| 第四色播日韩第一页| 日产国产精品亚洲系列| 日本一区二区三区精品国产| 亚洲精品无码AV中文字幕电影网站| 国产精品一区12p| 二区久久国产乱子伦免费精品| 日韩人妻无码精品专区|