Collections unmodifiableCollection,emptyList,singletonList 介绍以及总结

Java集合不可变性实践

共同点以及好处

Collections.unmodifiableCollection(xxx)

Collections.emptyList()

Collections.singletonList (xxx)

获取的均是不可修改的内容,满足了最常见的使用场景,即确定了长度的集合,长度为1的集合,空集合。

共点:它们都是不可修改的,减少了内存的占用,即定义时就确认这就是最终的形态。

同时JDK 提供的也减少了我们自己去构造和维护的成本,可用性更高,更强大。

Collections.unmodifiableCollection

说明:通过JDK Collections 自带提供的 unmodifiableCollection() 可以直接通过 arrays.aslist的方式直接构造该一个该对象,从字面意思理解就是这是一个不可修改的集合,即通过这样方式创建出来的内容只能执行一般的查询操作不支持 任何类似 add remove 等修改操作,否则直接抛出 不支持的操作异常。

类似于:

protected final Collection supportModes =

Collections.unmodifiableCollection(Arrays.asList(TMode.ONCE, TMode.MORE));

与其类似的还有 unmodifiableList, unmodifiableSet,unmodifiableMap 原理以及作用类似

Collections.emptyList

说明:返回一个空集合,同时也是内部类无法执行增删操作等;

好处:使用这种方式创建时不会创建新对象,减少内存开销,比 new 更节约资源。方法返回 emptyList 可以避免 null;

转换:如果需要操作可以使用一般的 ArrayList 等的构造函数去转换。

Collections.singletonList

说明:会返回一个长度只有 1 的不可变的集合,同时也无法执行增删等修改操作,依旧类似视图一样,可查询以及查看一般的属性,但无法改变内容。

————————————————

原文链接:https://blog.youkuaiyun.com/weixin_44131922/article/details/126343055

@TableName("user") @Data public class User implements UserDetails { // 用户id private Integer id; // 用户uid private String uid; // 用户密码 private String password; private boolean enabled; // 用户昵称 private String name; // 用户头像 private String img; // 用户地址 private String addr; // 用户电话 private String tel; // 余额 private int account; // 用户创建时间 private LocalDateTime dc; // 用户信息更新时间 private LocalDateTime de; // 用户类型 private Role role; // 创建身份枚举类 // 创建身份枚举类 public enum Role { 企业, 管理员; // 根据角色返回对应的权限 public Collection<? extends GrantedAuthority> getAuthorities() { switch (this) { case 企业: // 企业用户的权限 return Collections.singletonList(new SimpleGrantedAuthority("ROLE_企业")); case 管理员: // 管理员的权限 return Collections.singletonList(new SimpleGrantedAuthority("ROLE_管理员")); default: return Collections.emptyList(); } } } @Override public Collection<? extends GrantedAuthority> getAuthorities() { // 根据角色返回权限 return role.getAuthorities(); } @Override public String getUsername() { return this.uid; // 通常是用户名或用户唯一标识 } @Override public boolean isAccountNonExpired() { return true; // 账户是否过期 } @Override public boolean isAccountNonLocked() { return true; // 账户是否被锁定 } @Override public boolean isCredentialsNonExpired() { return true; // 密码是否过期 } @Override public boolean isEnabled() { return true; // 用户是否启用 } } 什么问题?
03-26
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值