java bridge method

本文深入探讨了Java编译器如何通过生成桥接方法解决泛型兼容性问题,特别是在早期Java版本中缺乏泛型支持的情况下。通过示例代码展示了当子类覆盖泛型父类的方法时,编译器自动生成桥接方法的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java编译器采用bridge方法来兼容本该使用泛型的地方使用了非泛型的用法的问题。

 

如下代码:

 

public class TestBridgeMethod {
	public static void main(String[] args) {
		P p = new S();
		p.test(new Object());
	}
}

class P<T> {
	public T test (T t){
		return t;
	}
}

class S extends P<String> {
	@Override
	public String test(String t) {
		return t;
	}
}

 

p引用的是S的对象,但S的test方法返回值是String,在jdk1.4中没有泛型,就不会对p.test(new Object());进行检查,这样在调用的时候就会报ClassCastException

声明p的时候使用P<String> p就不会有这样的问题了。

 

 

为了兼容非泛型的代码,java编译器为test生成了两个方法。看下面的代码:

import java.lang.reflect.Method;
import java.util.Arrays;


public class TestBridgeMethod {
	public static void main(String[] args) {
		Class<?> clazz = S.class;
		Method[] methods = clazz.getMethods();
		for(Method method : methods) {
			System.out.println(method.getName() + ":" + Arrays.toString(method.getParameterTypes()) + method.isBridge());
		}
	}
}

class P<T> {
	public T test (T t){
		return t;
	}
}

class S extends P<String> {
	@Override
	public String test(String t) {
		return t;
	}
}
 

 

运行结果为:

 

test:[class java.lang.String]false

test:[class java.lang.Object]true

getClass:[]false

hashCode:[]false

equals:[class java.lang.Object]false

toString:[]false

notify:[]false

notifyAll:[]false

wait:[long, int]false

wait:[]false

wait:[long]false

 

编译器为S生成了两个test方法,一个参数为String,用于泛型。一个参数为Object,用于非泛型,这个方法就是bridge方法,调用method.isBridge返回true

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值