java之数据类型与变量(二)

目录

一、浮点型变量

双精度浮点型

单精度浮点型

二、字符型变量

三、布尔型变量


一、浮点型变量

  • 双精度浮点型

public static void main(String[] args) {
    double a=1.01;
    System.out.println(a);//输出为1.01
}

例一:当求小数时,用整形int能否求出呢:

public static void main(String[] args) {
    int a=1;
    int b=2;
    System.out.println(a/b);
}

编译程序:

如上图所示,我们不能得到想要的1/2=0.5,得到的结果为0,说明是不能用整型求浮点数 ,因为在java中,int除以int的值仍然是int,会直接舍弃掉小数部分,所以要求得0.5,只能用double定义

public static void main(String[] args) {
    double a=1.0;
    double b=2.0;
    System.out.println(a/b);
}

编译程序发现结果是我们想要的结果

 除了这个例题之外,还有一个有趣的题

public static void main(String[] args) {
    double a=0.5;
    double b=1.1;
    System.out.println(a*a);
    System.out.println(b*b);
}

进行编译:

 如图,我们发现了一个神奇的现象,发现0.5*0.5得到的结果是0.25,而1.1*1.1却不是我们以为的1.21,这是因为double类型的内存布局遵守IEEE 754标准,尝试使用有限的内存空间表示更多可能无限的小数,那么就会存在一定的精度误差,故而浮点数是一个近似值,并不是精确值。

注意:

  • double在任何系统下都是8个字节
  • double的包装类型为Double
  • 浮点数与整数在内存中的存储方式不同,不能单纯使用n^2的形式来计算
  • double类型的内存布局遵守IEEE 754标准,尝试使用有限的内存空间表示更多可能无限的小数,那么就会存在一定的精度误差,故而浮点数是一个近似值,并不是精确值。
  • 单精度浮点型

float类型在java中占4个字节,同样遵守IEEE 754标准。但是float表示的数据精度范围较小,一般在工程上优先考虑double,不推荐float。float的包装类型为Float

public static void main(String[] args) {
    float a=1.0f;
    float b=1.0F;
    System.out.println(a);
    System.out.println(b);
}

 进行编译

 如上图,说明1.0f与1.0F效果是一样的。

普及:

  • IEEE二进制浮点数算术标准(IEEE 754)是20世纪80年代以来最广泛使用的浮点数运算标准,为许多CPU与浮点运算器所采用。这个标准定义了表示浮点数的格式(包括负零-0)与反常值(denormal number)),一些特殊数值(无穷(Inf)与非数值(NaN)),以及这些数值的“浮点数运算符”;它也指明了四种数值舍入规则和五种例外状况(包括例外发生的时机与处理方式)。
  • IEEE 754规定了四种表示浮点数值的方式:单精确度(32位)、双精确度(64位)、延伸单精确度(43比特以上,很少使用)与延伸双精确度(79比特以上,通常以80位实现)。 只有32位模式有强制要求,其他都是选择性的。
  • 大部分编程语言都有提供IEEE浮点数格式与算术,但有些将其列为非必需的。例如,IEEE 754问世之前就有的C语言,有包括IEEE算术,但不算作强制要求(C语言的float通常是指IEEE单精确度,而double是指双精确度)。
  • 该标准的全称为IEEE二进制浮点数算术标准(ANSI/IEEE Std 754-1985),又称IEC 60559:1989,微处理器系统的二进制浮点数算术(本来的编号是IEC 559:1989)。 后来还有“与基数无关的浮点数”的“IEEE 854-1987标准”,有规定基数为2跟10的状况。最新标准是“ISO/IEC/IEEE FDIS 60559:2010”。

二、字符型变量

语法表示:用单引号+单个字母表示

计算机中的字符本质上是一个整数,在C语言中使用ASCLL表示字符,在java中使用Unicode表示字符,故而一个字符占用两个字节,表示的字符种类更多,包括中文。

char的包装类型为Character

public static void main(String[] args) {
    char a='A';//大写字符
    char b='1';//数学字符
    System.out.println(a);
    System.out.println(b);

    //注意:java中的字符可以存放整形
    char c='整';
    System.out.println(c);
}

进行编译:

  • 三、布尔型变量

布尔型变量常常用来表示真假,但是boolean类型的变量只有两种取值:true表示真,false表示假

public static void main(String[] args) {
    boolean a=true;
    System.out.println(a);
    boolean b=false;
    System.out.println(b);
}

进行编译:

 到这里,思考一个问题:java中的boolean类型和int类型能否相互转换呢?

//假设boolean和int可以相互转换
public static void main(String[] args) {
    boolean a=true;
    System.out.println(a+1);
}

我们对其编译,发现

出现了错误:java: 二元运算符 '+' 的操作数类型错误

第一个类型: boolean

第二个类型: int

说明boolean类型与int类型之间是不能相互转换的,也就是不存在1表示true,0表示false这样的用法

 注意:

  • boolean类型的变量只有两种取值:true表示真,false表示假
  • boolean类型与int类型之间是不能相互转换的,不存在1表示true,0表示false这样的用法
  • java虚拟机规范中,没有明确规定boolean占几个字节,没有大小,没有专门用来处理boolean的字节码指令,而在Oracle公司的虚拟机实现中,boolean占1个字节
  • boolean的包装类型是Boolean

本文的知识暂时到这里,主要介绍了 浮点型变量、字符型变量、布尔型变量,当然,介绍的都是最基础的,如果有什么问题,望各位大佬们指点!

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张张_张

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值