您的位置 首页 java

自学Java笔记_day02_第二章 Java的基础语法

2.1 标识符(了解)

简单的说,凡是程序员自己命名的部分都可以称为标识符。

即给类、变量、方法、包等命名的字符序列,称为标识符。

1、标识符的命名规则(重要)

(1)标识符可以包含 英文字母 26个(区分大小写) 、 0 -9数字 、 $ (美元符号) 和 _ (下划线) 。

(2)标识符不能以数字开头。

(3)标识符不能是关键字。

2、标识符的命名规范(了解)

(1)见名知意

(2)类名、接口名等:每个单词的首字母都大写,形式:XxxYyyZzz,

例如:HelloWorld,String,System等

(3)变量、方法名等:从第二个单词开始首字母大写,其余字母小写,形式:xxxYyyZzz,

例如:age,name,bookName,main

(4)包名等:每一个单词都小写,单词之间使用点.分割,形式:xxx.yyy.zzz,

例如:java.lang

(5)常量名等:每一个单词都大写,单词之间使用下划线_分割,形式:XXX_YYY_ZZZ,

例如:MAX_VALUE,PI

2.2 变量

2.2.1 变量的概念

变量的作用:用来存储数据,代表内存的一块存储区域,变量中的值是可以改变的。

2.2.2 变量的三要素(重要)

1、数据类型

2、变量名

3、值

2.2.3 变量的使用应该注意什么?(了解)

1、先声明后使用

2、在使用之前必须初始化

如果没有初始化,会报“未初始化”错误

3、变量有作用域

如果超过作用域,也会报“找不到符号”错误

4、在同一个作用域中不能重名

2.2.4 变量的声明和赋值、使用的语法格式?(了解)

1、变量的声明的语法格式:

 	数据类型  变量名;
例如:
int age;
String name;
......  

2、变量的赋值的语法格式:

 变量名 = 值;
例如:
age = 18;
name = "柴林燕"; //字符串的值必须用""
........  

3、变量的使用的语法格式:

 通过变量名直接引用
例如:
(1)输出变量的值
System.out.print("姓名:" + name);//""中的内容会原样显示
(2)计算
age = age + 1;  

2.3 数据类型

2.3.1 Java数据类型的分类(重要)

1、基本数据类型

