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

Terwer Java SE评论34字数 874阅读2分54秒阅读模式
  1. Java 中的原生数据类型共有 8 种:

    1) 整型:使用 int 表示。(32 位)文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    2) 字节型:使用 byte 表示。(表示-128~127 之间的 256 个整数, 8 位)。文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    3)短整型:使用 short 表示。(16 位)文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    4)长整型:使用 long 表示。(64 位)文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    5)单精度浮点型:使用 float 表示。所谓浮点型,指的就是小数,也叫做实数,比如 1.2。文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    6)双精度浮点型:使用 double 表示。双精度浮点型表示的数据范围要比单精度浮点型大。文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    7)字符型:使用 char 表示(char 是 character 的缩写)。所谓字符,就是单个的字符表示,
    比如字母 a,或者中文张,外面用单引号包围上。比如 char a = ‘B’; char b = ‘张’;文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    8)布尔类型,使用 boolean 表示。布尔类型只有两种可能值,分别是 true 与 false。文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

  2. Java 中的所有浮点类型默认情况下都是 double。不能将 double 类型的值赋给 float 类型的变量,即便该 double 类型的值处于 float 类型的范围内也是不可以的。总之,能否成功赋值取决于等号右边的值类型与等号左边的变量类型是否一致。
  3. 如何将 double 类型的值赋给 float 类型的变量?答案就是文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    (1)强制类型转换,将 double 类型的值强制转换为 float 类型。文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    (2)使用 java 语言的支持。文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    强制转换的语法: 类型 变量名 = (类型)变量值;文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

  4. 变量在使用前必须要赋值;变量必须要声明其类型方可使用;变量在使用前必须要定义,并且只能定义一次。
  5. 如下代码无法通过编译:文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    int a = 1;文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

  6. short b = a;文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    a 是 int 类型,b 是 short 类型,int 类型表示的数据范围要比 short 类型大,不能将表示范围大的值赋给表示范围小的变量。文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

  7. 如下代码可以通过编译:文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    short a = 1;文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    int b = a;文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

    a 是 short 类型,b 是 int 类型,int 类型表示的数据范围要比 short 类型大,可以将表示范围小的值赋给表示范围大的变量。文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

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

文章更新历史文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

2022/05/08 fix:修改备注。 文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html

文章源自浅海拾贝-https://blog.terwergreen.com/pitfalls-of-using-primitive-data-types.html
相关文章
  • 扫码加我微信
  • 验证消息请输入:来自你的博客
  • weinxin
  • 我的微信公众号
  • 微信扫一扫与我交流吧
  • weinxin
Terwer
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: