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

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

原文地址:https://www.cnblogs.com/baiyue/p/5936435.html