​ 8种:整型系列( byte , short ,int, long )、浮点型( float , double )、单字符型(char)、布尔型( boolean

建议根据字节大小排序记忆,方便后续自动转换。

记忆: byte –> short == char –> int –> long –> float –> double –> boolean

2、引用数据类型

​ 类、接口、数组、枚举…..

2.3.2 Java的基本数据类型

自学Java笔记_day02_第二章 Java的基础语法

数据类型表结构图

1、整型系列

(1)byte:字节类型,占内存:1个字节,存储范围:-128~127

(2)short:短整型类型 , 占内存:2个字节 , 存储范围:-32768~32767

(3)int:整型 , 占内存:4个字节 , 存储范围:-2的31次方 ~ 2的31次方-1

(4)long:整型 , 占内存:8个字节 , 存储范围:-2的63次方 ~ 2的63次方-1

注意:如果要表示某个常量数字它是long类型,那么需要在数字后面加L

2、浮点型系列(小数)

(1)float:单精度浮点型 , 占内存:4个字节 , 精度:科学记数法的小数点后6~7位

注意:如果要表示某个常量数字是float类型,那么需要在数字后面加F或f

(2)double:双精度浮点型 , 占内存:8个字节 , 精度:科学记数法的小数点后15~16位

注意:如果要表示某个常量数字是double类型,那么需要在数字后面加D或d

3、单字符类型

char:字符类型 , 占内存:2个字节 , Java中使用的字符集:Unicode编码集

自学Java笔记_day02_第二章 Java的基础语法

Unicode编码表

字符的三种表示方式:

(1)’一个字符’

例如:’A’,’0’,’尚’

(2)转义字符

 n:换行
r:回车
t:Tab键
:
":”
':
b:删除键Backspace  

(3)u字符的Unicode编码值的十六进制型

例如:u5c1a代表’尚’

4、布尔类型

boolean:只能存储true或 false

2.3.3 进制(了解,可以暂时忽略)

1、进制的分类:(了解,可以暂时忽略)

(1)十进制

​ 数字组成:0-9

​ 进位规则:逢十进一

(2) 二进制

​ 数字组成:0-1

​ 进位规则:逢二进一

(3) 八进制

​ 数字组成:0-7

​ 进位规则:逢八进一

(4)十六进制

​ 数字组成:0-9,a~f(或A~F)

​ 进位规则:逢十六进一

2、进制的表示形式,亦10为例:(了解,可以暂时忽略)

(1)十进制:正常表示 : System.out.println(10);

(2)二进制:0b或0B开头 : System.out.println(0B10);

(3)八进制:0开头 : System.out.println(010);

(4)十六进制:0x或0X开头 : System.out.println(0X10);

3、进制之间的互相转化(理解)

3.1.十进制转二进制

自学Java笔记_day02_第二章 Java的基础语法

十进制转二进制

自学Java笔记_day02_第二章 Java的基础语法

十进制小数转二进制

3.2.二进制转八进制

自学Java笔记_day02_第二章 Java的基础语法

二进制转八进制

3.3.八进制转十进制

自学Java笔记_day02_第二章 Java的基础语法

八进制转十进制

4、扩展内容:为什么byte是-128~127?(理解)

1个字节:8位

0000 0001 ~ 0111 111 ==> 1~127

1000 0001 ~ 1111 1111 ==> -127 ~ -1

0000 0000 ==>0

1000 0000 ==> -128(特殊规定)

————>

解释:计算机数据的存储(了解)

计算机数据的存储使用二进制补码形式存储,并且最高位是符号位,1是负数,0是正数。

规定:正数的补码与反码、 原码 一样,称为三码合一;

​ 负数的补码与反码、原码不一样:

​ 负数的原码:把十进制转为二进制,然后最高位设置为1

​ 负数的反码:在原码的基础上,最高位不变,其余位取反(0变1,1变0)

​ 负数的补码:反码+1

例如:byte类型(1个字节,8位)

25 ==> 原码 0001 1001 ==> 反码 0001 1001 –>补码 0001 1001

-25 ==>原码 1001 1001 ==> 反码1110 0110 ==>补码 1110 0111

底层是用加法代替减法:-128==》-127-1==》-127+(-1)

​ -127- -1 ==> -127 + 1

4、学生疑惑解答?(理解)

(1)为什么float(4个字节)比long(8个字节)的存储范围大?

(2)为什么double(8个字节)比float(4个字节)精度范围大?

因为float、double底层也是二进制,先把小数转为二进制,然后把二进制表示为科学记数法,然后只保存:

(1)符号位(2)指数位(3)尾数位

详见《float型和double型数据的存储方式.docx》

2.3.4 基本数据类型的转换

1、自动类型转换

(1)概念:把存储范围小的值(常量值、变量的值、表达式计算的结果值)赋值给了存储范围大的变量.顺序图如下:

byte->short->int->long->float->double

​ char->

 int i = 'A';//char自动升级为int
double d = 10;//int自动升级为double  

(2)当存储范围小的数据类型与存储范围大的数据类型一起混合运算时,会按照其中最大的类型运算

 int i = 1;
byte b = 1;
double d = 1.0;
​
double sum = i + b + d;//混合运算,升级为double  

(3)当byte,short,char数据类型进行算术运算时,会按照int类型处理

 byte b1 = 1;
byte b2 = 2;
byte b3 = (byte)(b1 + b2);//b1 + b2自动升级为int
​
char c1 = '0';
char c2 = 'A';
System.out.println(c1 + c2);//113   

(4)boolean类型不参与

2、强制类型转换

(1)当把存储范围大的值(常量值、变量的值、表达式计算的结果值)赋值给了存储范围小的变量时,需要强制类型转换。顺序图如下:

double->float->long->int->short->byte

​ ->char

提示:强制转换有风险,可能会损失精度或溢出

 double d = 1.2;
int num = (int)d;//损失精度
​
int i = 200;
byte b = (byte)i;//溢出  

(2)boolean类型不参与

(3)当某个值想要提升数据类型时,也可以使用强制类型转换

 int i = 1;
int j = 2;
double shang = (double)i/j;  

提示:这个情况的强制类型转换是没有风险的。

2.3.5 特殊的数据类型转换(扩展知识)

1、任意数据类型的数据与String类型进行“+”运算时,结果一定是String类型(重要理解)

 System.out.println("" + 1 + 2);//12  

2、但是String类型不能通过强制类型()转换,转为其他的类型(重要理解)

 String str = "123";
int num = (int)str;//错误的  

2.4 运算符

1、按照操作数个数的分类:

(1)一元运算符:操作数只有一个

例如:正号(+),负号(-),自增(++),自减(–),逻辑非(!),按位取反(~)

(2)二元运算符:操作数有两个

例如:加(+),减(-),乘(*),除(/),模(%)

​ 大于(>),小于(<),大于等于(>=),小于等于(<=),等于(==),不等于(!=)

​ 赋值(=,+=,-=,*=,/=,%=,>>=,<<=。。。)

​ 逻辑与(&),逻辑或(|),逻辑异或(^),短路与(&&),短路或(||)

​ 左移(<<),右移(>>),无符号右移(>>>),按位与(&),按位或(|),按位异或(^)

(3)三元运算符:操作数三个

例如: ? :

2、Java基本数据类型的运算符:

(1) 算术运算符

(2)赋值运算符

(3)比较运算符

(4)逻辑运算符

(5)条件运算符

(6)位运算符(难)

2.4.1 算术运算符

加法:+

减法:-

乘法:*

除法:/

注意:整数与整数相除,只保留整数部分

取模:% 取余

注意:取模结果的正负号只看被模数

正号:+

负号:-

自增:++

自减:–

原则:自增与自减

++/–在前的,就先自增/自减,后取值

++/–在后的,就先取值,后自增/自减

整个表达式的扫描,是从左往右扫描,如果后面的先计算的,那么前面的就暂时先放到“操作数栈”中

++/–在前代码示例:

自学Java笔记_day02_第二章 Java的基础语法

++/–在后示例:

自学Java笔记_day02_第二章 Java的基础语法

 int i = 1;
System.out.println(i++); //1
System.out.println(i)
int j = 1;
++j;//j=2
​
int a = 1;
int b = a++;//(1)先取a的值“1”放操作数栈(2)a再自增,a=2(3)再把操作数栈中的"1"赋值给b,b=1
​
int m = 1;
int n = ++m;//(1)m先自增,m=2(2)再取m的值“2”放操作数栈(3)再把操作数栈中的"2"赋值给n,n=1
​
int i = 1;
int j = i++ + ++i * i++;
/*
从左往右加载
(1)先算i++
①取i的值“1”放操作数栈
②i再自增 i=2
(2)再算++i
①i先自增 i=3
②再取i的值“3”放操作数栈
(3)再算i++
①取i的值“3”放操作数栈
②i再自增 i=4
(4)先算乘法
用操作数栈中3 * 3 = 9,并把9压会操作数栈
(5)再算求和
用操作数栈中的 1 + 9 = 10
(6)最后算赋值
j = 10
*/  

2.4.2 赋值运算符

基本赋值运算符:=

扩展赋值运算符:+=,-=,*=,/=,%=…

注意:所有的赋值运算符的=左边一定是一个变量

扩展赋值运算符=右边的计算结果的类型如果比左边的大的话会强制类型转换,所以结果可能有风险。

扩展赋值运算符的计算:(1)赋值最后算(2)加载数据的顺序是把左边的变量的值先加载,再去与右边的表达式进行计算

 
int i = 1;
int j = 5;
j *= i++ + j++;//j = j *(i++ + j++);
/*
(1)先加载j的值“5”
(2)在计算i++
①先加载i的值“1”
②再i自增,i=2
(3)再计算j++
①先加载j的值"5"
②再j自增,j=6
(4)算  加法
i + 5 = 6
(5)算乘法
5 * 6 = 30
(6)赋值
j = 30
*/  

2.4.3 比较运算符

大于:>

小于:<

大于等于:>=

小于等于:<=

等于:== 注意区分赋值运算符的=

不等于:!=

注意:比较表达式的运算结果一定只有true/false

比较表达式可以作为(1)条件(2)逻辑运算符的操作数

2.4.4 逻辑运算符

逻辑运算符的操作数必须是布尔值,结果也是布尔值

逻辑与:&

 
运算规则:只有左右两边都为true,结果才为true。
例如:true & true 结果为true
       false & true 结果为false
        true & false 结果为false
        false & false 结果为false  

逻辑或:|

 
运算规则:只要左右两边有一个为true,结果就为true。
例如:true | true 结果为true
       false | true 结果为true
       true | false 结果为true
        false | false 结果为false    

逻辑异或:^

 
运算规则:只有左右两边不同,结果才为true。
例如:true ^ true 结果为false
        false ^ true 结果为true
        true ^ false 结果为true
        false ^ false 结果为false            

逻辑非:!

 
运算规则:布尔值取反
例如:!true 为false
        !false 为true  

短路与:&&

 
运算规则:只有左右两边都为true,结果才为true。
例如:true & true 结果为true
        true & false 结果为false
        false & ?  结果就为false
它和逻辑与不同的是当&&左边为false时,右边就不看了。  

短路或:||

 
运算规则:只要左右两边有一个为true,结果就为true。
例如:true | ? 结果为treu
       false | true 结果为true
        false | false 结果为false  
它和逻辑或不同的是当||左边为true时,右边就不看了。  

开发中一般用短路与和短路或比较多

面试题:&& 和 &的区别?

&&当左边为false,右边不计算

&不管左边是true还是false,右边都要计算

2.4.5 条件运算符

? :

语法格式:

 
条件表达式 ? 结果表达式1 : 结果表达式2  

运算规则:

整个表达式的结果:当条件表达式为true时,就取结果表达式1的值,否则就取结果表达式2的值

代码示例:

 
(1)boolean类型
boolean marry = true;
System.out.println(marry? "已婚" : "未婚");
​
(2)求最值
int i = 3;
int j = 5;
int max = i>=j ? i : j;
//当i>=j时,max就赋值为i的值,否则就赋值为j的值  

2.4.6 位运算符

左移:<<

​ 运算规则:左移几位就相当于乘以2的几次方

右移:>>

​ 运算规则:右移几位就相当于除以2的几次方

无符号右移:>>>

​ 运算规则:往右移动后,左边空出来的位直接补0,不看符号位

按位与:&

​ 运算规则:

​ 1 & 1 结果为1

​ 1 & 0 结果为0

​ 0 & 1 结果为0

​ 0 & 0 结果为0

按位或:|

​ 运算规则:

​ 1 | 1 结果为1

​ 1 | 0 结果为1

​ 0 | 1 结果为1

​ 0 & 0 结果为0

按位异或:^

​ 运算规则:

​ 1 ^ 1 结果为0

​ 1 ^ 0 结果为1

​ 0 ^ 1 结果为1

​ 0 ^ 0 结果为0

按位取反:~

​ 运算规则:~0就是1

​ ~1就是0

如何区分&,|,^是逻辑运算符还是位运算符?

如果操作数是boolean类型,就是逻辑运算符,如果操作数是整数,那么就位运算符。

2.4.7 运算符优先级

提示说明:

(1)表达式不要太复杂

(2)先算的使用()

2.4.8 运算符操作数类型说明

1、算术运算符

数字和单个字符可以使用算术运算符。

其中+,当用于字符串时,表示拼接。

2、赋值运算符

右边的常量值、表达式的值、变量的值的类型必须与左边的变量一致或兼容(可以实现自动类型转换)或使用强制类型转换可以成功。

3、比较运算符

其他的比较运算符都是只能用于8种基本数据类型。

其中的==和!=可以用于引用数据类型的比较,用于比较对象的地址。(后面讲)

 
int i = 10;
int j = 10;
System.out.println(i==j);//true
​
char c1 = '帅';
char c2 = '帅';
System.out.println(c1 == c2);//true  

4、逻辑运算符

逻辑运算符的操作数必须是boolean值

5、条件运算符

?前面必须是条件,必须是boolean值

结果表达式1和结果表达式2要保持类型一致或兼容

6、位运算符

一般用于整数系列

以上运算符都是针对基本数据类型设计的。

能够用于引用数据类型只有基本的赋值运算符=,和比较运算符中的==和!=。其他运算符都不能用于引用数据类型。

其中字符串类型还有一个+,表示拼接

文章来源:智云一二三科技

文章标题:自学Java笔记_day02_第二章 Java的基础语法

文章地址:https://www.zhihuclub.com/181751.shtml

关于作者: 智云科技

热门文章

网站地图