8种基本数据类型
1-整型(4种)
长整型数值-后缀L : 40000000000L
十六进制-前缀0x : 0xCAFE
八进制-前缀0 : 010 (易混淆,少用)
java7开始:
二进制-前缀0b : 0b1001 = 9(十进制)
下划线易读机制 :1_000_000 = 1000000
2-浮点类型(2种)
char类型 (1种)
JAVA应尽量避免使用char类型,1个java的char字符并不完全等于一个unicode的字符。char采用的UCS-2编码,是一种淘汰的UTF-16编码,编码方式最多有65536种,远远少于当今Unicode拥有11万字符的需求。java只好对后来新增的Unicode字符用2个char拼出1个Unicode字符。导致String中char的数量不等于unicode字符的数量。
char在Oracle(数据库)中,是固定宽度的字符串类型(即所谓的定长字符串类型),长度不够的就会自动使用空格补全。因此,在一些特殊的查询中,就会导致一些问题,而且这种问题还是很隐蔽的,很难被开发人员发现。一旦发现问题的所在,就意味着数据结构需要变更,可想而知,这是多么大的灾难啊。
所以,一个unicode字符(代码点)在java中有的是用一个代码单元表示,有的是用两个代码单元表示。
String.length()
显示的是代码单元的数量。
要想知道字符串中代码点的数量,需要使用
int UnicodeCount = StringA.codePointCount(0,StringA.length())
StringA.charAt(n)
返回位置n的代码单元,当此位置位“半个Unicode字符时”容易出现乱码,或者?
string.offsetByCodePoints(0, i);
将返回第i个代码点的序号(从0编号),如果第i个代码点占有a,a+1两个代码单元将返回a+1.
随后我们可以通过StringcodePointat(序号)返回第i个代码点,单如果第i个代码点为双字符表示,此方法仍然不能显示该字符。
综上所述,我们应当尽量避免java中char类型的使用。
boolean类型(1种)
两种值- true 和 false