数据类型和运算符

2.1 标识符和关键字

2.1.1 关键字和保留字

1、关键字(keyword)的定义和特点
定义:被Java语言赋予了特殊含义,用做专门用途的字符串(单词)
特点:关键字中所有字母都为小写 。
数据类型和运算符数据类型和运算符
2、保留字(reserved word)
Java保留字:现有Java版本尚未使用,但以后版本可能会作为关键字使 用。自己命名标识符时要避免使用这些保留字 goto 、const

2.2.2 标识符(Identifier)

1、标识符定义:
Java 对各种变量、方法和类等要素命名时使用的字符序列称为标识符
技巧:凡是自己可以起名字的地方都叫标识符。
2、定义合法标识符规则:
由26个英文字母大小写,0-9 ,_或 $ 组成
数字不可以开头。
不可以使用关键字和保留字,但能包含关键字和保留字。
Java中严格区分大小写,长度无限制。
标识符不能包含空格。
3、Java中的名称命名规范:
包名:多单词组成时所有字母都小写:xxxyyyzzz
类名、接口名:多单词组成时,所有单词的首字母大写:XxxYyyZzz
变量名、方法名:多单词组成时,第一个单词首字母小写,第二个单词开始每个 单词首字母大写:xxxYyyZzz
常量名:所有字母都大写。多单词时每个单词用下划线连接:XXX_YYY_ZZZ
注意1:在起名字时,为了提高阅读性,要尽量有意义,“见名知意”。
注意2:java采用unicode字符集,因此标识符也可以使用汉字声明,但是不建议使用。

2.2 变量和常量

2.2.1 变量

1、变量的概念:
(1)内存中的一个存储区域
(2)该区域的数据可以在同一类型范围内不断变化
(3)变量是程序中最基本的存储单元。包含变量类型、变量名和存储的值
2、变量的作用: 用于在内存中保存数据
3、使用变量注意:
Java中每个变量必须先声明,后使用
使用变量名来访问这块区域的数据
变量的作用域:其定义所在的一对{ }内
变量只有在其作用域内才有效
同一个作用域内,不能定义重名的变量
4、声明变量
语法:<数据类型> <变量名称>
例如:int var;
5、变量的赋值
语法:<变量名称> = <值>
例如:var = 10;
6、声明和赋值变量
语法: <数据类型> <变量名> = <初始化值>
例如:int var = 10;
7、变量的分类
按数据类型
对于每一种数据都定义了明确的具体数据类型(强类型语言),在内存中分 配了不同大小的内存空间。
数据类型和运算符按声明的位置的不同
在方法体外,类体内声明的变量称为成员变量。
在方法体内部声明的变量称为局部变量。
数据类型和运算符
注意:二者在初始化值方面的异同:
同:都有生命周期
异:局部变量除形参外,需显式初始化。

2.3基本数据类型

1、整数类型:byte、short、int、long**
Java各整数类型有固定的表数范围和字段长度,不受具体OS的影响,以保 证java程序的可移植性。
java的整型常量默认为 int 型,声明long型常量须后加‘l’或‘L’
java程序中变量通常声明为int型,除非不足以表示较大的数,才使用long
数据类型和运算符
500MB 1MB = 1024KB 1KB= 1024B B= byte ? bit?
bit: 计算机中的最小存储单位。byte:计算机中基本存储单元。
2、浮点类型:float、double**
与整数类型类似,Java 浮点类型也有固定的表数范围和字段长度,不受具体操作 系统的影响。 浮点型常量有两种表示形式:
十进制数形式:如:5.12 512.0f .512 (必须有小数点)
科学计数法形式:如:5.12e2 512E2 100E-2
float:单精度,尾数可以精确到7位有效数字。很多情况下,精度很难满足需求。
double:双精度,精度是float的两倍。通常采用此类型。
Java 的浮点型常量默认为double型,声明float型常量,须后加‘f’或‘F’。数据类型和运算符
浮点数不适用于禁止出现舍入误差的金融计算中
例如,命令System.out.println(2.0-1.1);将打印出0.8999999999999999,而不是人们希望的0.9。出现这种问题的主要原因在于浮点数值是采用二进制系统表示的。而在二进制系统中无法精确的表示分数1/10,这就好像十进制无法精确表示1/3一样。

