远方的灯塔 - 专注于服务端技术分享 远方的灯塔 - 专注于服务端技术分享
首页
  • Java SE
  • Struts2
  • Hibernate
  • MyBatis
  • JAX-WS
  • 并发
  • 分布式
  • Git
  • 文章分类
  • 文章标签
  • 文章归档
  • 《C程序设计语言》
心情随笔
友情链接
给我留言 (opens new window)
关于我
GitHub (opens new window)

Terwer Green

一个后端老菜鸟
首页
  • Java SE
  • Struts2
  • Hibernate
  • MyBatis
  • JAX-WS
  • 并发
  • 分布式
  • Git
  • 文章分类
  • 文章标签
  • 文章归档
  • 《C程序设计语言》
心情随笔
友情链接
给我留言 (opens new window)
关于我
GitHub (opens new window)
  • JavaSE

    • Java_SE之Java_SE平台与JDK
    • Java_SE_第二讲:原生数据类型
    • Java_SE_第三讲:原生数据类型使用陷阱
    • Java_SE_第四讲:运算符
    • Java_SE_第五讲:运算符续
    • Java_SE_第六讲:流程控制语句
    • Java_SE_第七讲:流程控制续
    • Java_SE_第八讲:理解面向对象程序设计
    • Java_SE_第九讲:面向对象之封装
    • Java_SE_第十讲:面向对象之封装续
    • Java_SE_第十一讲:面向对象之封装续二
    • Java_SE_Lesson_1:面向对象高级
    • Java_SE_Lesson_2:多态与static和final关键字
    • Java_SE_Lesson_3:接口、单例模式、包与访问控制
    • Java_SE之Object类详解
    • Java_SE之String类及其源代码剖析
    • 包装类与数组
    • 冒泡排序、交换排序与快速排序
    • Java数组的查找方式及二分查找
    • 常量与Java集合框架简介
    • 常用的Java开发IDE
    • ArrayList深入分析
    • LinkedList源代码深入剖析
    • 数据结构中的基本结构分析
    • 《Java语言新特性》

  • 开源框架

  • Linux

  • Struts2

  • Hibernate

  • Webservice

  • 分布式

  • 分布式框架

  • 后端开发
  • JavaSE
terwer
2022-10-10

JavaSE第三讲:原生数据类型使用陷阱

  1. Java 中的原生数据类型共有 8 种:

    1) 整型:使用 int 表示。(32 位)

    2) 字节型:使用 byte 表示。(表示-128~127 之间的 256 个整数, 8 位)。

    3)短整型:使用 short 表示。(16 位)

    4)长整型:使用 long 表示。(64 位)

    5)单精度浮点型:使用 float 表示。所谓浮点型,指的就是小数,也叫做实数,比如 1.2。

    6)双精度浮点型:使用 double 表示。双精度浮点型表示的数据范围要比单精度浮点型大。

    7)字符型:使用 char 表示(char 是 character 的缩写)。所谓字符,就是单个的字符表示, 比如字母 a,或者中文张,外面用单引号包围上。比如 char a = ‘B’; char b = ‘张’;

    8)布尔类型,使用 boolean 表示。布尔类型只有两种可能值,分别是 true 与 false。

  2. Java 中的所有浮点类型默认情况下都是 double。不能将 double 类型的值赋给 float 类型的变量,即便该 double 类型的值处于 float 类型的范围内也是不可以的。总之,能否成功赋值取决于等号右边的值类型与等号左边的变量类型是否一致。

  3. 如何将 double 类型的值赋给 float 类型的变量?答案就是

    (1)强制类型转换,将 double 类型的值强制转换为 float 类型。

    (2)使用 java 语言的支持。

    强制转换的语法: 类型 变量名 = (类型)变量值;

  4. 变量在使用前必须要赋值;变量必须要声明其类型方可使用;变量在使用前必须要定义,并且只能定义一次。

  5. 如下代码无法通过编译:

    int a = 1;

  6. short b = a;

    a 是 int 类型,b 是 short 类型,int 类型表示的数据范围要比 short 类型大,不能将表示范围大的值赋给表示范围小的变量。

  7. 如下代码可以通过编译:

    short a = 1;

    int b = a;

    a 是 short 类型,b 是 int 类型,int 类型表示的数据范围要比 short 类型大,可以将表示范围小的值赋给表示范围大的变量。

  8. 总结:可以将表示范围小的值赋给表示范围大的变量;但不能直接将表示范围大的值赋给表示范围小的变量,只能通过强制类型转换实现。

文章更新历史

2022/05/08 fix:修改备注。

编辑 (opens new window)
#类型#表示#使用#范围#变量#陷阱
上次更新: 2023/02/22, 13:47:25
Java_SE_第二讲:原生数据类型
Java_SE_第四讲:运算符

← Java_SE_第二讲:原生数据类型 Java_SE_第四讲:运算符→

最近更新
01
解决css部分border被圆角切掉之后圆角的边框消失问题
03-18
02
使用TypeScript开发一个自定义的Node-js前端开发脚手架
03-08
03
Github-Actions使用release-please实现自动发版
03-06
更多文章>
Theme by Vdoing | Copyright © 2011-2023 Terwer Green | MIT License | 粤ICP备2022020721号-1 | 百度统计
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式