类型转换分为自动转换和强制转换。
自动转换一般是类型存储位数低的转向类型存储位数高的,
byte(1字节)->short(2)->char(2)->int(4)->long(8)->float(4)->double(8),前面的可以自动转换到后面的,自动类型转换一般不会导致数据丢失。因为存储位数低的类型对象只需在其二进制码前补上相应的0即可转换成存储位数高的类型,不会导致数据丢失。强制转换恰好相反,存储位数高的类型对象要截断高位二进制码才能转换成存储位数低的类型,截断将导致数据丢失。
short char之间的转换
short和char的区别就是short是有符号位整数,取值范围为-32768~32767,char是无符号位的,取值范围为0~65535。由于最高位二进制码代表的意义不同,所以无论是从short到char又或者从char到short都有可能发生丢失精度。
浮点 整数之间的转换
float的类型存储形式:符号位1位,指数8位,尾数(小数部分)23位。由于科学计数法,化为二进制的整数部分必为1,所以不需记录整数部分。
例子:
123456789 二进制 111010110111100110100010101 科学计数法表示就是1.11010110111100110100010101*2^26。正数,符号位0,指数26,为00011010,尾数11010110111100110100010101,但尾数位只有23位,截断,精度丢失,所以为11010110111100110100011(第23位为0,24位为1,0舍1入,所以23位为1)。最后变成1.11010110111100110100011*2^26
int i = 123456789;
float f1 = i;
System.out.println(f1);//打印转型后的float
打印结果:
1.23456792E8(精度已丢失)
用计算器将十进制的123456792转换成二进制得111010110111100110100011000
正是上述的1.11010110111100110100011*2^26,所以整形转浮点型有可能出现精度丢失。
最后还是没能理解ieee754标准,搞不清楚float在内存中是怎么存的。求大神告知。
分享到:
相关推荐
在LabVIEW编程环境中,强制类型转换是至关重要的一个环节,特别是在涉及到数据通信,如TCP/IP通信时。本文将深入探讨LabVIEW中强制类型转换的概念、使用场景以及具体操作方法。 LabVIEW是一种图形化编程语言,它的...
在IT领域,字符串类型转换是编程中非常基础且重要的部分,尤其在处理不同编码、数据类型转换时,掌握各种string类型的转换方法对于提高程序的健壮性和灵活性至关重要。以下将详细解析从给定文件中提取出的关于“各种...
在C#编程中,类型转换是开发者经常遇到的操作,它涉及到不同数据类型的相互转化。本文将深入探讨C#中常见的类型转换扩展,并介绍如何通过扩展方法来增强类型转换的便捷性和可读性。 首先,我们要了解C#内置的类型...
VHDL 数据类型转换函数 VHDL 中的数据类型转换函数是指在 VHDL 程序中将不同类型的数据相互转换的函数。这些函数的作用是实现不同类型的数据之间的转换,以便正确地进行赋值操作。 在 VHDL 中,数据类型转换函数...
在C++编程中,数据类型的相互转换是一种常见的操作,它涉及到不同数据类型的变量之间值的迁移。本篇文章将深入探讨C++中不同类型的转换方法,包括隐式转换和显式转换,以及它们在实际编程中的应用。 首先,我们讨论...
"C++强制类型转换函数详解" C++中强制类型转换函数是指使用强制类型转换操作符来实现类型转换的过程。C++风格的类型转换提供了4种类型转换操作符来应对不同场合的应用,即const_cast、static_cast、dynamic_cast和...
C++ 到 C# 数据类型转换 在软件开发中,数据类型转换是一个非常重要的步骤,特别是在使用不同的编程语言时。C++ 和 C# 是两种非常流行的编程语言,它们之间的数据类型转换是非常必要的。本文将详细介绍 C++ 到 C# ...
在探讨“数据库中CLOB类型转换的问题”这一主题时,我们首先需要理解CLOB(Character Large Object)数据类型的基本概念及其在数据库中的应用场景。随后,将深入分析CLOB类型转换过程中可能遇到的问题,并提供相应的...
西门子数据类型转换在工业自动化领域中是一个关键的议题,特别是在使用西门子S7系列PLC(可编程逻辑控制器)时。S7系列PLC支持多种数据类型,包括INT、DINT、REAL、STRING等,这些数据类型在不同场景下各有其应用。...
在Java开发中,类型转换是常见的操作,尤其是在处理数据绑定或者序列化时。Spring框架提供了强大的数据绑定功能,其中就包括自动类型转换。然而,有时系统默认的转换器可能无法满足我们所有的需求,这时就需要自定义...
RTTI对于异常处理、多态性以及类型安全的转换至关重要。C++标准提供了两个主要的手段来利用RTTI:`typeid`运算符和类型转换。 `typeid`运算符提供了在运行时检查对象类型的能力。`typeid`有两种形式:`typeid(type_...
### C语言隐式类型转换规则详解 #### 一、引言 C语言作为一种广泛使用的编程语言,具有严格的类型检查机制。在C语言中,不同类型的数值可以通过类型转换来进行混合运算。这种转换分为两种:隐式类型转换和显式类型...
显式类型转换,也称为类型强制转换,允许程序员明确地将一个数据类型的值转换为另一个数据类型。这在处理不同数据精度或者需要特定类型变量时尤其有用。本篇文章将深入探讨显式类型转换,特别是将变量转换为浮点型和...
在C++编程语言中,类的转换是一种重要的特性,它允许程序员定义类对象与内置数据类型之间以及不同自定义类之间的转换方式。这种转换通常分为两种类型:转换构造函数和成员转换函数,这两种方法都遵循C++的隐式类型...
### MySQL 数据类型转换详解 #### 一、引言 在MySQL数据库中,数据类型转换是一项非常重要的技能。它可以帮助我们灵活地处理不同类型的数据,尤其是在进行数据检索或处理时,经常需要将一种数据类型转换为另一种...
在VC++编程环境中,类型转换是一项非常常见的操作,特别是在处理不同数据类型之间的交互时。VC++,即Visual C++,是Microsoft开发的一款强大的C++集成开发环境,它支持多种类型的类型转换,包括隐式转换和显式转换。...
### 自定义类型转换器 #### 一、概述 在Java编程中,经常需要处理不同数据类型之间的转换。例如,从用户界面获取的数据通常是字符串形式,而程序内部可能需要将其转换为日期、数字等其他类型。Struts2框架提供了一...
### 数据库技术:SQL数据类型转换 在数据库管理和查询操作中,经常需要对不同数据类型进行转换以满足特定的需求或实现特定的功能。SQL Server 提供了两种常用的数据类型转换方式:`CAST()` 和 `CONVERT()` 函数。这...
在程序开发过程中经常需要进行数据的类型转换,而且如果一个字段的类型改成另一个类型时,所有相关的类型转换的地方都要跟着修改,不但造成了很多重复转换的代码而且修改字段类型时额外修改相关转换代码的工作量也很...
### C++中的四种类型转换详解 #### 一、引言 C++作为一种强大的面向对象编程语言,支持多种类型的转换机制,这些转换机制不仅能够帮助程序员处理数据类型之间的兼容性问题,还能确保程序的安全性和正确性。本文将...