java数据类型02_基本数据类型

java是一种强类型语言,每个变量都必须声明其类型。

java的数据类型分为两大类:基本类型(primitive type)和引用类型(reference type)。
在这里插入图片描述

1. 整数型

整数型常量:

  • 十进制整数,例如:123,-100等

  • 八进制整数,要求以0开头,例如:015等

  • 十六进制整数,要求以0x或0X开头,例如:0x1A,0x15等

数据类型占用存储空间越大,那么表数的范围也就越大。在实际开发中,我们应该根据实际情况选用合适的的数值类型,避免出现超出表数范围的情况(一般情况下我们选用int类型)。

类型 占用存储空间 表数范围
byte 1字节 -2727-1(-128127)
short 2字节 -215215-1(-3276832767)
int 4字节 -231~231-1 (-2147483648~2147483647) 约21亿
long 8字节 -263~263-1

注意事项

  1. 注意数据类型的表数范围,避免出现超出表数范围精度丢失的情况。

  2. 整型常量默认为int类型,声明long型常量可以加“l”或“L”,建议使用“L”。

【扩展知识】

整型的范围与运行Java代码的机器无关,不需要针对不同的处理器选择最有效的整形。

2.浮点型

小数类型在Java中称为浮点类型。

浮点型常量:

  • 十进制数形式,例如:3.14 或 123.45

  • 科学计数法形式,例如:314E2代表31400.0或314E-2代表3.14

浮点类型分为float类型和double类型:

  1. float类型被称作单精度类型,尾数可以精确到7位有效数字,在很多情况下,float类型的精度很难满足需求。

  2. double类型被称作双精度类型,数值精度是float类型的两倍,绝大部分应用程序都采用double类型,浮点型常量默认为double类型。

类型 占用存储空间 表数范围
float 4字节 -3.403E38~3.403E38
double 8字节 -1.798E308~1.798E308

注意事项

1、 浮点型常量默认为double类型。

2、 浮点型常量赋值给float类型,需要在常量后面添加“f”或 “F”。

3、 避免直接比较两个浮点数的大小,这样比较可能会出现问题。

【扩展知识】

整数和浮点数在内存中的存储方式不一样,感兴趣的同学可以自行网上学习。

3.布尔型

boolean类型有两个值:true和false。true代表真,false代表假。

boolean类型用来判断逻辑条件,常用于程序流程控制。

【扩展知识】

在java规范中,没有明确指出boolean类型所占用的空间大小,深度解读可查阅这篇博文

4. 字符型

4.1字符型

字符型在内存中占有2个字节,在Java中使用单引号包裹起来的一个字符称之为字符常量。

例如‘A’是一个字符,它与“A”是不同的,“A”表示含有一个字符的字符串。

【示例】字符型使用

public static void main(String[] args) { 
	char c1 = 'a';  // 正确,声明并赋值一个'a'字符
	char c2 = '安'; // 正确,声明并赋值一个'安'字符
	char c3 = '8';  // 正确,声明并赋值一个'8'字符
	char c4 = '88'; // 错误,单引号只能包裹一个字符
	char c5 = '';   // 错误,单引号包裹的不能一个字符都没有
	char c6 = "安"; // 错误,字符只能用单引号包裹,双引号包裹的为字符串
}

补充:char类型表示的是Unicode编码表中的字符,所以可以表示一个中文字符。

char****类型和int类型的联系和区别

char类型常量在内存中存储的就是Unicode编码值,例如:‘A’— 65, ‘1’— 49。

在一定范围内,char类型和int类型是可以通用的。

【示例】char类型和int类型

public static void main(String[] args) { 
	char c1 = 'A'; // Unicode对应的数值为65
	System.out.println(c1 + 1);          // 输出:66
	char c2 = 97;  // Unicode对应的字符为'a'
	System.out.println((char)(c2 - 32)); // 输出:'A'
}

char类型和int类型区别:

1、 分配的内存空间不同,int类型占4个字节,char类型占用2个字节。

2、 数值表示的范围不同,int类型标识的范围比char类型更大,并且int类型还可以表示负数。

4.2字符集

我们知道计算机只能识别0或1,在计算机中储存的信息都是用二进制数表示的,数值型我们知道该如何转化为2进制然后存储在内存,那么字符型在内存中又是怎么来存储的呢?

本质上字符是没法直接转化为二进制的,我们在屏幕上看到的英文、汉字等字符都是二进制数转换之后的结果。

通俗来说,按照何种规则将字符存储在计算机中,我们称为"编码"。例如字符’A’我们可以用十进制65来表示,然后把十进制65转化为二进制后存储在内存中;

反之,将存储在计算机中的二进制数解析显示出来,称为"解码"。例如我们从内存中取值的时候,如果取出来的值为十进制65,那么就代表了我们取出来的数据为字符‘A’。

于是乎人类按照以上的“编码”和“解码”规则就创建出了各个语言与之对应的编码表。

字符在内存中的存取:

在这里插入图片描述

常见的字符编码表:

  • ASCII:美国信息交换标准代码,是基于拉丁字母的一套电脑编码系统,主要用于显示现代的英语和西欧语言的编码表。

  • GBK:全称《汉字内码扩展规范》,字库是用来表示中文用的编码。

  • Unicode:又称为万国码、统一码,是为了解决传统的编码方案的局限性而产生的,他为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。

Unicode编码,占2个字节,可允许有65536个字符,一个中文字符在内存中占用2个字节。

4.3转义字符

Java 语言中还允许使用转义字符来将其后的字符转变为其它的含义。

转义符 含义 Unicode值
\b 退格(backspace) \u0008
\n 换行 \u000a
\t 制表符(tab) \u0009
\” 双引号 \u0022
\’ 单引号 \u0027
\ 反斜杠 \u005c

ps:如需最新的免费文档资料和教学视频,请添加QQ群(627407545)领取。

发布了35 篇原创文章 · 获赞 0 · 访问量 372

猜你喜欢

转载自blog.csdn.net/zhoujunfeng121/article/details/104521756