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类型变量。