数据类型的一些注意事项

导读:本篇文章讲解 数据类型的一些注意事项,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

第一章 数据类型与运算符


提示:本文只罗列出JAVA数据类型的一些注意事项,相关的基础知识并不会一一去详细说明。


前言

之前有写过IDEA如何从创建项目到类的详细步骤。

以下是链接:《JAVA SE》IntelliJ IDEA创建项目以及注意事项

下面将会给老铁们介绍一下Java数据类型和运算符的一些注意的要点。

一、八大基本数据类型和引用类型

数据类型分为八大基本类型以及引用数据类型,以下是博主用XMind做的思维导图:
数据类型
注意:
1.String在Java中是属于引用类型。

2.类名称的首字母大写。

3.布尔型只有两个值,不能类型转换成int。

4.int为4字节和操作系统与JVM无关。(这里说一下自己见解,之前用VC的时候C语言里面的int是四字节,但用C-FREE的时候int是2字节,我怀疑不止和计算机内部存储有关还和IDE也有点关系~)

5.八大基本类型中,int和char的包装类比较特殊,需要写全称。
在这里插入图片描述
6.定义常量使用final关键字。

二、字面量

程序中直接写出来的值,称为字面量。

例如:

100 –> 整型字面量,默认是int类型

‘a’ –>字符型字面量,默认是char类型

50.5 –>浮点数(小数)字面量,默认是double类型

”abc“ –>字符串型字面量,默认是String类

如下图:在这里插入图片描述100.0默认是double类型的字面量,直接赋值给float类型的a会报错。此时需要修改100.0为100.0F才可以正常运行。

在这里插入图片描述

三、double类型的精度丢失问题

Java 中的 double 虽然也是 8 个字节, 但是浮点数的内存布局和整数差别很大, 不能单纯的用 2 ^ n 的形式表示数据范围。

Java 的 double 类型的内存布局遵守 IEEE 754 标准(和C语言一样), 尝试使用有限的内存空间表示可能无限的小数, 势必会存在一定的精度误差。

在这里插入图片描述
解决办法:

1.仍然使用double,但我们一般只看小数点后六位

2.使用BigDecimal类来代替double的使用。

四、字符串拼接

字符串的 + 操作, 表示字符串拼接

例如:字符串与整数的拼接

String str = "result = "; 
int a = 10; 
int b = 20; 
String result = str + a + b; 
System.out.println(result); 
// 执行结果
result = 1020 
 

以上代码说明, 当一个 + 表达式中存在字符串的时候, 都是执行字符串拼接行为。

因此我们可以很方便的使用 System.out.println 同时打印多个字符串或数字。

五、变量的命名规则

硬性指标:
1.一个变量名只能包含数字, 字母, 下划线
2.数字不能开头。
3.变量名是大小写敏感的. 即 num 和 Num 是两个不同的变量。

注意: 虽然语法上也允许使用中文/美元符($)命名变量, 但是强烈不推荐这样做.

软性指标:
1.变量命名要具有描述性, 见名知意
2.变量名不宜使用拼音(但是不绝对)。
3.变量名的词性推荐使用名词
4.变量命名推荐 小驼峰命名法, 当一个变量名由多个单词构成的时候, 除了第一个单词之外, 其他单词首字母都大写.

六、类型转换问题

1.不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型

如以下代码:
long 表示的范围更大, 可以将 int 赋值给 long, 但是不能将 long 赋值给 int。
double 表示的范围更大, 可以将 int 赋值给 double, 但是不能将 double 赋值给 int。

int a = 10; 
long b = 20; 
a = b; // 编译出错, 提示可能会损失精度. 
b = a; // 编译通过. 
int a = 10; 
double b = 1.0; 
a = b; // 编译出错, 提示可能会损失精度. 
b = a; // 编译通过.

2.如果需要把范围大的类型赋值给范围小的, 需要强制类型转换, 但是可能精度丢失.

int a = 0; 
double b = 10.5; 
a = (int)b; //精度会丢失
int a = 10; 
boolean b = false; 
b = (boolean)a; // 编译出错, 提示不兼容的类型,boolean不能转换

强制类型转换不是一定能成功, 互不相干的类型之间无法强转

1.byte和byte的运算问题

错误的写法:

byte a = 10; 
byte b = 20; 
byte c = a + b; 
System.out.println(c); 
// 编译报错
Test.java:5: 错误: 不兼容的类型:int转换到byte可能会有损失

结论:
1.byte 和 byte 都是相同类型, 但是出现编译报错. 原因是, 虽然 a 和 b 都是byte, 但是计算 a + b 会先将 a 和 b 都提升成 int, 再进行计算, 得到的结果也是 int, 这是赋给 c, 就会出现上述错误。
2.由于计算机的 CPU 通常是按照 4 个字节为单位从内存中读写数据. 为了硬件上实现方便, 诸如 byte 和 short 这种低于4 个字节的类型, 会先提升成 int, 再参与计算。

正确的写法:

byte a = 10; 
byte b = 20; 
byte c = (byte)(a + b); 
System.out.println(c); 

2.int 和 String 之间的相互转换

int 转成 String:

int num = 10; 
// 方法1 
String str1 = num + ""; 
// 方法2 
String str2 = String.valueOf(num); 

String 转成 int:

String str = "100"; 
int num = Integer.parseInt(str); 

总结

隐式类型转换和类型提升, 是本章的难点. 但是一般我们更推荐在代码中避免不同类型混用的情况, 来规避类型转换和类型提升的问题。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/115507.html

(0)
Java光头强的头像Java光头强

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!