day03课堂笔记:
1、java采用全球统一的文字编码方式;unicode用-utf-8,utf-16,utf-16; 实现,实际开发中一般用utf-8。因此java代码中标识符可以用中文。
2、八种数据类型的取值范围
byte:-128-127
short:-32768-32767
int:-214474783648-2147483647
char:0-65535无负数
boolean:true/false
注意:short和char相比,char可以比short存更大的正数,因为char没有负数,所以正数的范围更大;
成员变量没有手动赋值时系统会自动赋值0,而局部变量不会自动赋值,故局部变量必须先声明再赋值才能访问。而成员变量不必声明时就赋值也能访问。
八种数据类型的默认值都是0;其中byte,short,int long 为0;float,double为0.0;boolean为false;char为\u0000
一个中文占用两个字节,而char类型恰好两个字节因此可以用char类型变量存储一个汉字。
1、char类型变量赋值时字面值用''括起来
char类型中的转义字符\(只转义紧接着的字母)
1、\n是换行public class day1学习笔记
{
char a='\n';
system.out.println(a);
}
编译通过后说明转义字符\n是两个字节
system.out.print()跟system.out.println()的区别是前者打印完不换行而后者打印完换行
2、\t是制表符,也就是打印一个tab的空白出来
3、控制台输出一个\,system.out.println('\\');前一个\具有转义功能,会将后面的\转义普通的”\“字符,而system.out.println('\')中\会将后面的'转义,故前一个’没有配对的引号,会报错。
4、输出一个普通的'字符,system.out.println('\'')这个程序中\将‘转义成不具备其他功能的普通’并打印输出。
5、输出一个"hello world"程序system.out.println('\"hello world\"')这里面\具有转义功能,会将特殊字符(比如”)转换成普通字符。
jdk中自带的native2ascii.exe命令(源文件在安装目录bin目录下),可以将文字装换成unicode编码形式;
语法:在命令行输入native2ascii,回车,然后输入文字回车即可得到uniccode编码
char n='\u得来的unicode编码';\u的作用是表示后面的一串字符是unicode编码。
system.out.println(n);
即可得到想要打印的文字
system.out.println('\u0000")输出的是空白
2、整数数据类型
1、java中的整数型字面值被默认当作int类型来处理,如果要设置整数型字面值当做long类型,则需要在整数型子面值后面添加l或者L建议使用大写的L
2、java语言当中的整数型有三种写法
第一种方式;十进制(缺省默认)
第二种方式:八进制(首位以0开始)
第三种方式:十六进制(以0x开始
例如int a=10;十进制
int a=010;八进制
int a=0x10;十六进制
但是打印他们进行输出时会自动转为十进制输出。
int i=123;表示默认为int类型的123赋值给int类型的i
long i=456;表示默认为int类型的123赋值给long类型的i,成为类型转换机制,小进制转换成大进制,是自动转换的不需要进行数据类型转换。
当long i=字面值;时,如果字面值超过int类型范围就会出错,因为这个数字超过了int范围,这与long的范围没有关系。
解决方式:long i=字面值L;这时加上了L就代表一开始的字面值就是long类型。
long x=100L;
int y=x;
编译不通过,因为大容量不能直接赋值给小容量,需要进行强制类型转换,编译通过后,可能会损失精度。
强转原理:00000000 00000000 00000000 00000000 00000000 00000000 00000000 01011110强制int转换后00000000 00000000 00000000 01011110,如果前四位有一位不是0则会损失精度
long x=100L;
int y=int(x);
如果00000000 00000000 00000000 00000000 10000000 00000000 00000000 00000000强制int转换后10000000 00000000 00000000 00000000,变成了负数;
对于byte数据类型有一个特殊;字面值只要没有超过byte的范围就无需转换数据类型,直接赋值
byte a=9;当中9是int数据类型但是不需要转换数据类型就可以可以直接赋值给byte类型的变量。
byte v=byte(a)进行byte类型的强制数据转换
byte a=198;
byte v=byte(a)强制类型转换:00000000 00000000 00000000 11000110转换为11000110这是一个补码,转换为原码后00111010位就是该数字58,这就使精度缺失。
3、char cc=65535;编译通过,按理说char类型是两个字节,大容量向小容量转换需要加强制运算符,但是没加也通过了。可以总结出;当一个数据的字面值不超过byte,short,char的范围时,可以不加高精度到低精度的强制类型转换符。
cc=65536编译报错
3、浮点型数据类型
float单精度4个字节
double双精度8个字节
double的精度(相对来说的)比较低,所以不是做财务软件,所以sun公司在基础se类库中定义了更高的精度的数据类型,他是java.math.BigDecimal
se类库原码位置:C:\Program Files\Java\jdk-13.0.2\lib\src.zip
在java当中所有的浮点型数据字面值都默认当作double型来处理。
要想该字面值赋给float型变量有两种方式:
第一种:float f=float(5.1);
第二种:float f=5.1F;
float,byte,int都可以直接赋值,因为方便编程,sun公司给了特殊权限,可以直接赋值。
4、布尔型数据类型
只有一个字节,经常使用在逻辑运算和条件控制语句当中,值只有0和1;
publid class datatypetest07
{
publid static void main(String[]args)
{
boolean loginsuccess=1;肯定会报错,底层的0和1用false和true表示。
}
}
5、八种数据类型的转换规则。
1、八中数据类型除了布尔型之外剩下的七种之间都可以相互转换。
2、小容量向大容量转换,称为自动类型转换,容量从小到大排序;
byte<short<int<long<float<double
char<
任何浮点数据不管占多少字节,都比整数型容量大。
char和short可表示的种类数量相同,但是char可以取更大的正整数。
3、大容量转小容量必须强制转换符,但是会损失精度,所以谨慎使用他。
4、在整数字面值没有超过byte,char,short的取值范围时,可以直接赋值给byte,short,char类型的变量。
5、byte,short,char混合运算(加减乘除与或非等等)时,各自先转换成int类型再做运算
6、多种数据类型的混合运算(加减乘除与或非等等),先转换成容量最大的那种类型再做运算。
注意int i=10;
byte b=i/3;会报错,编译器只检查语法,不会运算i/3,i/3后是int类型,无法赋值给byte类型变量。