Java强制转化示例代码详解

2025-03-25 15:50

本文主要是介绍Java强制转化示例代码详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Java强制转化示例代码详解》:本文主要介绍Java编程语言中的类型转换,包括基本类型之间的强制类型转换和引用类型的强制类型转换,文中通过代码介绍的非常详细,需要的朋友可以参考下...

引入

Java编程语言中,类型转换(无论是强制类型转换还是自动类型转换)的方向并不是简单地基于“高位”和“低位”的概念,而是基于数据类型的范围和精度。

基本类型强制转换

1.数字之间

short s = 100;
int i = s; // 自动类型转换,安全

int j = 30000; // 一个大于short类型能表示的最大值的int
short k = (short) j; // 强制类型转换,可能导致数据丢失

上面给出了两种数值转换的概念,第一种是short转成int类型,由于short是16位的,int是32位的,此时就是低精度转为高精度,所以编译器会自动进行类型转换,是安全的,不用强转(因为这种转换是安全China编程的,不会丢失任何信息,只是简单地扩展了符号位)

而第二种则是让int类型转成short,高精度转低精度,不安全,强制类型转换,short只能存储低16位的数据,高16位的位置就舍弃了,所但凡int的高16位存有数据,此时的强转就会发生数据丢失。

所以通常而言,这种高精度强转低精度是没有意义的。

2.数字字符之间

引入

以前有涉及过steam,buffer的概念,并且它们本质都是数编程China编程组。

int c=23456;
char d=(char) c; //将int类型的c强转成char类型的d
System.out.println(d); //并且能够解析http://www.chinasem.cn输出

steam就是类似如下的一串二进制数字,在解析时以8位或32位等解析成十进制,就可以得到不同的结果:

Java强制转化示例代码详解

 int[] arr={23456,23457,34567,23876,32447};
 for(int x:arr){//解析输出
      char e=(char) x;
      System.out.println(e);        
 }                             

【以上就是两个基本类型强制转换的例子,而且基本类型之间都可以进行强转,只是有的没有意义。】

引用类型的强制转换

引入多态概念前提

e.g.首先,我们定义一个父类Animal,并在其中声明一个方法makeSound,但不在父类中实现它(可以将它设为抽象方法,但在这个例子中,我们为了简化,让它返回一个默认字符串)。然后,我们创建两个子类DogCat,它们都继承自Animal类,并各自实现了makeSound方法。

// 父类 Animal
class Animal {
    // 可以是一个抽象方法,但这里为了简化,我们提供一个默认实现
    public String makeSound() {
        return "Some generic animal sound";
    }
}

// 子类 Dog 继承自 Animal
class Dog extends Animal {
    @Override
    public String makeSound() {
        return "Woof! Woof!";
    }
}

// 子类 Cat 继承自 Animal
class Cat extends Animal {
    @Override
    public String makeSound() {
        return "Meow! Meow!";
    }
}

public class PolymorphismExample {
    public static void main(String[] args) {
        // 使用父类类型的引用来指向子类对象
        Animal myDog = new Dog();
        Animal myCat = new Cat();

        // 调用被重写的方法,将展示多态性
        System.out.println(myDog.makeSound()); // 输出: Woof! Woof!
        System.out.println(myCat.makeSound()); // 输出: Meow! Meow!

        // 尽管 myDog 和 myCat 都是 Animal 类型的引用,
        // 但它们实际上指向的是 Dog 和 Cat 对象,
        // 因此调用 makeSound 方法时会执行子类中的实现。
    }
}

在这个例子中,展示了多态性的两个关键方面:

父类引用指向子类对象myDog是一个Animal类型的引用,但它实际上指向了一个Dog对象。同样,myCat是一个Animal类型的引用,但它指向了一个Cat对象。

方法重写DogCat类都重写了Animal类中的makeSound方法。因此,当通过myDogmyCat引用调用makeSound方法时,会分别调用DogCat类中的实现。

以上例子展示了多态所遵守的两项,下面是完整的多态遵循条件:

要符合多态,通常需要满足以下几个条件:

继承:多态通常依赖于继承关系。在面向对象编程中,子类继承父类,从而可以重用父类的代码并扩展新的功能。多态性允许我们使用父类类型的引用来引用子类对象。

方法重写(Override):子类需要重写父类中的某些方法,以便在调用这些方法时能够表现出不同的行为。方法重写是多态性的关键所在,它允许子类提供父类方法的具体实现。

父类引用指向子类对象:这是多态性的另一个重要方面。我们可以创建一个父类类型的引用,并将其指向一个子类对象。当通过这个引用调用一个被重写的方法时,将调用子类中的该方法实现,而不是父类中的实现。

接口或抽象类:虽然多态性不一定需要接口或抽象类,但它们为多态性提供了强大的支持。接口和抽象类可以定义方法签名,而不提供具体实现。子类可以实现这些接口或继承这些抽象类,并提供具体的方法实现。这样,当使用接口或抽象类类型的引用来引用子类对象时,就可以实现多态性。

运行时类型识别(RTTI, Run-Time Type Identification):在Java等语言中,运行时类型识别是多态性的基础之一。它允许程序在运行时确定对象的实际类型,并根据这个类型来调用相应的方法。这是通过方法重写和父类引用指向子类对象来实现的。

