今天继续学习java的第二章知识。加油加油!!!
基本数据类型
浮点型
浮点型字面默认是double;
当我们要声明float类型时,在字后量后面加f或者F,例如:
float f = 10.1234567891f;
double是8个字节,双精度数据类型;
当我们声明double类型时,我们也可以在后面加d或者D,例如:
double d = 10.123456789d;
boolean
boolean逻辑值,boolean逻辑值只能用true和false两个关键字表示。
char字符型
char 字符型 单个字符 'a' 单引号表示 "" 双引号表示字符串 字符串也是由一个一个字符组成的 计算机之所以能够显示字符,底层会有一个对照表(编码表) 字符 a --- 97 --- 二进制 java表示字符时,使用的unicode编码(包含全球各个国家的语言符号,万国码,兼容ASCII码) utf-8 是一种边长的,用于在文件,传输时使用的具体编码表 可以根据编码值的大小,动态变化长度 表示英文字母时 1字节 表示中文字符时 3字节
字符型也是可以参与运算的,例如:a+10就是97+10。
基本数据类型转换
例外: boolean不能与其他基本类型转换 byte short int long float double char 都是数值型 容量小 ----> 容量大 默认会自动转换 byte,short,char-->int 容量大 ----> 容量小 默认不能进行转换 可以强制类型转换: 可能会出现问题: 数据溢出,精度降低
在混合运算时,自动将容量小的转为容量大的 由于小数二进制底层存储结构与整数不同 4字节float表示的范围大于8字节long。
数据类型转换分为默认转换和强制转换:
默认转换: 整形,字符型,浮点型的数据在混合运算中相互转换,转换时遵循以 下原则: 容量小的类型默认转换为容量大的数据类型;数据类型按容量大小排 序为: byte,shor t,char->int->long->float->double byte,short,char之 间不会互相转换,他们三者在计算时首先会转换为int类型
强制转换:容量大的数据类型转换为容量小的数据类型时,要加上强制转换符,但可能造 成精 度降低或溢出;使用时要格外注意。
有多种类型的数据混合运算时,系统首先自动的将所有数据转换成容量最大的 那一 种数据类型,然后再进行计算。
● long类型与float类型的大小
在内存中占用的是4个字节的空间,而long型占用的是8个字节的空间。可是为 什么4个字节的float型的最大值会大于long型的最大值呢? long整型数,在内存中占用8个字节共64位,它表示的数值有2的64次方,平 分正负,数值范围是负2的63次方到正2的63次方-1。
● 而float在内存中占4个字节,共32位,但是浮点数在内存中是这样的:
V=(-1)^s * M * 2^E
浮点数的32位不是简单的直接表示大小,而是按照一定的标准分配的。其中第1位,符号位,即S。接下来的8位,指数域,即E。 剩下的23位,小数域,即M。 也就是说,浮点数在内存中的二进制值不是直接转换为十进制数值的,而是 按照上述公式计算而来,通过这个公式,虽然只用到了4个字节,但是浮点数却 比长整型的最大值要大。
运算符
Java 语言支持如下运算符:
● 算术运算符: +,-, * ,/,%,++,--
● 字符串连接运算符:+
● 关系(比较)运算符: >,= ,<= , == ,!=
● 逻辑运算符: !,& , | , &&,||
● 赋值运算符: = ,+ = ,- = , * = ,/ =
● 条件运算符
● 位运算符
-
算术运算
+ - * / % ++ -- + 加法 数值+数值 数值+字符 + 字符串连接 字符串+字符串 数值+字符串 - * / % ++ -- 数值+数值 数值+字符 ++ 自增1(在混合运算时,++在后 先运算 后++;++在前面 先++, 后运算) -- 自减1
-
比较运算符
-
逻辑运算符
逻辑运算 逻辑值与逻辑值 & | ! && || ^(逻辑异或) & | ^ ! 既可以参与逻辑运算 也可以参与位运算
-
“&”和“&&”的区别:
单&时,左边无论真假,右边都进行运算;
双&时,如果左边为真,右边参与运算,如果左边为假,那么右边不参与运算
“|”和“||”的区别同理,||表示:当左边为真,右边不参与运算。
-
赋值运算符
符号:=
当“=”两侧数据类型不一致时,可以使用自动类型转换或使用强制类型转换原 则进行处 理。
扩展赋值运算符: +=, -=, *=,/=, %=
= 右边的值赋给左边 注意数据类型 (注意:经常写 == 写成=) += -= *= /= %=
-
条件运算符
语法:(条件表达式)? 表达式1:表达式2;
条件表达式结果为true,运算后的结果是表达式1; 为false,运算后的 结果是表达式2;
-
位运算
位(比特位)运算 移位 << 做移 >> 右移 >>> 无符号右移
例:
int b = -6; System.out.println(b>>1);//3 -3 有符号的移动 符号不变的 System.out.println(b>>>1);//3 2147483645 无符号右移 注意负数 移位后,高位补0
表达式的运算顺序
控制台输入
控制台输入: 在基础语法学习时,交互式的向程序中输入内容,实际程序中是用不到.
- 使用标准输入串System.in 使用Scanner取得一个字符串或一组数字 在新增一 个Scanner对象时需要一个System.in对象,因为实际上还是 System.in在取得 用户输入。
- Scanner的next()方法用以 取得用户输入的字符串; nextInt()将取得的输入字 符串转换为整数类型;
- 同样,nextFloat()转换成浮点型; nextBoolean()转 换成布尔型。
例: System.out.print("输入");
Scanner scan = new Scanner(System.in);
String read = scan.next ();
System.out.println("输入数据:"+read);
在使用Scanner对象时,需要在文件头带入 java.util.Scanner; 写法为: import java.util.Scanner;
控制语句
● 条件语句 - 根据不同条件,执行不同语句。
if
if .. else
if .. else if
if .. else if .. else if .. else
switch
●循环语句 – 重复执行某些动作
for
while
do .. while;
if条件结构
流程控制语句
if条件结构是根据条件判断之后再做处理
if(条件表达式){ 条件成立执行 }
if(条件表达式){ 条件成立执行 }else{ 条件不成立执行 }
if(条件表达式){ 条件成立执行 }else if(条件表达式){ 条件成立执行 }...
if(条件表达式){ 条件成立执行 }else if(条件表达式){ 条件成立执行 }...else{ 所有条件都不成立执行 }
switch语句
switch语句:多分支选择语句,根据表达式的值,来执行多个操作中的一个。
switch (表达式){
case value1: 语句序列1;
[break];
…………
case valueN: 语句序列N;
[break];
[default : 缺省语句;]
}
表达式可以是byte、short、int、char、枚举类型。JDK 7以后,可以使用String类 型;
case语句后面只能使用常量表达式; case后的值不能重复;
某个case分支如果没有提供break语句,则继续执行下一个case后的语句;
当表达式的值与任一case子句中的值都不匹配时,将执行default后面的语句;
如果 没有default子句,则程序直接跳出switch语句。
总结
以上就是我这次学习的成果,感觉自己渐渐入门了,继续加油努力咯!