Java语言由关键字,标识符,注释,常亮和变量,运算符,语句,函数,和数组组成
重要的知识点
“&”和“&&”的区别:
单&时,左边无论真假,右边都进行运算;
双&时,如果左边为真,右边参与运算,如果左边为假,那么右边不参与运算。
“|”和“||”的区别同理,双或时,左边为真,右边不参与运算。
异或( ^ )与或( | )的不同之处是:当左右都为true时,结果为false。
单&时,左边无论真假,右边都进行运算;
双&时,如果左边为真,右边参与运算,如果左边为假,那么右边不参与运算。
“|”和“||”的区别同理,双或时,左边为真,右边不参与运算。
异或( ^ )与或( | )的不同之处是:当左右都为true时,结果为false。
我之前学过一点C语言,在使用java时发现一个问题很让我困扰
int a=0,b=0; for (int i=0; i<3; i++) { a = a++; System.out.println(a); }C语言中是可以这样赋值的,而java中不可以,a的值会一直是0
我当时很疑惑,之后查了资料才明白
在Java中,
a=a++;
相当于
int b=a++;
a=b;
在C中
a=a++;
相当于
a=a;
a++;
a=a++;
相当于
int b=a++;
a=b;
在C中
a=a++;
相当于
a=a;
a++;
因此java中不可以这样赋值,必须b=a++,或者单独一个a++
1-1 关键字
什么是关键字
定义:被Java语言赋予了特殊含义的单词。
特点:关键字中所有字母都为小写。
1-2 标识符
定义:在程序中自定义的一些名称。
特点:由26个英文字母大小写,数字:0-9,符号:_ $ 组成。
定义合法标识符规则:
1、数字不可以开头。
2、不可以使用关键字。
注意:
1、Java中严格区分大小写。
2、在起名字的时,为了提高阅读性,要尽量有意义。
3、公司中经常会通过“_”代表某一类名称,例如:_temp。
通过“$”代表外部类与内部类的关系(后面会讲到),例如:TrafficLamp$Red。
Java中的名称规范:
包名:多单词组成时所有字母都小写。
例如:xxxyyyzzz
com.itheima.xuruihang
类名接口名:多单词组成时,所有单词的首字母大写。
例如:XxxYyyZzz
class XuRuiHang {}
变量名和函数名:多单词组成时,第一个单词首字母小写,第二个单词开始每个单词首字母大写。
例如:xxxYyyZzz xuRuiHang()
常量名:所有字母都大写。多单词时每个单词用下划线连接。
例如:XXX_YYY_ZZZ XU_RUI_HANG = 3;
1-3 注释
定义
:
用于注解说明解释程序的文字就是注释。
特点:
提高了代码的阅读性。
Java中的注释格式:
单行注释
格式: //注释文字
多行注释
格式: /* 注释文字 */
文档注释
格式:/** 注释文字 */
注意:
1、对于单行和多行注释,被注释的文字,不会被JVM(java虚拟机)解释执行。
2、对于文档注释,是java特有的注释,其中注释内容可以被JDK提供的工具 javadoc 所解析,生成一套以网页文件形式体现的该程序的说明文档。
2、对于文档注释,是java特有的注释,其中注释内容可以被JDK提供的工具 javadoc 所解析,生成一套以网页文件形式体现的该程序的说明文档。
3、注释是一个程序员必须要具有的良好编程习惯。初学者编写程序可以养成习惯:先写注释再写代码。
4、将自己的思想通过注释先整理出来,在用代码去体现。因为代码仅仅是思想的一种体现形式而已。
4、将自己的思想通过注释先整理出来,在用代码去体现。因为代码仅仅是思想的一种体现形式而已。
5、单行注释可以嵌套单行注释,单行注释可以嵌套多行注释,多行注释可以嵌套单行注释。
但是,多行注释不能嵌套多行注释,因为多行注释的开头会和被嵌套的多行注释的结尾配对,导致后面的注释失效。
6、可以使用注释对代码中的错误进行定位。
1-4 常量
定义:
常量表示不能改变的数值。
Java中常量的分类:
1、整数常量,所有整数。
2、小数常量,所有小数。
3、布尔(boolean)型常量,只有两个数值。true、false。
4、字符常量,将一个数字字母或者符号用单引号( ' ' )标识。
5、字符串常量,将一个或者多个字符用双引号("")标识。
6、null常量,只有一个数值就是:null。
5、字符串常量,将一个或者多个字符用双引号("")标识。
6、null常量,只有一个数值就是:null。
对于整数,有三种表现形式:
八进制:0-7,满8进1,用0开头表示。
十进制:0-9,满10进1。
十六进制:0-9,A-F,满16进1,用0x开头表示。
八进制:0-7,满8进1,用0开头表示。
十进制:0-9,满10进1。
十六进制:0-9,A-F,满16进1,用0x开头表示。
进制的由来:
任何数据在计算机中都是以二进制的形式存在的。二进制早期由电信号开关演变而来。
一个整数在内存中一样也是二进制的,但是使用一大串的1或者0组成的数值进行使用很麻烦。
一个整数在内存中一样也是二进制的,但是使用一大串的1或者0组成的数值进行使用很麻烦。
所以就想把一大串缩短点,将二进制中的三位用一位表示。这三位可以取到的最大值就是7,超过7就进位了,这就是八进制。
但是对于过长的二进制变成八进制还是较长,所以出现的用4个二进制位表示一位的情况,四个二进制位最大是15,这就是十六进制。
规律:进制越大,表现形式越短。
附:进制的基本转换
①十进制 二进制 互转
例如:
1011 = 1*2(0)+1*2(1)+0*(2)+1*2(3)= 1 + 2 + 0 + 8 = 11
附:括号中的数值代表次方。
②十进制 八进制 互转
例如:
十进制 43
二进制 0101011
三位分割 010-101-110
八进制 2 5 6
三位分割 010-101-110
八进制 2 5 6
因此,0101011 = 0256
结论:
八进制,其实就是二进制位,3个二进制位,1个八进制位。
八进制,其实就是二进制位,3个二进制位,1个八进制位。
十进制 43
二进制 0101011
四位分割 1010-1110
十六进制 10(A) 14(E)
四位分割 1010-1110
十六进制 10(A) 14(E)
因此,0101011 = 0AE
结论:
十六进制,其实就是二进制位,4个二进制位,1个十六进制位。
十六进制,其实就是二进制位,4个二进制位,1个十六进制位。
负数的二进制表现形式:
对应的正数二进制取反加1。
对应的正数二进制取反加1。
求-6的二进制表现形式:对应的正数6二进制取反加1。
0000-0110
取反 1111-1001
加1+0000-0001
-----------------
1111-1010
注意:
负数的二进制最高位永远是1。
1-5 变量
定义:内存中的一个存储区域,该区域有自己的名称(变量名)和类型(数据类型),该区域的数据可以在同一类型范围内不断变化。
用来不断的存放同一类型的常量,并可以重复使用。
用来不断的存放同一类型的常量,并可以重复使用。
特点:变量其实就是将不确定的数据进行存储。也就是需要在内存中开辟一个空间。
定义变量的格式:
数据类型 变量名 = 初始化值;
例如:byte b = 3;
注意:
1、格式是固定的,记住格式,以不变应万变。
2、变量的作用范围(一对{}之间有效)。
变量就如同数学中的未知数X。
Java语言是强类型语言,对于每一种数据都定义了明确的具体数据类型,在内存总分配了不同大小的内存空间。
数据类型包括8种基本类型,3种引用类型。
共有八种基本数据类型
double 8字节,boolean true/false,
char 2字节
1-6 类型转换
自动类型转换(也叫隐式类型转换)强制类型转换(也叫显式类型转换)
类型转换的原理
什么时候要用强制类型转换?
表达式的数据类型自动提升
所有的byte型、short型和char的值将被提升到int型。
如果一个操作数是long型,计算结果就是long型;
如果一个操作数是float型,计算结果就是float型;
如果一个操作数是double型,计算结果就是double型。
分析
System.out.println(‘a’)与System.out.println(’a’+1) 的区别。
‘a’是一个char类型数据,前面一句会直接打印a,而后面一句由于被提升到int型,a在ASCII表中是97,97+1为98。
自动类型提升
byte b = 3;
int x = 4;
x = x + b;//b会自动提升为int类型进行运算。
强制类型转换
byte b = 3;
b = b + 4;//报错
b = (byte)b+4;//强制类型转换,强制将b+4的结果转换为byte类型,再赋值给b。
思考:
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
byte b = 3;
int x = 4;
x = x + b;//b会自动提升为int类型进行运算。
强制类型转换
byte b = 3;
b = b + 4;//报错
b = (byte)b+4;//强制类型转换,强制将b+4的结果转换为byte类型,再赋值给b。
思考:
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
哪句是编译失败的呢?为什么呢?
b=3+4 ,3和4都是常量,所以java在编译时期会检查该常量的和是否超出byte类型的范围。如果没有可以赋值。
b=b1+b2不可以,是因为b1和b2是变量,因为变量的值会变化,不确定具体的值,所以默认使用int类型进行存储。
b=b1+b2不可以,是因为b1和b2是变量,因为变量的值会变化,不确定具体的值,所以默认使用int类型进行存储。
1-7 运算符
1-7-1 算数运算符
算术运算符的注意问题
如果对负数取模,可以把模数负号忽略不记,如:5%-2=1。但被模数是负数就另当别论。
对于除号“/”,它的整数除和小数除是有区别的:整数之间做除法时,只保留整数部分而舍弃小数部分。
例如:int x=3510;x=x/1000*1000; x的结果是?3000
“+”除字符串相加功能外,还能把非字符串转换成字符串
1-7-2 赋值运算符
符号:
= , +=, -=, *=, /=, %=
示例:
int a,b,c; a=b=c =3;
int a = 3; a+=5;等同运算a=a+5;
思考:
short s = 3;
s=s+2;
s+=2;
有什么区别?
有区别,s+2会被类型提升为int型,而S+=2不会,依旧是short类型
1-7-3 比较运算符
注1:比较运算符的结果都是boolean型,也就是要么是true,要么是false。
注2:比较运算符“==”不能误写成“=” 。
注2:比较运算符“==”不能误写成“=” 。
1-7-4 逻辑运算符
逻辑运算符用于连接布尔型表达式,在Java中不可以写成3<x<6,应该写成x>3 & x<6 。
“&”和“&&”的区别:
单&时,左边无论真假,右边都进行运算;
双&时,如果左边为真,右边参与运算,如果左边为假,那么右边不参与运算。
“|”和“||”的区别同理,双或时,左边为真,右边不参与运算。
异或( ^ )与或( | )的不同之处是:当左右都为true时,结果为false 。
“&”和“&&”的区别:
单&时,左边无论真假,右边都进行运算;
双&时,如果左边为真,右边参与运算,如果左边为假,那么右边不参与运算。
“|”和“||”的区别同理,双或时,左边为真,右边不参与运算。
异或( ^ )与或( | )的不同之处是:当左右都为true时,结果为false 。
1-7-5 位运算符
1-7-6 三元运算符
格式
(条件表达式)?表达式1:表达式2;
如果条件为true,运算后的结果是表达式1;
如果条件为false,运算后的结果是表达式2;
示例:
获取两个数中大数。
int x=3,y=4,z;
z = (x>y)?x:y;//z变量存储的就是两个数的大数。
(条件表达式)?表达式1:表达式2;
如果条件为true,运算后的结果是表达式1;
如果条件为false,运算后的结果是表达式2;
示例:
获取两个数中大数。
int x=3,y=4,z;
z = (x>y)?x:y;//z变量存储的就是两个数的大数。