当前位置: 首页 > 面试题库 >

Java:为什么我们需要强制转换而不是双精度?

佘京
2023-03-14
问题内容

我不知道您是否认为这是一个重要问题,但我想知道。float是一个浮点数(4个字节)。double是浮点数(8个字节)。为什么我们定义双重假名铸造:

double d = 2.1;

但是我们需要使用浮点数进行转换:

float f = (float) 2.1;

要么

float f = 2.1f;

先感谢您。


问题答案:

如果浮点文字以字母F或结束,则其类型为float f。否则,其类型为double,并且可以选择以字母D或结尾d

浮点类型(floatdouble)也可以使用E或e(对于科学记数法),Ff(32位浮点文字)和Dd(64位双精度文字;这是默认值,并且按照惯例被省略)来表示。

double d1 = 123.4;
// same value as d1, but in scientific notation
double d2 = 1.234e2;
float f1  = 123.4f;

请参见oracle Java教程中的浮点文字



 类似资料:
  • 我现在正在学习遗传和多态性,除此之外,我也理解它。为什么我需要投三个。setY()不应该已经可以访问它了,因为我正在创建一个从G类继承的H对象。 第8行是语法错误。

  • 问题内容: 我正在使用Java 1.6.0_25。 我定义了一个注释: 后来当我使用getAnnotation时: 编译器和IDE同意我必须强制转换结果,但是getAnnotation在Java 1.5文档中声明为: 由于Resource.class是Class类型,在我看来,这意味着cls.getAnnotation(Resource.class)应该返回Resource类型,并且我需要进行强制

  • 问题内容: 我正在编写一个Android应用程序,只是好奇为什么我们必须始终在Android中进行类型转换。我了解我们需要确定类型,以便我们的代码正常运行,但是也许还有其他原因吗? 范例 : 在这个问题的上下文中,我问为什么我们必须类型转换findViewById的返回值。(我也很好奇如果可以解释的话,这种类型的转换是如何完成的。) 问题答案: 从文件加载资源。它返回某种,但是Java编译器无法知

  • 问题内容: 我对Maven快照的含义以及为什么要构建一个快照感到困惑。 问题答案: Maven中的快照版本尚未发布。 这个想法是,前一个版本(或任何其他版本)完成后,存在一个。那个版本可能会变成 。它基本上是“ 开发中”。这可能接近实际发行版,或相当遥远(0.9例如,发行后立即发行)。 “真实”版本和快照版本之间的区别在于快照可能会得到更新。这意味着今天下载的文件可能不同于昨天或明天下载的文件。

  • 问题内容: 直到今天,我还以为例如: 只是以下方面的捷径: 但是,如果我们尝试这样做: 然后;将不会编译,但;会编译良好。 这是否意味着实际上;是类似这样的捷径 ? 问题答案: 与这些问题一样,JLS保留了答案。在这种情况下,第1.5.26.2节“复合赋值运算符”。摘录: 形式的复合赋值表达式等效于,其中T是的类型,不同之处在于该表达式E1仅被评估一次。 §15.26.2中引用的示例 以下代码正确

  • 我为JavaFX TableColumn创建了一个扩展函数,使得在没有重复样板的情况下实现cellFactory更加简洁。扩展函数定义如下: 为了格式化TableCell,我只需要定义TableCell中应该发生什么。当当前单元格有非空项可用时更新项。例如,要格式化LocalDateTime,我现在可以编写: 然后我继续定义另一个扩展来执行此操作,因此我可以编写: 此函数使用第一个函数,如下所示: