JAVA基础语法动手动脑实践体会
一、运行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};
运行结果:
gsxdcsad
二、运行TestDouble.java程序。
public class TestDouble { public static void main(String args[]) { System.out.println("0.05 + 0.01 = " + (0.05 + 0.01)); System.out.println("1.0 - 0.42 = " + (1.0 - 0.42)); System.out.println("4.015 * 100 = " + (4.015 * 100)); System.out.println("123.3 / 100 = " + (123.3 / 100)); } }
运行之后会出现这种情况:
使用Java,double 进行运算时,经常出现精度丢失的问题,总是在一个正确的结果左右偏0.0000**1。这样的情况通过double计算出来的结果去和0比较大小,尤其是有小数点的时候,经常会因为精度丢失而导致程序处理流程出错。所以尽量不要使用double来进行计算。
float与double的区别
单精度浮点数在机内占4个字节,用32位二进制描述。
双精度浮点数在机内占8个字节,用64位二进制描述。
浮点数在机内用指数型式表示,分解为:数符,尾数,指数符,指数四部分。
数符占1位二进制,表示数的正负。
指数符占1位二进制,表示指数的正负。
尾数表示浮点数有效数字,0.xxxxxxx,但不存开头的0和点
指数存指数的有效数字。
指数占多少位,尾数占多少位,由计算机系统决定。
可能是数符加尾数占24位,指数符加指数占8位 -- float.
数符加尾数占48位,指数符加指数占16位 -- double.
知道了这四部分的占位,按二进制估计大小范围,再换算为十进制,就是你想知道的数值范围。
对编程人员来说,double 和 float 的区别是double精度高,有效数字16位,float精度7位。但double消耗内存是float的两倍,double的运算速度比float慢得多,java语言中数学函数名称double 和 float不同,不要写错,能用单精度时不要用双精度(以省内存,加快运算速度)
所以你把double赋值给float变量的过程,实际上是一个强制转换,肯定会损失精度。
三、运行程序。
int X=100; int Y=200; System.out.println("X+Y="+X+Y); System.out.println(X+Y+"=X+Y");
运行结果如下:
加号有两个作用:相加作用和连接符作用。当加号两边都是数值类型时为求和作用;当一边是数值类型一边是非数值类型或两边都是非数值类型时当作连接符使用。所以第一行双引号外第一个加号是起连接符的作用所以x,y不会相加,第二行第一个加号是求和作用,所以x,y的值会相加。
第一题代码:
//加减乘除运算 //赵东睿 20142948 //2015/10/5 package operation; import javax.swing.JOptionPane; public class operation { public static void main(String[] args) { String firstNumber,secondNumber; int number1,number2,sum,dif,pro,quo; firstNumber = JOptionPane.showInputDialog("Enter first intager"); secondNumber = JOptionPane.showInputDialog("Enter second intager"); number1 = Integer.parseInt(firstNumber); number2 = Integer.parseInt(secondNumber); sum = number1 + number2; dif = number1 - number2; pro = number1 * number2; quo = number1 / number2; JOptionPane.showMessageDialog(null,"The sum is " + sum + "\n" + "The dif is " + dif + "\n" + "The pro is " + pro + "\n" + "The quo is " + quo,"Results",JOptionPane.PLAIN_MESSAGE); System.exit(0); } }