---恢复内容开始---
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
---恢复内容结束---