为什么需要变量
变量是程序的基本组成单位
变量的介绍
概念
变量相当于内存中的一个数据存储空间的表示,通过变量名可以访问到变量的值。
变量使用的基本步骤
声明变量
int a;
赋值
a = 60; //把60赋给a
使用System.out.println(a);
//也可以直接[int a = 60;]一步完成
变量快速入门
案例
变量注意事项
变量表示内存中的一个存储区域[不同的变量,类型不同,占用空间大小不同,比如:int4个字节,double就是8个字节]
该区域必须先申明,后使用,即有顺序
该区域的数据可以在同一类型范围内不断变化
变量在同一个作用域内不能重名
变量
程序中 + 的使用
当两边为数值类型时,做加法运算
当两边有一边是字符串,则做拼接运算
课堂测试题
运算从左到右
数据类型
每一种数据都定义了明确的数据类型,在内存中分配了不同大小的内存空间(字节)。
String属于类
整数类型
基本介绍
java的整数类型就是用来存放整数值记得,比如12,30等等
案例演示:
byte n1 = 10;
short n2 = 10;
区别:所占空间不同
整形类型
整型细节
java各整数类型有固定的范围和字段长度,不受具体OS[操作系统]影响,以保证java的可移植性。
java的整型常量默认为int型,声明long型常量须后加 'l' 或 'L'
java程序中变量常声明为int型,除非不足以表示大数,才使用long
bit:计算机中的最小存储单位。byte:计算机中基本存储单元,1byte = 8bit。
浮点类型
浮点类型分类
说明
关于浮点数在机器上存放形式的简单说明,浮点数=符号位+指数位+尾数位
位数部分可能丢失,造成精度损失(小数都是近似值)。
浮点型细节
与整数类型类似,java浮点型也有固定的范围和字段长度,不受OS影响
java的浮点类型默认是double型,声明float型需要后加 'f' 或 'F'
浮点型常量有两种形式
十进制形式:5.12 51.2f .521 (必须有小数点)
科学计数法形式:5.12e2[5.12 * 10的二次方] 5.12e-2[5.12 / 10的二次方]
通常情况下应当使用double型,因为比float型精确。
double num9 = 2.1234567851;
float num10 = 2.1234567851f;
浮点数使用陷阱
java API 文档
API (Application Programming Interface,应用程序编程接口)是java提供的基本编程接口(java提供的类还有相关方法)。中文在线文档:https://www.matools.com
java语言提供了大量的基础类,因此Oracle公司也为这些基础类提供了相应的API文档,用于告诉开发者如何使用这些类,以及这些类里包含的方法。
Java类的组织形式[图]
举例说明使用
安:包->类->方法
直接索引
字符类型
基本介绍
字符类型我们可以表示单个字符,字符类型是char,char是两个字节(可以存放汉字),多个字符我们用字符串String(后面再讲)
案例演示
char c1 = 'a';
char c2 = '\t';
char c3 = '汉';
char c4 = 97;
字符类型细节
字符常量用单引号( '' )括起来的字符。
java允许使用转义字符 '\' 来将其后的字符转变为特殊字符型常量例如 '\n'
在Java中,char的本质是一个整数,在输出时,是Unicode码对应字符。
可以直接给char赋一个整数,然后输出时,会按照对应的Unicode字符输出[97]
char类型是可以进行运算的,相当于一个整数,因为它都有对应的Unicode码。
字符类型的本质
字符型存储到计算机中,需要将字符对应的码值(整数)找出来,比如 'a'
存储:'a' ==> 码值 97 ==> 二进制(1100001) ==> 存储
读取:二进制(1100001) ==> 码值 97 ==> 'a' ==> 显示
字符和码值的对应关系是通过字符编码决定的(是规定好的)
字符编码表
ASCII:一个字节表示,一共128个字符,实际一个字节可以保存256个,只用了128个
Unicode:固定大小的编码,两个字节表示字符,字母和汉字统一都是占用两个字节,比较浪费空间
utf-8:大小可变的编码,字母使用1个字节,汉字使用3个字节
gbk:可以表示汉字,范围较广,字母使用1个字节,汉字使用2个字节
gb2312:可表示汉字,gb2312 < gbk
big5:繁体中文,台湾,香港
ASCII编码介绍
上世纪60年代,美国制定的一套字符编码,使用一个字节,对英语字符与二进制之间的关系做了统一规定。一共128个编码,只占用一个字符的后七位,第一位统一为0
缺点:不能表示所有字符
Unicode编码介绍
优点:世界上所有符号纳入其中。每一个符号都给予一个独一无二的编码,使用Unicode没有乱码问题。
缺点:一个英文字母和一个汉字都占用2个字节,造成空间浪费。
最多编码数是65536个字符
编码0-127的字符与ASCII编码一样,例如 'a' 在ASCII中是0x61,在unicode中是0x0061,都对应97。
UTF-8编码介绍
UTF-8是互联网上使用最多的一种Unicode的改进方式
UTF-8是一种变长的编码形式。它可以使用1-6个字节表示一个符号,根据不同的符号变化字节长度
使用大小可变的编码字母占1个字节,汉字占3个字节
布尔类型
基本介绍
布尔类型也叫Boolean类型,只允许取值true和flase,没有null
只用1个字节
适合用于逻辑运算,一般用于流程控制
if条件控制
while循环控制
do-while循环控制
for循环控制
案例演示
细节说明
不可以用0或非0整数替代false和true
基本类型数据转换
自动类型转换
介绍
当java程序进行赋值或者运算时,精度小的类型自动转换为精度大的数据类型,这个就是自动类型转换。
数据类型按精度大小顺序为
案例如下
int a = 'c'; //可以转换
double d = 80 //可以转换
注意和细节
有多种类型数据混合运算时,系统首先自动将所有数据转换成容量最大的那种数据,再进行计算。
当我们把精度大的数据赋值给精度小的数据类型时,就会报错,反之就会进行自动类型转换。
(byte、short)和char不能相互转换
byte、short、char他们三者可以计算,在计算时首先转换成int类型。
boolean不参与转换
自动提升原则:表达式结果的类型自动提升为操作数中最大的类型
代码
强制类型转换
介绍
自动类型转换的逆过程,将容量大的数据类型转换成容量小的数据类型。使用时要加上强制转换符(),但是可能造成精度降低或溢出,格外要注意。
案例演示
inti= (int)1,9;
System.out.println(i);
intj=100;
byteb1= (byte)j;
System.out.println(b1);
注意和细节
当数据的大小从大——> 小,就需要强制类型转换
强转符号只针对最近的操作数有效,往往需要小括号提升优先级
// int x = (int)10 * 3.5 + 6 * 1.5; // 没有意义,10本来就是int类型,输出结果仍是double
inty= (int)(10*3.5+6*1.5);
System.out.println(y);
char类型可以保存int的常量值,但不能保存int的变量值,需要强转
charc1=100;
intm=100;
// char c2 = m; // 错误
charc3= (char)m;
System.out.println(c3);
byte、short、char类型进行运算的时候,当作int类型处理。
代码
类型转换练习题
基本数据类型和String类型的转换
介绍
在程序开发中,我们经常需要将基本数据类型转换成String类型。或将String类型转换换成基本让你数据类型。
基本类型转String类型
语法:将基本类型的值 + "" 即可
String类型转基本类型
语法:通过基本类型的包装类调用parseXX方法即可
案例演示:
注意与细节
在将String类型转换成基本数据类型时,要确保String类型能够转成有效的数据,比如我们可以把"123",转成一个整数,但是不能把"hello"转成一个整数
如果格式不正确,就会抛出异常,程序终止。
代码同上