@safeVarargs注解

@SafeVarargs注解在JDK7中引入,用于处理可变长参数中的泛型,确保类型安全。该注解只能用于static或final方法,帮助编译器识别泛型在可变长参数中的正确使用,避免警告信息。文章详细解释了其用法及限制。

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

@SafeVarargs在JDK 7中引入,主要目的是处理可变长参数中的泛型,此注解告诉编译器:在可变长参数中的泛型是类型安全的。可变长参数是使用数组存储的,而数组和泛型不能很好的混合使用。

40f090dc84bebd6b3b87dae3fc1b78d5bbe.jpg

数组元素的数据类型在编译和运行时都是确定的,而泛型的数据类型只有在运行时才能确定下来,因此当把一个泛型存储到数组中时,编译器在编译阶段无法检查数据类型是否匹配,因此会给出警告信息。

aecdcd017f33909dc2afa13dc406f252608.jpg

这里使用了-Xlint:unchecked参数,排查出未经检查的和不安全的操作。其实这里的代码是没有问题的,所以加上注解可以通过编译。

20a1cd00412ed8aa91e04c5a752a4551260.jpg

@SafeVarargs注解只能用在参数长度可变的方法或构造方法上,且方法必须声明为static或final,否则会出现编译错误。

还有一种是错误使用的方式,比如下面的代码加上@SafeVarargs注解可以通过编译,但是你看看能发现什么问题?

54de5e90f270aadc1dff222bcd73bf55fde.jpg

并且我们编译是可以通过的

e1e666160040d8bf17fa9ebd14cc49a1ad6.jpg

但是我们这里去掉@SafeVarargs后,重新编译,会曝出如下错误,可能受到污染,但是还要自己查的哈!

b70cbf514faaff6879b8213e3442ef8a6c2.jpg

参考:http://softlab.sdut.edu.cn/blog/subaochen/2017/04/safevarargs%E7%9A%84%E7%94%A8%E6%B3%95/

 

对于javac命令是官方给我们提供的编译工具,但是我们还有很多Non-Standard Options可以选择,这么多不熟悉的操作真的让人眼花缭乱,可以打印出编译过程中遇到的警告,如下图:

24505ddd8b6b8f4c8137bc74b531f96b124.jpg

 

 

 

转载于:https://my.oschina.net/u/2277632/blog/2967078

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值