20200929 动手动脑

第一题


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};

 

 这是运行结果

从其中可以看出 这是两个对象的建立,而且这应该是一个类的实例化 而不是原始数据类型。

而在这个枚举的类型中可以看到 用字符串转译可以的出这是true的意思,我经过查找资料了解。

枚举的类型好像是给数据一个转换

而且是转译成你所规定的字符,所以在用字符串转义的调用后得出了true。

在整体遍历输出的时候也就输出了你所规定的三个单词。

第二题

这是对反码补码和原码的一些了解

数在计算机中是以二进制形式表示的

数分为有符号数和无符号数.

原码、反码、补码都是有符号定点数的表示方法.

一个有符号定点数的最高位为符号位,0是正,1是副. 

原码就是这个数本身的二进制形.反码就是原码的各位取反,补码可由原码得到.如果机器数是正数,则该机器数的补码与原码一样;

如果机器数是负数,则该机器数的补码是对它的原码(除符号位外)各位取反,并在未位加1而得到的.

第三题

这是一个计算机精度计算会出现一些问题的题目

import java.math.BigDecimal;

public class TestBigDecimal
{
public static void main(String[] args)
{
BigDecimal f1 = new BigDecimal("0.05");
BigDecimal f2 = BigDecimal.valueOf(0.01);
BigDecimal f3 = new BigDecimal(0.05);
System.out.println("下面使用String作为BigDecimal构造器参数的计算结果:");
System.out.println("0.05 + 0.01 = " + f1.add(f2));
System.out.println("0.05 - 0.01 = " + f1.subtract(f2));
System.out.println("0.05 * 0.01 = " + f1.multiply(f2));
System.out.println("0.05 / 0.01 = " + f1.divide(f2));
System.out.println("下面使用double作为BigDecimal构造器参数的计算结果:");
System.out.println("0.05 + 0.01 = " + f3.add(f2));
System.out.println("0.05 - 0.01 = " + f3.subtract(f2));
System.out.println("0.05 * 0.01 = " + f3.multiply(f2));
System.out.println("0.05 / 0.01 = " + f3.divide(f2));
}
}

 这个使用double 和float 类型直接进行运算的话经过查阅资料了解

这是在计算机运算中浮点数十进制对二进制转换

会丢失一部分精度

注:根本原因是:十进制值通常没有完全相同的二进制表示形式;十进制数的二进制表示形式可能不精确。只能无限接近于那个值。

而在double 数据类型时该函数会将这个数值的二进制转换成十进制而二进制本来就有一部分精度由于位数限制而不能表示

这时就会出现精度的问题

第四题


public class Test {
public static void main(String[] args) {
int intValue=100;
long longValue=intValue;
double doubleValue=1234567890;
float floatValue=(float)doubleValue;
System.out.println(floatValue);//1.23456794E9

int X=100;
int Y=200;
System.out.println("X+Y="+X+Y);
System.out.println(X+Y+"=X+Y");
doNotRunme();

String string="";
double d1=1000.123;
double d2=1000.123;
if(Math.abs(d2-d1)<1e-10){

}
//System.out.println(string);

}

public static void doNotRunme()
{
doNotRunme();
}
}

前一个是对两个数据的连接

后一个是对两个数据的相加

所以会出现这种情况

原文地址:https://www.cnblogs.com/huangmouren233/p/13762585.html