008变量
变量介绍
变量是程序的基本组成单位。
变量有三个基本要素:类型+名称+值。
概念:变量是内存中一个数据存储空间的表示。
可以先声明变量在赋值,也可以边声明边赋值。
变量使用注意事项:
-
变量表示内存中的一个存储区域,不同的变量类型不同,占用的空间大小不同。
-
该区域有自己的名称和类型。
-
变量必须先声明,后使用。
-
该区域的数据可以再同一类型范围内不断变化。
-
变量在同一个作用域内不能重名。
-
变量 = 变量名 + 值 + 数据类型。
+号的使用
- 当左右两边都是数值型时,则做加法运算。
- 当左右两边有一方为字符串,则做拼接运算。
- 运算顺序从左到右。
System.out.println(100 + 98);//198
System.out.println("100" + 98);//10098
System.out.println(100 + 3 + "hello");//103hello
System.out.println("hello" + 100 + 3);//hello1003
数据类型
string不是基本数据类型,是类。
整数类型
整型的使用细节
-
Java各个整数类型有固定的的范围和字段长度,不受具体OS的影响,以保证 java 程序的可移植性。
-
java 的整型常量默认是int型,声明long型常量须后加 ‘l’ 或 ‘L’ 。
public class IntDetail{ //编写一个main方法 public static void main(String[] args) { //java 的整型常量默认是int型,声明long型常量须后加 'l' 或 'L' 。 int n1 = 2;//right int n2 = 2L;//wrong long n3 = 2L;//right } }
- java 程序中变量常声明为int型,除非不足以表示大数,才用 long 。
- bit:计算机中的最小存储单位。byte:计算机中基本存储单元,1 byte = 8 bit.
浮点类型
public class FloatDetail{
public static void main(String[] args) {
//Java的浮点型常量(具体值)默认为double型,声明float型常量,需在后面加'f'或者'F'
float num1 = 1.1;//wrong! 等式后面默认为双精度,赋值给单精度变量会有精度损失
float num2 = 1.1F;//right
double num3 = 1.1;//right
double num4 = 1.1f;//right
}
}
浮点数使用陷阱
public class FloatDetail{
public static void main(String[] args) {
//Java的浮点型常量(具体值)默认为double型,声明float型常量,需在后面加'f'或者'F'
//float num1 = 1.1; //wrong! 等式后面默认为双精度,赋值给单精度变量会有精度损失
float num2 = 1.1F;//right
double num3 = 1.1;//right
double num4 = 1.1f;//right
//浮点数陷阱 2.7和 8.1/3
double num5 = 2.7;
double num6 = 8.1 / 3;
System.out.println(num5);//2.7
System.out.println(num6);//2.6999999999999997
//得到一个重要的使用点:当我们对运算结果是小数的进行相等判断时,要小心。
//应该是以两个数的差值的绝对值,在某个精度范围内判断
//
//错误的写法
// if( num5 == num6 ){
// System.out.println("相等!");
// }
//
//
//正确的写法
if(Math.abs(num5 - num6) < 0.0000001){
System.out.println("相等!");
}
}
}
//注释快捷键 ctrl + /
字符类型
字符类型可以表示单个字符,字符类型是char,char是两个字节(可以存放汉字),多个字符我们用字符串String
//
public class CharDetail{
public static void main(String[] args) {
char c1 = 'a';
char c2 = '\t';
char c3 = '汉';
char c4 = 99; //字符类型可以存放一个数字
System.out.println(c1);
System.out.println(c2);
System.out.println(c3);
System.out.println(c4);//快捷键:ctrl + shift + D 复制光标所在的整行并粘贴到下一行
//删除整行 ctrl + shift + K ==》已经改成ctrl + K
}
}
字符类型使用细节
- 字符常量是用单引号 ( ‘’ ) 括起来的单个字符。
- Java中还允许使用转义字符 ‘\’ 来将其后的字符转变为特殊字符型常量。如 ‘\n’ 表示换行符。
- 在Java中,char的本质是一个整数,在输出时,是unicode码对应的字符。
- 可以直接给char赋一个整数,然后输出时,会按照对应的unicode字符输出。
- char类型是可以进行运算的,相当于一个整数,因为它都对应有unicode码。
public class CharDetail01{
public static void main(String[] args) {
char c1 = 97;
System.out.println(c1);//输出a
char c2 = 'a';
System.out.println((int)c2);//输出97
char c3 = '昉';
System.out.println((int)c3);//输出'昉'对应的数字
char c4 = 28881;
System.out.println(c4);//输出
//char类型是可以进行运算的,相当于一个整数,因为它都对应有unicode码。
System.out.println('a' + 10);//输出
//课堂测试
char c5 = 'b' + 1;
System.out.println((int)c5);//输出99
System.out.println(c5);//输出c(99对应的字符——>ASCII编码表)
}
}
字符类型本质探讨
-
字符型存储到计算机中,需要将字符对应的码值(整数)找出来,比如’a’
存储: ‘a’ ==> 码值 97 ==> 二进制(110 0001) ==>存储
读取:二进制(110 0001) ==> 97 ==> ‘a’ ==> 显示
-
字符和码值的对应关系是通过字符编码表决定的。
-
ASCII编码表(一个字节表示,一共128个字符,实际上一个字符可以表示256个字符,只用其中128个)。
Unicode(Unicode编码表,固定大小的编码,使用两个字节来表示字符,字母和汉字统一都是占用两个字节,这样浪费空间)。
utf-8 (编码表,大小可变的编码,字母占用1个字节,汉字占用3个字节,比GBK能用的中文字更多)。
GBK(可以表示汉字,而且范围广,字母1个字节,汉字两个字节)。
GB2312(可以表示汉字,GB2312 < GBK)。
BIG5码(繁体中文,台湾香港)。
布尔类型
boolean类型只能取true和false,占用一个字节,适用于逻辑运算。
不可以用0或者非0整数代替true和false,与C语言不同。
编码
ASCII编码表(一个字节表示,一共128个字符,实际上一个字符可以表示256个字符,只用其中128个)。
Unicode:将世界上所有文字纳入其中,浪费空间。使用Unicode没有乱码问题。所有字符统一都是占用两个字节。
utf-8 :可以理解为对Unicode的一种改进,大小可变。字母占用1个字节,汉字占用3个字节。
GBK(可以表示汉字,而且范围广,字母1个字节,汉字两个字节)。
GB2312(可以表示汉字,GB2312 < GBK)。
BIG5码(繁体中文,台湾香港)。
数据类型转换
public class AutoConvert{
public static void main(String[] args) {
//演示自动转换
int num = 'a';//char -> int
double d1 = 80;//int -> double
System.out.println(num);//97
System.out.println(d1);//80.0
}
}
自动类型转换注意和细节
- 当有多种类型的数据混合运算的时候,系统首先自动将所有数据都转换成容量最大的那一种数据类型,然后再进行计算。
- 当我们把精度大的那种数据类型赋值给精度小的数据类型时,就会报错,反之就会进行自动类型转换。
- (byte , short)和char之间不会相互自动转换。
- byte,short,char它们三者可以计算,在计算时都转换成int类型。
- boolean不参与转换。
- 自动提升原则:表达式结果的类型自动提升为操作数中最大的类型。
public class AutoConvertDetail{
public static void main(String[] args) {
//(1)当有多种类型的数据混合运算的时候,
//系统首先自动将所有数据都转换成容量最大的那一种数据类型,然后再进行计算。
int n1 = 10;//right
float d1 = n1 + 1.1;
//wrong 1.1是double n1->double 结果类型是double
//正确的两种写法
double d2 = n1 + 1.1;//right
float d3 = n1 + 1.1f;//right
//(2)当我们把精度大的那种数据类型赋值给精度小的数据类型时,就会报错,
//反之就会进行自动类型转换。
int n2 = 1.1;
//wrong
//(3)(byte , short)和char之间不会相互自动转换。
//当把一个数赋值给byte时,先判断该数是否在byte范围内,如果是就可以。
byte b1 = 10;//right -128~127
int n2 = 1;
byte b2 = n2;
//wrong 如果是变量赋值,类型判断
//char c1 = b1;
//wrong byte 不能自动转换成char
//
//(4)byte,short,char它们三者可以计算,在计算时都转换成int类型。
byte b2 = 1;
short s1 = 1;
short s2 = b2 + s1;
//wrong
//b2 + s1结果转换为int型 从int转成short会有精度损失
int s2 = b2 + s1;//right
byte b3 = b1 + b2; //wrong
//只要是byte型参与了运算,就会自动转换成int型
//从int转换成byte会有精度损失
//(5)boolean不参与转换。
boolean pass = true;
int num100 = pass;
//wrong
//(6)自动提升原则:表达式结果的类型自动提升为操作数中最大的类型。
byte b4 = 1;
short s3 = 100;
int num200 = 1;
double num300 = 1.1;
double num500 = b4 + s3 + num200 + num300;
//right
//num500只能是double型
}
}
强制类型转换
自动类型转换的逆过程,将容量大的数据类型转换成容量小的数据类型。使用时要加上强制类型转换符(),但可能造成精度降低或溢出,要格外注意。
public class ForceConvert{
public static void main(String[] args) {
int n1 = (int)1.9;
System.out.println(n1);//输出1 造成精度损失
int n2 = 2000;
byte b1 = (byte)n2;
System.out.println(b1);//输出-48 造成数据溢出
}
}
强制类型转换的细节
- 当进行数据的大小从大—>小的转换时,就需要用到强制类型转换。
- 强转符号只针对最近的操作数有效,往往用小括号提升优先级。
- char类型可以保存int的常量值,但不能保存int的变量值,需要强转。
- byte和short、char类型在进行运算时,当做int类型来处理。
public class ForceConvertDetail{
public static void main(String[] args) {
//演示强制类型转换
//
//(2)强转符号只针对最近的操作数有效,往往用小括号提升优先级。
int x = (int)10 * 3.5 + 6 * 1.5;//wrong
int y = (int)(10 * 3.5 + 6 * 1.5);//right
//(3)char类型可以保存int的常量值,但不能保存int的变量值,需要强转。
char c1 = 100;
int m = 100;
char c2 = m;//wrong
char c3 = (char)m;
System.out.println(c3);//输出d
}
}
练习题
基本数据类型和String类型的转换
1.基本数据类型转String类型:
方法: 将基本数据类型的值 + “” 即可。
2.String类型转基本数据类型:
方法:通过基本类型的包装调用parseXX方法即可。
public class StringToBasic{
public static void main(String[] args) {
//基本数据类型-->String
int n1 = 100;
float f1 = 1.1F;
double d1 = 4.5;
boolean b1 = true;
String s1 = n1 + "";
String s2 = f1 + "";
String s3 = d1 + "";
String s4 = b1 + "";
System.out.println(s1);
System.out.println(s2);
System.out.println(s3);
System.out.println(s4);
System.out.println(n1 + "" + f1 + d1 + b1);
System.out.println("========================================");
//String -->基本数据类型
String s5 = "25";
int num1 = Integer.parseInt(s5);
System.out.println(num1);
double num2 = Double.parseDouble(s5);
System.out.println(num2);
boolean b = Boolean.parseBoolean("true");
System.out.println(b);
long num3 = Long.parseLong(s5);
System.out.println(num3);
short num4 = Short.parseShort(s5);
System.out.println(num4);
byte num5 = Byte.parseByte(s5);
System.out.println(num5);
float num6 = Float.parseFloat(s5);
System.out.println(num6);
System.out.println(s5.charAt(1));//取出字符串“25”的第一位‘5’
}
}
3.怎么把字符串转换成一个字符:
得到字符串的一个字符
System.out.println(s5.charAt(1));//取出字符串“25”的第一位字符‘5’
基本数据类型和String类型转换的细节
-
在将String类型转换成基本数据类型时,要保证String类型能够转成有效的数据,比如我们可以把“123”转成一个整数,但不能把“hello”转成一个整数。
-
如果格式不正确,就会抛出异常,程序就会终止。