【注意:虽然给出了这么多条件,但是多态性的核心在于方法重写和父类引用指向子类对象(句柄可以指向自己类的对象或者自己的子孙后代类的对象)这两个方面。】

【注意:引用类型之间的强制类型转换就没有这么自由了,会有诸多限制】

如下两个子类继承Person父类:

Java强制转化示例代码详解

Java强制转化示例代码详解

【注意:遵循一个类的句柄可以指向自己类的对象或者自己的子孙后代类的对象】

所以以下两种表达方式是错误的:

①直接报错:

Java强制转化示例代码详解

②运行时报错:

运行时报错是因为不符合多态,即“指向自己类的对象或者自己的子孙后代类的对象”,这里表示的是:

将s(指向Child2实例的Person类型变量)强转换成Child 3,Child2和Child3是兄弟关系,不符合多态。

Java强制转化示例代码详解

 如何解决以下问题呢?(o ∀ o )

有啦!!就用那招!((*)

引入关键字instanceof:

instanceof 是一个用于检查对象是否为特定类或其任何父类的实例的关键字。这个操作符返回一个布尔值:如果对象是指定类的实例,或者是该类的任何子类的实例,则返回 true;否则返回 false

if (object instanceof ClassName) {
    // 对象是指定类的实例或其子类的实例时执行的代码
}

其中:

  • object 是要检查的对象
  • ClassName 是要检查的类名(包括接口名)

还不理解没关系,以下给出一个实例:

class Animal {}
class Dog extends Animal {}
class Cat extends Animal {}

public class Main {
    public static void main(String[] args) {
        Animal myDog = new Dog();
        //Animal myDog = new Dog(); 创建了一个 Dog 类的实例,并将其引用赋值给 Animal 类型的变量 myDog。这意味着 myDog 指向的是一个 Dog 对象,但它在编译时被视为 Animal 类型。
        Animal myCat = new Cat();
       // Animal myCat = new Cat(); 类似地,创建了一个 Cat 类的实例,并将其引用赋值给 Animal 类型的变量 myCat。
        System.out.println(myDog instanceof Dog);    // 输出 true
        System.out.println(myDog instanceof Animal); // 输出 true
        System.out.println(myDog instanceof Cat);    // 输出 false
        System.out.println(myDog instanceof Object); // 输出 true

        System.out.println(null instanceof Animal);  // 输出 false
    }
}

在这个示例中,myDog 是 Dog 类的实例,也是 Animal 类和 Object 类的实例(因为所有类都继承自 Object)。因此,myDog instanceof Dog 返回 truemyDog instanceof Animal 也返回 true,但 myDog instanceof Cat 返回 false,因为 myDog 不是 Cat 的实例。同样地,null 不是任何类的实例,所以 null instanceof Animal 返回 false

public class Test{
    public static void main(String[] mmm) throws Exception{
        Child2 x=new Child2();
        //Child2 x = new Child2(); 创建了一个 Child2 类的实例,并将其引用赋值给 Child2 类型的变量 x。
        Child3 w=new Child3();
        //Child3 w = new Child3(); 创建了一个 Child3 类的实例,并将其引用赋值给 Child3 类型的变量 w。

        //句柄可以指向自己类的对象或者自己的子孙后代类的对象
        Person s=x; //父类指子类child2
        m1(s);
        
        s=w;
        m1(s);
        
        public static void m1(Person s){
            Child3 w=null;
            if(s instanceof Child3){
            //⭐使用instanceof关键字检查s是否是Child3的实例,如果是true,才进行下面的强转代码
               //⭐用instanceof来验证强转http://www.chinasem.cn⭐
                 w=(Child3) s;            
            }
                   
        }                                                           
    }
}

可以看见上面对m1() 方法进行了两次调用。

如果 s 指向的是 Child3 实例(在第二次调用 m1(s); 时),条件为真,代码块内的强转类型转换 w = (Child3) s; 会执行。如果 s 指向的是 Child2 实例(在第一次调用 m1(s); 时),条件为假,代码块内的代码不会执行。

总结

到此这篇关于Java强制转化的文章就介绍到这了,更多相关Java强制转化内容请搜索China编程(www.cppcns.cwww.chinasem.cnom)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于Java强制转化示例代码详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153928

相关文章

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

java streamfilter list 过滤的实现

《javastreamfilterlist过滤的实现》JavaStreamAPI中的filter方法是过滤List集合中元素的一个强大工具,可以轻松地根据自定义条件筛选出符合要求的元素,本文就来... 目录1. 创建一个示例List2. 使用Stream的filter方法进行过滤3. 自定义过滤条件1. 定

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

SpringCloud之consul服务注册与发现、配置管理、配置持久化方式

《SpringCloud之consul服务注册与发现、配置管理、配置持久化方式》:本文主要介绍SpringCloud之consul服务注册与发现、配置管理、配置持久化方式,具有很好的参考价值,希望... 目录前言一、consul是什么?二、安装运行consul三、使用1、服务发现2、配置管理四、数据持久化总

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

redis+lua实现分布式限流的示例

《redis+lua实现分布式限流的示例》本文主要介绍了redis+lua实现分布式限流的示例,可以实现复杂的限流逻辑,如滑动窗口限流,并且避免了多步操作导致的并发问题,具有一定的参考价值,感兴趣的可... 目录为什么使用Redis+Lua实现分布式限流使用ZSET也可以实现限流,为什么选择lua的方式实现