zoukankan      html  css  js  c++  java
  • Java语法基础练习2

    ---恢复内容开始---

    1.仔细阅读示例:EnumTest.java分析结果

            代码:

       

        运行结果:

                

        分析:枚举类型就是一个类,枚举中的常量就是枚举类型中的实例,可把字符串转化为枚举;而且他本身是一个类,所以不是原始数据类型,同时也不能被继承。同时由于s与t引用的不是同一个数据对象,所以不相等。也不是原始数据类型。

    2.   原码就是符号位加上真值的绝对值,即用第一位表示符号,其余位表示值。故他的取值范围是[-127, 127]。原码是人脑最容易理解和计算的表示方法。

         反码:正数的反码是他本身,负数的反码是在其原码的基础上,符号位不变,其余各位取反。例如[+1]=[00000001](原码)=[00000001](反码);[-1]=[10000001](原码)=[11111110](反码)。

         补码:正数的补码是其本身;负数的补码是在其原码的基础上,符号位不变,其余取反,最后加1。

         Java中的数是用补码表示的。

    3.同名变量覆盖

       代码:

         

       结果:

           

          

    5.运行程序

           代码:

                   

          结果:

               

          分析:使用double类型的数值进行计算时,其结果不精确。

    N进制可以理解为:数值×基数的幂,例如我们熟悉的十进制数123.4=1×10²+2×10+3×(10的0次幂)+4×(10的-1次幂);其它进制的也是同理,例如二进制数11.01=1×2+1×(2的0次幂)+0+1×(2的-2次幂)=十进制的3.25。double类型的数值占用64bit,即64个二进制数,除去最高位表示正负符号的位,在最低位上一定会与实际数据存在误差(除非实际数据恰好是2的n次方)。举个例子来说,比如要用4bit来表示小数3.26,从高到低位依次对应2的1,0,-1,-2次幂,根据最上面的分析,应当在二进制数11.01(对应十进制的3.25)和11.10(对应十进制的3.5)之间选择。简单来说就是我们给出的数值,在大多数情况下需要比64bit更多的位数才能准确表示出来(甚至是需要无穷多位),而double类型的数值只有64bit,后面舍去的位数一定会带来误差,无法得到“数学上精确”的结果。解决方法:现在已经可以解决这个问题了,原则是使用BigDecimal并且一定要用String来构造。 但是想像一下吧,如果要做一个加法运算,需要先将两个浮点数转为String,然后构造成BigDecimal,在其中一个上调用add方法,传入另一个作为参数,然后把运算的结果(BigDecimal)再转换为浮点数。

    6.运行程序

        代码:

            

         结果:

            

         分析:+x+y表示依次输出x,y的值;x+y才是运算。

    7.两个数的运算

        代码:       

    package main;

    //An addition program

    import javax.swing.JOptionPane;  // import class JOptionPane

    public class YunSuan {  

    public static void main( String args[] )  {    

    String firstNumber,   // first string entered by user           

    secondNumber;// second string entered by user   

      String  fuhao;       //fuhao    

    int number1,          // first number to add       

      number2,          // second number to add        

    sum; // sum of number1 and number2       

    int sum1,sum2,sum3;     // read in first number from user as a string    

    firstNumber =       

    JOptionPane.showInputDialog( "Enter first integer" );

        // read in second number from user as a string    

    secondNumber =       

    JOptionPane.showInputDialog( "Enter second integer" );    

    fuhao=      

    JOptionPane.showInputDialog( "Enter the fuhao" );       

      // convert numbers from type String to type int    

    number1 = Integer.parseInt( firstNumber );    

    number2 = Integer.parseInt( secondNumber );       

    if(fuhao.equals("+"))      

      {         // add the numbers       

      sum = number1 + number2;        

    JOptionPane.showMessageDialog(            

      null, "The sum is " + sum, "Results",             

    JOptionPane.PLAIN_MESSAGE );        }       

    else if(fuhao.equals("-"))       

    {        

    sum1=number1-number2;       

      JOptionPane.showMessageDialog(             

    null, "The sum1 is " + sum1, "Results",            

      JOptionPane.PLAIN_MESSAGE );       

    }       

    else if(fuhao.equals("*"))       

    {        

    sum2=number1*number2;        

    JOptionPane.showMessageDialog(             

    null, "The sum2 is " + sum2, "Results",            

      JOptionPane.PLAIN_MESSAGE );      

      }       

    else if(fuhao.equals("/"))       

    {    

    if(number2!=0)       

    {sum3=number1/number2;        

    JOptionPane.showMessageDialog(             

    null, "The sum3 is " + sum3, "Results",             

    JOptionPane.PLAIN_MESSAGE );}      

      else        

    JOptionPane.showMessageDialog(          

    null, "The sum3 is error", "Results",          

    JOptionPane.PLAIN_MESSAGE );       

    }       

    System.exit( 0 );   // terminate the program

     } }

    结果:特殊情况除法中,除数为0

    ---恢复内容结束---

  • 相关阅读:
    Linux内核同步方法
    C++11写轻量级AOP框架
    Typora夜樱主题
    MySQL添加主键和外键
    命题连接词和命题逻辑
    打印一个类全部信息的方法
    getClass()和instanceof以及类的equals方法
    多态
    在构造函数中调用另一个构造函数
    参数传递
  • 原文地址:https://www.cnblogs.com/baiyue/p/5936435.html
Copyright © 2011-2022 走看看