如果需要在数值计算中不含有任何舍入误差,就应该使用BigDecimal类,后面会介绍这个类的。**
3、字符类型:char
char 型数据用来表示通常意义上“字符”(2字节)
Java中的所有字符都使用Unicode编码,故一个字符可以存储一个字母,一个汉字,或其他书面语的一个字符。
字符型变量的三种表现形式:
字符常量是用单引号(‘ ’)括起来的单个字符。例如:char c1 = ‘a’; char c2 = ‘中’; char c3 = ‘9’;
Java中还允许使用转义字符‘\’来将其后的字符转变为特殊字符型常量。 例如:char c3 = ‘\n’; // '\n’表示换行符
直接使用 Unicode 值来表示字符型常量:‘\uXXXX’。其中,XXXX代表 一个十六进制整数。如:\u000a 表示 \n。
数据类型和运算符
char类型是可以进行运算的。因为它都对应有Unicode码。
4、布尔类型:boolean
boolean 类型用来判断逻辑条件,一般用于程序流程控制:
if条件控制语句;
while循环控制语句;
do-while循环控制语句;
for循环控制语句;
• 请不要这样写:if ( is == true && done == false ) ,只有新手才那么写。
对于任何程序员 if ( whether && !done ) 都不难理解吧。所以去掉所有的==fasle 和 ==true。
boolean类型数据只允许取值true和false,无null。
不可以使用0或非 0 的整数替代false和true,这点和C语言不同。
Java虚拟机中没有任何供boolean值专用的字节码指令,Java语言表达所操作的 boolean值,在编译之后都使用java虚拟机中的int数据类型来代替:true用1表示,false 用0表示。———《java虚拟机规范 8版》
5、 字符串类型:String
String不是基本数据类型,属于引用数据类型
使用方式与基本数据类型一致。
6、基本数据类型转换
自动类型转换:容量小的类型自动转换为容量大的数据类型。数据类型按容 量大小排序为:数据类型和运算符
将容量大的类型转换成容量小的类型,需要进行强制转换
注意:只要不超出范围可以将整型值直接赋值给 byte,short,char
在多种类型混合运算过程中,首先先将所有数据转换成容量最大的那种,再运算.
有多种类型的数据混合运算时,系统首先自动将所有数据转换成容量最大的 那种数据类型,然后再进行计算。
byte,short,char之间不会相互转换,他们三者在计算时首先转换为int类型。
boolean类型不能与其它数据类型运算。
当把任何基本数据类型的值和字符串(String)进行连接运算时(+),基本数据类 型的值将自动转化为字符串(String)类型。
7、强制类型转换
自动类型转换的逆过程,将容量大的数据类型转换为容量小的数据类型。使用时要加上强制转换符:(),但可能造成精度降低或溢出,格外要注意。
通常,字符串不能直接转换为基本类型,但通过基本类型对应的包装类则可以实现把字符串转换成基本类型。
如: String a = “43”; int i = Integer.parseInt(a);
boolean类型不可以转换为其它的数据类型。
8 、进制
(1)关于进制
所有数字在计算机底层都以二进制形式存在。
对于整数,有四种表示方式:
二进制 0 1
八进制 0 1 2 3 4 5 6 7
十进制 0-9
十六进制 0-9 A-F
(2)二进制
二进制的表示形式:原码 反码 补码
正数 的原码 反码 补码都是一样
负数 原码 将一个负数表示程二进制
反码 按位取反 0变1 1 变0
补码 反码+1
为什么要设计程原码,反码,补码 ?
在与计算机无法识别符号位 所以在运算中 将符号位也参与运算 只有加法没有减法
(3)进制间转化
要将一个十进制的数转换为八进制 首先转换为2进制 然后三位2进制表示一位8进制
十进制转换为十六进制 4位二进制表示一位16进制的数
不同进制的数据的表示
十进制直接表示 二进制直接使用01表示
八进制表示的时候一般在数据的前边加0 014
十六进制表示的时候一般在前边加上0x 表示是十六进制表示 0xC
System.out.println(bb1);输出时 所有的整数都按照int类型输出

2.4 运算符

运算符是一种特殊的符号,用以表示数据的运算、赋值和比较等。
算术运算符
赋值运算符
比较运算符(关系运算符)
逻辑运算符
位运算符
三元运算符
2.4.1算数运算符
数据类型和运算符
算数运算中 byte short char int 运算的结果都是int类型
运算中如果有long类型存在 则结果long类型
在整数类型及char类型做运算的时候 如果操作数如果时byte short char 那么运算的结果是int
如果期中有int类型的操作书 结果肯定是int
如果操作书中有long类型 结果肯定是long
如果在运算中操作数中有float类型 则结果为float
如果在运算中操作数中有double类型 则结果为double
boolean不能参与算数运算 boolean也不能和其他类型之间进行相互转换

对于/ *法运算 其中如果有负数 则结果为负

在除法运算中 取得是相除的商
%取模运算 结果为余数 结果的正负与第一个操作数保持一致

++ 自增
–自减
++ 作用都是给当前操作数+ 1
++写在操作数之后 是先取操作数的值 然后在给该数加1
++写在操作数之前 是先加1 在取值
算术运算符的注意问题
如果对负数取模,可以把模数负号忽略不记,如:5%-2=1。 但被模数是 负数则不可忽略。此外,取模运算的结果不一定总是整数。
对于除号“/”,它的整数除和小数除是有区别的:整数之间做除法时,只保留整数部分而舍弃小数部分。 例如:int x=3510;x=x/1000*1000; x的结果是?
“+”除字符串相加功能外,还能把非字符串转换成字符串.例如: System.out.println(“5+5=”+5+5); //打印结果是? 5+5=55 ?
2.4.2赋值运算符
符号:=
当“=”两侧数据类型不一致时,可以使用自动类型转换或使用强制 类型转换原则进行处理。
支持连续赋值。
扩展赋值运算符: +=, -=, *=, /=, %=
2.4.3 比较运算符
数据类型和运算符
比较运算符的结果都是boolean型,也就是要么是true,要么是false。
比较运算符“==”不能误写成“=”
2.4.4 逻辑运算符
&—逻辑与 | —逻辑或 !—逻辑非 && —短路与 || —短路或 ^ —逻辑异或
数据类型和运算符
逻辑运算符用于连接布尔型表达式,在Java中不可以写成33 & x<6 。
“&”和“&&”的区别:
单&时,左边无论真假,右边都进行运算;
双&时,如果左边为真,右边参与运算,如果左边为假,那么右边不参与运算。
“|”和“||”的区别同理,||表示:当左边为真,右边不参与运算。
异或( ^ )与或( | )的不同之处是:当左右都为true时,结果为false。
理解:异或,追求的是“异”!
&运算中只要有false 结果就为false
| 运算中 只要有true 结果就为true
! true 为false false 为true
^ 当两个不同时 则为true 相同时为false
&& 当在运算中 如果符号左边为false 则右边不在执行运算 只有左边为true 右边才会进行运算
|| 短路或 如果符号左边为true 右边就不执行运算 只有左边为false 右边才会执行运算