1.0.0 Summary
Tittle:【Java】-NO.16.EBook.4.Java.1.002-【疯狂Java讲义第3版 李刚】- 数据类型
Style:EBook
Series:Java
Since:2017-09-01
End:....
Total Hours:...
Degree Of Diffculty:2
Degree Of Mastery:2
Practical Level:2
Desired Goal:2
Archieve Goal:....
Gerneral Evaluation:...
Writer:kingdelee
Related Links:
http://www.cnblogs.com/kingdelee/
1.基本数据类型
double:占8字节,64位
float:占4字节,32位
需要精确保存浮点类型,应该使用BigDecimal
1字节:即8位
浮点型
float af = 5.2345556f;
// 下面将看到af的值已经发生了改变
System.out.println(af);
double a = 0.0;
double c = Double.NEGATIVE_INFINITY;
float d = Float.NEGATIVE_INFINITY;
// 看到float和double的负无穷大是相等的。
System.out.println(c == d);
// 0.0除以0.0将出现非数
System.out.println(a / a);
// 两个非数之间是不相等的
System.out.println(a / a == Float.NaN);
// 所有正无穷大都是相等的
System.out.println(6.0 / 0 == 555.0/0);
// 负数除以0.0得到负无穷大
System.out.println(-8 / a);
// 下面代码将抛出除以0的异常
// System.out.println(0 / 0);
5.2345557
true
NaN
false
true
-Infinity
类型转换:
String 字符串类型:
当第一次使用某个字符串字面量时,jvm会使用常量池缓存字符串字面量。之后每次使用都直接使用常量池的字面量。
除法: /
一般除数不能为0. 例外情况:当 有一方是浮点数时,结果也是浮点数,即除数是0 则为正/负 无穷大。
public static void main(String[] args)
{
double a = 5.2;
double b = 3.1;
double div = a / b;
// div的值将是1.6774193548387097
System.out.println(div);
// 输出正无穷大:Infinity
System.out.println("5除以0.0的结果是:" + 5 / 0.0);
// 输出负无穷大:-Infinity
System.out.println("-5除以0.0的结果是:" + - 5 / 0.0);
// 下面代码将出现异常
// java.lang.ArithmeticException: / by zero
System.out.println("-5除以0的结果是::" + -5 / 0);
}
取余: %
1.两边都是整数,对0取余会抛异常;除数为0,余数为0
2.有一边为浮点数,对0取余结果为非数NaN;除数不为0时,输出0.0
public static void main(String[] args)
{
double a = 5.2;
double b = 3.1;
double mod = a % b; System.out.println(mod); // mod的值为2.1
System.out.println("5对0.0求余的结果是:" + 5 % 0.0); // 输出非数:NaN
System.out.println("-5.0对0求余的结果是:" + -5.0 % 0); // 输出非数:NaN
System.out.println("0对5.0求余的结果是:" + 0 % 5.0); // 输出0.0
System.out.println("0对0.0求余的结果是:" + 0 % 0.0); // 输出非数:NaN
System.out.println("0对5求余的结果是:" + 0 % 5); // 0
// 下面代码将出现异常:java.lang.ArithmeticException: / by zero
System.out.println("-5对0求余的结果是:" + -5 % 0);
}
简单算术:
public static void main(String[] args)
{
double a = 3.2; // 定义变量a为3.2
// 求a的5次方,并将计算结果赋为b。
double b = Math.pow(a , 5);
System.out.println(b); // 输出b的值。
// 求a的平方根,并将结果赋给c
double c = Math.sqrt(a);
System.out.println(c); // 输出c的值。
// 计算随机数,返回一个0~1之间的伪随机数。
double d = Math.random();
System.out.println(d); // 输出随机数d的值
// 求1.57的sin函数值:1.57被当成弧度数
double e = Math.sin(1.57);
System.out.println(e); // 输出接近1
}
赋值运算符
public static void main(String[] args)
{
// 定义一个byte类型的变量
byte a = 5;
// 下面语句出错,因为5默认是int类型,a + 5就是int类型。
// 把int类型赋给byte类型的变量,所以出错,编译时出错
// a = a + 5;
// 定义一个byte类型的变量
byte b = 5;
// 下面语句不会出现错误
b += 5;
}
Byte:
Short:
Character:
Integer:
/**
* Cache to support the object identity semantics of autoboxing for values between
* -128 and 127 (inclusive) as required by JLS.
*
* The cache is initialized on first usage. The size of the cache
* may be controlled by the {@code -XX:AutoBoxCacheMax=<size>} option.
* During VM initialization, java.lang.Integer.IntegerCache.high property
* may be set and saved in the private system properties in the
* sun.misc.VM class.
*/
Long:
Float和Double都没有cache
package com.lee.test.java.ebook.crazy_java.u_6_oop_2; /**
* Description:
* <br/>网站: <a href="http://www.crazyit.org">疯狂Java联盟</a>
* <br/>Copyright (C), 2001-2016, Yeeku.H.Lee
* <br/>This program is protected by copyright laws.
* <br/>Program Name:
* <br/>Date:
*
* @author Yeeku.H.Lee kongyeeku@163.com
* @version 1.0
*/
public class WrapperClassCompare {
public static void main(String[] args) {
Integer a = new Integer(6);
// 输出true
System.out.println("6的包装类实例是否大于5.0" + (a > 5.0));
System.out.println("比较2个包装类的实例是否相等:"
+ (new Integer(2) == new Integer(2))); // 输出false
System.out.println(new Integer(2).equals(new Integer(2)));
// 通过自动装箱,允许把基本类型值赋值给包装类的实例
Integer ina = 2;
Integer inb = 2;
System.out.println("两个2自动装箱后是否相等:" + (ina == inb)); // 输出true
Integer biga = 128;
Integer bigb = 128;
System.out.println("两个128自动装箱后是否相等:" + (biga == bigb)); // 输出false
System.out.println("两个128自动装箱后是否equals:" + biga.equals(bigb)); // 输出true Integer a1 = new Integer(1);
Integer a2 = new Integer(1); System.out.println(a1.equals(a2));
System.out.println(a1 == a2); System.out.println("---------String----------"); String str1 = "1";
String str2 = "1";
String str3 = new String("2");
String str4 = new String("2");
String str5 = "1" + str1;
String str6 = "11";
String str7 = new String("11");
// 弱
System.out.println("两个字符串字面量内容比较:" + "1".equals("1"));
// 弱
System.out.println("两个字符串字面量对象对象:" + "1" == "1");
System.out.println("两个字符串字面量内容比较:" + str1.equals(str2));
System.out.println("两个字符串字面量对象比较:" + str1 == str2);
System.out.println("两个字符串字面量内容比较:" + str3.equals(str4));
System.out.println("两个字符串字面量对象比较:" + str3 == str4);
System.out.println("拼接的字符串比较1:" + str5.equals(str6));
System.out.println("拼接的字符串比较:" + str5 == str6);
System.out.println("拼接的字符串比较:" + str6 == str7); System.out.println("---------Integer----------"); Integer int1 = 1;
Integer int2 = 1;
Integer int3 = new Integer(1);
Integer int4 = new Integer(1);
Integer int5 = 128;
Integer int6 = 128; // 弱
// System.out.println(1 == 1);
System.out.println("两个字符串字面量内容比较:" + int1.equals(int2));
System.out.println("两个字符串字面量对象比较:" + (int1 == int2));
System.out.println("两个字符串字面量内容比较:" + int3.equals(int4));
System.out.println("两个字符串字面量对象比较:" + (int3 == int4));
System.out.println("两个字符串字面量内容比较:" + int5.equals(int6));
System.out.println("两个字符串字面量对象比较:" + (int5 == int6)); Byte b3 = new Byte("1");
System.out.println(b3);
Byte b4 = new Byte("11");
System.out.println(b4);
// Byte [-128, 127] 即 2^7,
Byte b5 = new Byte("127");
// System.out.println(1 << 7 - 1);
System.out.println(b5);
// Short [-32768, 32767] 2^15
// System.out.println((1 << 15) - 1); Short s1 = 128;
Short s2 = 128;
Short s3 = 127;
Short s4 = 127;
System.out.println(s1 == s2); // true
System.out.println(s3 == s4); // false Long l1 = 128l;
Long l2 = 128l;
Long l3 = 127l;
Long l4 = 127l;
System.out.println(l1 == l2); // false
System.out.println(l3 == l4); // true System.out.println("-------String---------"); }
}
public static void main(String[] args) { // 常量池:
// 管理编译时的被确定并保存到.class的数据(常量)。 // 1.字符串常量池
// 管理在编译时计算出来的值。如String s1 = "a"
// 2. new String("a"),先使用常量池管理"a",再在堆内存保存构建的"a"对象,即共有两个对象
// 3. .intern()可以值复制到常量池中并返回对应的地址,如果已经存在则返回已存在的地址 String s1 = "a";
String s2 = "a";
String s3 = new String("a");
String s4 = new String("a"); System.out.println("#1:" + (s1 == s2)); // T 两个都是常量池中的值,其地址一样
System.out.println("#2:" + (s1 == s3)); // F 前者是常量池,后者是堆内存中的,地址肯定不一样
System.out.println("#3:" + (s3 == s4)); // F new 出来的是堆内存中不一样的两个对象,尽管构造函数将其对象的值是一样的,但地址不一样 String intern = s3.intern();
String intern1 = s4.intern();
System.out.println("#4:" + (s2 == intern)); // T intern返回了常量池中的相同值的地址
System.out.println("#5:" + (s3 == intern)); // F s3依旧是堆内存的地址,intern是常量池的地址
System.out.println("#6:" + (intern1 == intern)); //T 都是常量池的地址 } @Test
public void t1() { // 2.普通变量
// 根据字符串常量的定义,必须是编译时确定下来的。 String t4 = "a" + "b"; 这种有 计算的非final的是无法在编译时就确定的。 String t1 = "a";
String t2 = "b";
String t1_t2 = t1 + t2;
String t3 = "ab";
String t4 = "a" + "b";
String t5 = "ab"; System.out.println("#1:" + (t3 == t1_t2)); // F
System.out.println("#2:" + (t4 == t1_t2)); // F
System.out.println("#3:" + (t4 == t5)); // T
} @Test
public void t2() { // 2.宏变量
// 使用final修饰的变量可以转化为宏变量,即在编译的时候就能够确下来并保存到常量池中。 final String t1 = "a";
final String t2 = "b";
final String t1_t2 = t1 + t2;
final String t3 = "ab";
final String t4 = "a" + "b"; System.out.println("#1:" + (t3 == t1_t2)); // T 都能够在编译的过程中确定下来
System.out.println("#2:" + (t4 == t1_t2)); // T 都能够在编译的过程中确定下来
}