数据类型的一些注意事项

简介: 本文只罗列出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); 

总结

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

相关文章
|
存储 编译器 程序员
C++基础篇之什么是数据类型
C++基础篇之什么是数据类型
|
2月前
|
存储 C# 索引
C# 一分钟浅谈:变量与数据类型简介
【9月更文挑战第1天】在 C# 编程中,了解变量与数据类型至关重要。本文详细介绍了 C# 中的值类型(如整数、浮点数、布尔值等)和引用类型(如类、接口、数组、字符串)。通过示例代码展示了变量的声明与使用方法,并针对数据类型转换错误、变量未初始化及数值溢出等常见问题提供了解决方案。正确选择数据类型不仅能提升程序性能,还可避免潜在错误,有助于编写高质量代码。
130 47
|
2月前
|
存储 Linux C语言
【C++基础】数据类型详解
这篇文章详细介绍了C++中各种基本数据类型,包括整型、浮点型、字符型、字符串型和布尔型,以及它们的使用方式和范围。
24 4
|
6月前
|
Java
自定义的数据类型
自定义的数据类型
60 0
|
6月前
|
存储 C#
C# 数据类型与类型转换:包含教程与示例
使用正确的数据类型对应于相应的变量是重要的;这样可以避免错误、节省时间和内存,还会使您的代码更易于维护和阅读。最常见的数据类型有:
64 0
|
11月前
枚举的使用和注意事项
枚举的使用和注意事项
48 0
|
11月前
|
存储 编译器 C#
C# 变量数据类型的使用和案例(基础篇)
C# 变量数据类型的使用和案例(基础篇)
|
C#
57【C#基础】C#数据类型总结
【C#基础】C#数据类型总结
63 0
C#基础Ⅲ-数据类型
C#基础Ⅲ-数据类型
|
存储 安全 Java
【C#基础】C# 数据类型总结
编程语言 C# 数据类型的介绍 。
102 0
【C#基础】C# 数据类型总结