数据类型转换隐式转换及显式转换两种方式
liebian365 2024-10-20 09:57 21 浏览 0 评论
数据类型转换
类型转换是将一个值从一种类型更改为另一种类型的过程。
如:将 String型 类型数据“45”转换为一个整型数据,而且可以将任意类型的数据转换为 String 类型。
如果从低精度数据类型向高精度数据类型转换,则永远不会溢出,并且总是成功的;而把高精度数据类型向低精度数据类型转换则必然会有信息丢失,有可能失败。
数据类型转换有两种方式,即隐式转换与显式转换。
1 隐式转换
从低级类型向高级类型的转换,系统将自动执行,不会丟失信息,无须进行任何操作,直接赋值运用。这种类型的转换称为隐式转换,不用刻意,直接自动转化隐式转换也可以称为自动转换。
下列基本数据类型会涉及数据转换顺序
这些类型按精度从“低”到“高”排列的顺序为byte(1字节)<short (2字节)<int(char互换,在数据类型允许范围内可互换)< long (8字节)< float(4字节)<double(8字节)。
Java中的整形数据类型是指数据没有小数部分。Java有4种整型数据类型,分别是byte、short、int和long。这些数据类型的精度大小不同根据字节长度判定,从高到低排列依次为:long、int、short和byte。
long类型精度最高,它的取值范围为-2^63到2^63-1,所以在大数值的计算运算过程中需要使用long类型。int类型的精度是次高的,它的取值范围为-2^31到2^31-1,一般情况下,整数计算需要使用int类型。short类型的精度较低,取值范围为-2^15到2^15-1,一般使用short类型时数据不应太大。byte类型的精度是最低的,取值范围为-2^7到2^7-1。
Java中的浮点型有两种,分别是float和double。与整型数据类型不同,浮点型数据类型的精度是由小数点后的位数来确定的,它们的精度大小,从高到低排列依次为:double和float。浮点数小数点前位数用阶乘
表示,兼整数小数,精度高于整数。
使用int型变量为 float 型变量赋值,此时 int型变量将隐式转换成 float型变量。直接自动转换,无需转换同一类型,再进行赋值给变量。
int x = 50; // 声明int 型变量x
float y = x; // 将x赋值给y
此时执行输出语句, y的结果将是50.0。
隐式类型的转换需要遵循一定的规则,补充位数,不影响数据大小。
隐式转换从低精度向高精度转化来创建不同数值类型的变量。
public class ImplicitConversion {
public static void main(String[] args) {
// 声明byte型变量mybyte,并把byte型变量允许的值赋给 mybyte
byte mybyte = 127;
int myint = 150; // 声明int 型变量myint, 并赋值150
float myfloat = 452.12f; // 声明float型变量 myfloat, 并赋值
char mychar= 10; // 声明 char 型变量mychar,并赋值
double mydouble = 45.46546;// 声明 double型变量,并赋值
/*将运算结果输出 */
System. out. println("byte型与 float 型数据进行运算结果为:"+(mybyte+myfloat));
System. out. println("byte型与int 型数据进行运算结果为: " + mybyte * myint);
System. out. println("byte型与 char型数据进行运算结果为: " + mybyte / mychar);
System. out. println("double型与 char 型数据进行运算结果为: " + (mydouble +mychar));
}
}
运行结果:
byte型与float型数据进行运算结果为: 579.12
byte型与int型数据进行运算结果为: 19050
byte型与char型数据进行运算结果为: 12
double型与char型数据进行运算结果为: 55.46546
如果实例中的float和 int交换了位置,编译环境就会弹出“float值无法转变成int值”的错误。
float x = 50;
int y = x;
/*应用int y=(int)x */
float 值无法转变成int值时,需要用到显示转换。
2 显式转换
当把高精度的变量值赋给低精度的变量时,必须使用显式类型转换运算(又称强制类型转换),当执行显式类型转换时可能会导致精度损失。
语法如下:
(类型名) 要转换的值
显式数据类型转换:
将不同的数据类型进行显式类型转换。
public class ExplicitConversion {
public static void main(String[] args) {
int a = (int) 45.23; // double 类型强制转化成 int类型
long b = (long) 456.6F; // float 类型强制转化成 long 类型
char c = (char) 97.14;// double 型强制转换成 char型
System. out. println("45.23强制转换成 int的结果: " + a);
System. out. println("456.6F强制转换成long 的结果: " + b);
System. out. println("97.14 强制转换成 char 的结果" + c);
运行结果如图2.12所示。
45.23强制转换成int的结果:45
456.6F强制转换成long的结果: 456
97.14强制转换成char的结果a
当执行显式类型转换时可能会导致精度损失。
当把整数赋值给一个byte、short、int、long型变量时,不可以超出这些变量的取值范围,否则必须进行强制类型转换,会丟了信息。例如:
byte b = (byte)129;
什么情况下数据会强制转换
1.同类型大数据类型需要转换为小数据类型。例如,long类型需要转换为int类型,double类型需要转换为float类型。
2. 浮点数类型需要转换为整数类型。例如,float类型需要转换为int类型。
如:double类型数据被强制转换成int类型的数据
public class Test {
public static void main(String[] args) {
double doubleNum = 3.1415926;
int intNum = (int) doubleNum; System.out.println("强制转换前的double值为:" + doubleNum);
System.out.println("强制转换后的int值为:" + intNum);
}
}
将一个double类型的变量doubleNum强制转换为int类型的变量intNum。强制转换的语法是在需要转换的变量前加上括号并在括号内指定目标类型。在强制转换后,原始值被截断为整数,发生精度丢失。
相关推荐
- 月薪 4K 到 4W 的运维工程师都经历了什么?
-
运维工程师在前期是一个很苦逼的工作,在这期间可能干着修电脑、掐网线、搬机器的活,显得没地位!时间也很碎片化,各种零碎的琐事围绕着你,很难体现个人价值,渐渐的对行业很迷茫,觉得没什么发展前途。这些枯燥无...
- 计算机专业必须掌握的脚本开发语言—shell
-
提起Shell脚本很多都有了解,因为无论是windows的Dom命令行还是Linux的bash都是它的表现形式,但是很多人不知道它还有一门脚本编程语言,就是ShellScript,我们提起的Shel...
- Linux/Shell:排名第四的计算机关键技能
-
除了编程语言之外,要想找一份计算机相关的工作,还需要很多其他方面的技能。最近,来自美国求职公司Indeed的一份报告显示:在全美工作技能需求中,Linux/Shell技能仅次于SQL、Java、P...
- 使用Flask应用框架在Centos7.8系统上部署机器学习模型
-
安装centos7.8虚拟环境1、镜像链接...
- shell编程
-
简介:Shell是一个用C语言编写的程序,它是用户使用Linux的桥梁。Shell既是一种命令语言,又是一种程序设计语言。...
- 14天shell脚本入门学习-第二天#脚本和参数#排版修正
-
脚本是一种包含一系列命令的文本文件,通常用于自动化任务。Shell脚本是用Shell命令编写的脚本,可以在命令行中执行。掌握脚本的基础知识和变量的使用是编写高效脚本的关键。...
- 嵌入式Linux开发教程:Linux Shell
-
本章重点介绍Linux的常用操作和命令。在介绍命令之前,先对Linux的Shell进行了简单介绍,然后按照大多数用户的使用习惯,对各种操作和相关命令进行了分类介绍。对相关命令的介绍都力求通俗易懂,都给...
- 实现SHELL中的列表和字典效果
-
大家好,我是博哥爱运维。编写代码,很多情况下我们需要有种类型来存储数据,在python中有列表和字典,golang中有切片slice和map,那么在shell中,我们能否实现列表和字典呢,答案是肯定的...
- 14天shell脚本入门学习-第二天#脚本和变量
-
脚本是一种包含一系列命令的文本文件,通常用于自动化任务。Shell脚本是用Shell命令编写的脚本,可以在命令行中执行。掌握脚本的基础知识和变量的使用是编写高效脚本的关键。...
- shell常用命令之awk用法介绍
-
一、awk介绍awk的强大之处,在于能生成强大的格式化报告。数据可以来自标准输入,一个或多个文件,或者其他命令的输出。他支持用户自定义函数和动态正则表达式等先进功能,是Linux/unix一个强大的文...
- Linux编程Shell之入门——Shell数组拼接与合并
-
在Shell中,可以使用不同的方式实现数组拼接和合并。数组拼接指将两个数组中的元素合并成一个数组,而数组合并指将两个数组逐个组合成一个新数组。以下是关于Shell数组拼接和合并的详细介绍:数...
- shell中如何逆序打印数组的内容,或者反转一个数组?
-
章节索引图首先请注意,有序的概念仅适用于索引数组,而不适用于关联数组。如果没有稀疏数组,答案会更简单,但是Bash的数组可以是稀疏的(非连续索引)。因此,我们需要引入一个额外的步骤。...
- 如何学好大数据开发?---shell基本语法
-
昨天我们初步了解到了shell的一些基本知识,比如shell的分类,常用的shell类型。今天就带来大数据开发之shell基本语法,掌握好基础才是最重要的,那接下来就开始学习shell的基本语法。一、...
- Linux编程Shell之入门——Shell关联数组
-
关联数组是Shell中一种特殊的数组类型,它使用字符串作为下标。在关联数组中,每个元素都被标识为一个唯一的字符串键值,也称为关联数组的索引。在Shell中,可以使用declare或typeset命令...
- 从编译器视角看数组和指针
-
虽然有单独的文章描述数组和指针,但二者的关系实在值得再写一篇文章。...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- wireshark怎么抓包 (75)
- qt sleep (64)
- cs1.6指令代码大全 (55)
- factory-method (60)
- sqlite3_bind_blob (52)
- hibernate update (63)
- c++ base64 (70)
- nc 命令 (52)
- wm_close (51)
- epollin (51)
- sqlca.sqlcode (57)
- lua ipairs (60)
- tv_usec (64)
- 命令行进入文件夹 (53)
- postgresql array (57)
- statfs函数 (57)
- .project文件 (54)
- lua require (56)
- for_each (67)
- c#工厂模式 (57)
- wxsqlite3 (66)
- dmesg -c (58)
- fopen参数 (53)
- tar -zxvf -c (55)
- 速递查询 (52)