zoukankan      html  css  js  c++  java
  • 关于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); //运行结果为false,只有int、float数据类型为原始数据类型
       System.out.println(s.getClass().isPrimitive());  
       Size u=Size.valueOf("SMALL");  //从字符串中转换
       System.out.println(s==u); //true 输出为BOOL类型
     foe(Size value:Size.values())  //列出它的所有值
     {
        System.out.println(value);
       }
    }
    }
    enum Size{SMALL,MEDIUM,LARGE};

    该程序的运行结果是,枚举可用于switch语句中,枚举也可以像一般的类一样添加方法和属性,用于定义变量,以限制变量的赋值,赋值时通过“枚举名。值”来取得相关枚举中的值,可以使用“==”和equals()方法直接比对枚举变量的值。

    二、反码、补码和原码的相关概念

      1)反码:

        反码的表示分为两种情况:

    如果一个数为正数,则反码和原码相同. 同时 补码也和他们相同.

    如果一个数为负数,则符号位不变,其余各位按原码取反。

    例如:   1的原码为0000 0001,反码为0000 0001.

    -1的原码为1000 0001,反码为1111 1110.

    同样的问题存在于反码:+0的反码为0000 0000    -0的反码为1111  1111

      2)补码:如果一个数为正,那么补码、反码原码都相同,如果一个数为负,那么他的补码就是他的反码加1。

           例如:[+1] = [00000001] = [00000001] = [00000001]

      3)原码:把最高位作为符号位,0表示正数,1表示负数。其余各位代表数值本身的绝对值,例如:

                  1表示为0000 0001,-1表示为1000 0001

                  7 表示 0000  0111   -7 原码表示为: 1000 0111

        在JAVA的程序中是使用补码来表示数字的。

    三、Java中每个数据类型所占的位数,和表示数值的范围

        1.Int          32位       取值范围为 -2的31次方到2的31次方减1之间的任意整数(-2147483648~2147483647)

        2.Short       16位       取值范围为 -32768~32767之间的任意整数

        3.long        64位       取值范围为 -2的63次方到2的63次方减1之间的任意整数         (-9223372036854774808~9223372036854774807)

        4.float        32位       取值范围为 3.402823e+38 ~ 1.401298e-45

       5.double      64位       取值范围为 1.797693e+308~ 4.9000000e-324

       6.char        8位       取值范围为  -128~127

       7.byte        8位       取值范围为 -128~127之间的任意整数

       所得出的结论:不同的数据类型进行转换时可能会有精度的损失。

    四、为什么double类型的数值进行运算得不到“数学上精确”的结果?

           首先得从计算机本身讨论这个问题。计算机并不能识别除了二进制数据以外的任何数据。无论我们使用何种编程语言,在何种编程环境下工作,都要先把源程序翻译成二进制的机器码后才能被计算机识别。事实上,浮点数并不适合用于精确计算,而适合进行科学计算。Float和double型用来表示带有小数点的数,这些数都以科学计数法的形式存储。当一个数如50.534,转换成科学计数法的形式为5.053e1,它的小数点移动到了一个新的位置(即浮动)可见,浮点数本来就是用于科学计算的,用来进行精确计算实在是太不合适了。

    五、以下代码的输出结果是什么?

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

    运行结果的图为:

    结论:在System.out.println()中,如果string字符串后面是+和变量,会自动把变量转换成string类型,则加号起连接作用,然后把两个字符串连接成一个新的字符串输出;如果先有变量的加减运算再有字符串,那么会从左到右先计算变量的加减,然后再与后面的string结合成一个新的字符串。

  • 相关阅读:
    【STM32F429的DSP教程】第8章 DSP定点数和浮点数(重要)
    【STM32F407的DSP教程】第8章 DSP定点数和浮点数(重要)
    【STM32H7的DSP教程】第7章 ARM DSP源码和库移植方法(IAR8)
    【STM32F429的DSP教程】第7章 ARM DSP源码和库移植方法(IAR8)
    【STM32F407的DSP教程】第7章 ARM DSP源码和库移植方法(IAR8)
    【STM32H7的DSP教程】第6章 ARM DSP源码和库移植方法(MDK5的AC5和AC6)
    【STM32F429的DSP教程】第6章 ARM DSP源码和库移植方法(MDK5的AC5和AC6)
    【STM32F407的DSP教程】第6章 ARM DSP源码和库移植方法(MDK5的AC5和AC6)
    【STM32H7的DSP教程】第5章 Matlab简易使用之常用编程语句
    【STM32F429的DSP教程】第5章 Matlab简易使用之常用编程语句
  • 原文地址:https://www.cnblogs.com/th1314/p/5936561.html
Copyright © 2011-2022 走看看