java隐式方法(java隐式调用)

发布时间:2022-11-09

本文目录一览:

  1. java新手 问一下 隐式调用 ?? 如何查看隐式调用的方法?
  2. java中什么是显式类型转换和隐式类型转换?
  3. 关于java中的隐式调用问题

java新手 问一下 隐式调用 ?? 如何查看隐式调用的方法?

看源代码, System.out.println 的源码是这样的:

public void println(Object x) {
    String s = String.valueOf(x);
    synchronized (this) {
        print(s);
        newLine();
    }
}

然后 String.valueOf 的源代码是这样的:

public static String valueOf(Object obj) {
    return (obj == null) ? "null" : obj.toString();
}

所以就是调用的 objtoString 方法。

java中什么是显式类型转换和隐式类型转换?

自动类型转换,也称隐式类型转换,是指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以 Java 语言在设计时,没有为该操作设计语法,而是由 JVM 自动完成。

转换规则

从存储范围小的类型到存储范围大的类型。 具体规则为:

byte → short (char) → int → long → float → double

也就是说 byte 类型的变量可以自动转换为 short 类型,示例代码:

byte b = 10;
short sh = b;

这里在赋值时,JVM 首先将 b 的值转换为 short 类型,然后再赋值给 sh。 在类型转换时可以跳跃。示例代码:

byte b1 = 100;
int n = b1;

注意问题

在整数之间进行类型转换时,数值不发生改变,而将整数类型,特别是比较大的整数类型转换成小数类型时,由于存储方式不同,有可能存在数据精度的损失。 强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型的转换。

转换规则

从存储范围大的类型到存储范围小的类型。 具体规则为:

double → float → long → int → short (char) → byte

语法格式

(转换到的类型) 需要转换的值

示例代码:

double d = 3.10;
int n = (int)d;

这里将 double 类型的变量 d 强制转换成 int 类型,然后赋值给变量 n。需要说明的是小数强制转换为整数,采用的是“去1法”,也就是无条件的舍弃小数点的所有数字,则以上转换出的结果是 3。整数强制转换为整数时取数字的低位,例如 int 类型的变量转换为 byte 类型时,则只取 int 类型的低 8 位(也就是最后一个字节)的值。 示例代码:

int n = 123;
byte b = (byte)n;
int m = 1234;
byte b1 = (byte)m;

b 的值还是 123,而 b1 的值为 -46b1 的计算方法如下:m 的值转换为二进制是 10011010010,取该数字低 8 位的值作为 b1 的值,则 b1 的二进制值是 11010010,按照机器数的规定,最高位是符号位,1 代表负数,在计算机中负数存储的是补码,则该负数的原码是 10101110,该值就是十进制的 -46

注意问题

强制类型转换通常都会存储精度的损失,所以使用时需要谨慎。

关于java中的隐式调用问题

这是因为 System.out.println 这个方法可以打印出任何对象或者数据类型的关系。 他可以打印出 8 种基本类型和对象,基本类型就不说了,如果他发现参数为对象的话,会自动调用该对象的 toString() 方法进行打印,这也就是所谓的隐式调用了。 你的 R1R2 是对象,所以他会选择该对象中的 toString() 方法,然后打印。toString() 是由 Object 类派生的,所以任何对象都拥有这个方法。