*动手动脑:
问题1: 仔细阅读示例: EnumTest.java,运行它,分析运行结果?
源代码:
public class EnumTest {
public static void main(String[] args) {
Size s=Size.SMALL;
Size t=Size.LARGE;
//s和t引用同一个对象?
System.out.println(s==t);
//是原始数据类型吗? 不是
System.out.println(s.getClass().isPrimitive());
//从字符串中转换
Size u=Size.valueOf("SMALL");
System.out.println(s==u); //true
//列出它的所有值
for(Size value:Size.values()){
System.out.println(value);
}
}
}
enum Size{SMALL,MEDIUM,LARGE};
运行结果
false
false
true
SMALL
MEDIUM
LARGE
问题二:你能得到什么结论?你掌握了枚举类型的基本用法了吗?
枚举类型的常量以字符串的形式顺序储。源代码中s和t不是原始数据类型。getCLass():取得当前对象所属的Class对象 ;isPrimitive:用来判断指定的Class类是否为一个基本类型;因此s.getClass().isPrimitive()用来判断s是否是基本类型。Size u=Size.valueOf("SMALL");用来转化数据类型。Size.value()可遍历Size中的所有元素。使用“==”和equals()方法直接比对枚举变量的值。
*课后练习:
阅读相应教材,或者使用互联网搜索引擎,弄清楚反码、补码跟原码这几个概念,然后编写示例程序,对正数、负数进行各种位操作,观察输出结果,与手工计算的结果进行比对,看看Java中的数是采用上述哪种码表示的。
原码:原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值.
反码:正数:正数的反码与原码相同。负数:负数的反码,符号位为“1”,数值部分按位取反。可见如果一个反码表示的是负数, 人脑无法直观的看出来它的数值. 通常要将其转换成原码再计算.
补码:正数的补码就是其本身。负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1. (即在反码的基础上+1)。对于负数, 补码表示方式也是人脑无法直观看出其数值的. 通常也需要转换成原码在计算其数值.
*课后练习:
Java变量遵循“同名变量的屏蔽原则”,请课后阅读相关资料弄清楚相关知识,然后自己编写一些测试代码,就象本示例一样,有意识地在不同地方定义一些同名变量,看看输出的到底是哪个值。
例:package com;
class Test {
private static int value=1;
public static void main(String[] args){
int value=2;
System.out.println(value);
}
}
输出结果:2
每个变量都有一个“有效”的区域,成为有效域,出了这个区域,变量将不再有效。
*动手动脑:
查看Java中每个数据类型所占的位数,和表示数值的范围,你能得出什么结论?
基本数据类型有:
int长度数据类型有:byte(8bits)、short(16bits)、int(32bits)、long(64bits);
float长度数据类型有:单精度(32bits)、双精度(64bits double);
Boolen类型变量的取值有:ture、false;
Char数据类型有:unicode字符;
16位对应的类类型有:Integer 、Float、Boolean、Character、Double、Short、Byte、Long
结论:从低精度向高精度转换、基本类型向类类型转换、类类型向字符串转换、基本类型向字符串的转换
*动手动脑
为什么double类型的数值进行运算得不到“数学上精确”的结果?
float 和double类型主要是为科学计算和工程计算而设计的,他们执行二进制浮点运算,这两种类型在计算机中的储存分为三部分:符号位、指数为、尾数部分。数据以二进制存储在计算机时,会出现无线循环系列,在数据转化中会出现错误。十进制不能准确的表示1/3,同样二进制不能精确的表示1/10。
*注意思考:
在构建BigDecimal对象时应使用字符串而不是double数值,否则,仍有可能引发计算精度问题。(为什么会这样呢?)
double+、-不能准确的代表BigDecimal(String) 16位有效数以上的数字在使用BigDecimal时,应用*、/构造器创建对象才有意义。BigDecimal所创建的对象不能使用传统的等算术运算符直接对其对象进行数学运算,而必须调用相对应的方法。方法中的参数必须是BigDecimal的对象。
*动手动脑
以下代码的输出结果是什么?
int X=100;
int Y=200;
System.out.println("X+Y="+X+Y);
System.out.println(X+Y+"=X+Y");
输出结果:X+Y=100200 300=X+Y
为什么会有这样的输出结果?
语句一输出中“+”连接字面量,计算结果是将X和Y将两数据连接。
语句二输出中“+”是运算符,对X和Y求和。
*课后作业1
1、编写一个程序,用户输入两个数,求出其加减乘除,并用消息框显示计算结果。
源代码:
import java.util.Scanner;
import javax.swing.JOptionPane;// import class JOptionPane
public class Operation {
public static void main( String args[] ){
Scanner input=new Scanner(System.in);
System.out.println("请输入两个整数:");
double a,b;
a=input.nextDouble(); //输入第一个数
b=input.nextDouble(); //输入第二个数
double sum,difference,product,quotient;
sum=a+b;
difference=a-b;
product=a*b;
quotient=a/b;
//输出对话框显示结果
JOptionPane.showMessageDialog(
null, "The sum is " + sum +" "+
"The difference is "+ difference +" "+
"The product is "+product+" "+
"The quotient is "+quotient,"Results",
JOptionPane.PLAIN_MESSAGE );
System.exit( 0 );
}
}
运行结果: