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

共同点以及好处

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
### 使用场景 - **避免空指针异常**:当一个方法需要返回一个列表,但在某些情况下没有合适的数据可以返回时,返回 `Collections.emptyList()` 可以避免调用者在使用返回值时出现空指针异常。例如: ```java import java.util.Collections; import java.util.List; public class ExampleService { public List<String> getItems() { // 模拟没有数据的情况 if (true) { return Collections.emptyList(); } // 正常情况返回数据 // return someData; } } ``` 调用者可以安全地遍历这个列表,而不用担心空指针异常: ```java List<String> items = exampleService.getItems(); for (String item : items) { // 处理 item } ``` - **提供默认值**:在 API 设计中,为了避免返回 `null`,可以使用 `Collections.emptyList()` 作为默认返回值。这样可以使 API 的使用更加安全和清晰。 ### 原理 `Collections.emptyList()` 是 `java.util.Collections` 类中的一个静态方法。它返回的是一个不可变的空列表,该列表实现了 `List` 接口。其实现原理是通过一个静态的、私有的内部类 `EmptyList` 来表示空列表。这个内部类继承自 `AbstractList` 并实现了 `RandomAccess` 接口,它重写了 `size()`、`get()` 等方法,并且不允许对列表进行添加、删除等修改操作。 以下是简化的实现代码示例: ```java public class Collections { private static final List<?> EMPTY_LIST = new EmptyList<>(); public static final <T> List<T> emptyList() { return (List<T>) EMPTY_LIST; } private static class EmptyList<E> extends AbstractList<E> implements RandomAccess, Serializable { @Override public int size() { return 0; } @Override public E get(int index) { throw new IndexOutOfBoundsException("Index: "+index); } // 其他重写方法... } } ``` ### 作用 - **节省内存**:由于 `Collections.emptyList()` 返回的是一个静态的、不可变的空列表实例,无论调用多少次 `Collections.emptyList()`,返回的都是同一个实例。这避免了每次都创建新的空列表对象,从而节省了内存。 - **提高性能**:返回同一个实例也避免了创建新对象的开销,提高了性能。同时,由于该列表是不可变的,在多线程环境下使用也无需考虑线程安全问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值