
@safevarargs 注意事项
@safevarargs 注解用于确保使用可变参数类型时不会出现数组类型安全问题。但是,虽然它可以防止某些类型的错误,但它并非万能的。
在您提供的示例中,使用 varargs 数组作为参数的方法是:
static <t> t[] asarray(t... objs) {
return objs;
}并尝试将其与以下方法一起使用:
static <k> k[] picktwo(k k1, k k2, k k3) {
return asarray(k1, k2);
}此代码会引发编译错误,因为 picktwo 方法返回的是一个 object[] 数组,而 asarray 方法期望的是一个 string[] 数组。
简介PHP轻论坛是一个简单易用的PHP论坛程序,适合小型社区和个人网站使用。v3.0版本是完全重构的版本,解决了之前版本中的所有已知问题,特别是MySQL保留字冲突问题。主要特点• 简单易用:简洁的界面,易于安装和使用• 响应式设计:适配各种设备,包括手机和平板• 安全可靠:避免使用MySQL保留字,防止SQL注入• 功能完善:支持分类、主题、回复、用户管理等基本功能• 易于扩展:模块化设计,便于
21
这是因为 @safevarargs 注解并不提供类型安全。它只会阻止将原始类型数组分配给通用类型数组,而这里的问题是试图将通用类型数组分配给一个不同类型的通用类型数组。
要解决此问题,可以将 asarray 方法重写为返回 list<t>,而不是 t[]:
@safevarargs
static <t> list<t> aslist(t... objs) {
return new arraylist<>(arrays.aslist(objs));
}现在,picktwo 方法可以返回一个 list<t> 而不会引发错误:
static <K> List<K> pickTwo(K k1, K k2, K k3) {
return asList(k1, k2);
}以上就是@SafeVarargs注解真的能解决所有可变参数类型安全问题吗?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号