标签:Stream Permission distinct 列表 案例 Role new import 权限
package com.gblfy.gxts;
import com.google.common.collect.Lists;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.junit.Before;
import org.junit.Test;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
/**
* 案例3:
* 权限管理功能模块。查询某用户所有角色所包含的权限名称。
*/
public class CaseThree {
/**
* 角色模型
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
class Role {
/**
* 权限列表
*/
private List<Permission> permissionList;
}
@Data
@AllArgsConstructor
@NoArgsConstructor
class Permission {
//权限名称
private String name;
}
/**
* 用户角色列表
*/
List<Role> roleList;
//初始化数据
@Before
public void init() {
//声明用户角色列表
roleList = new ArrayList<>();
//声明一个管理员角色
Role adminRole = new Role();
//声明一个管理员权限列表
ArrayList<Permission> adminPermissionList = Lists.newArrayList(
new Permission("删除"),
new Permission("查看"),
new Permission("导出")
);
adminRole.setPermissionList(adminPermissionList);
//声明一个用户角色
Role userRole = new Role();
//声明一个用户权限列表
ArrayList<Permission> userPermissionList = Lists.newArrayList(
new Permission("新建"),
new Permission("修改"),
new Permission("删除"),
new Permission("查看")
);
userRole.setPermissionList(userPermissionList);
//将权限放入角色列表中
roleList.add(adminRole);
roleList.add(userRole);
}
/**
* 查找去重后权限列表
*/
@Test
public void findNoScoreStudentList() {
roleList.stream()
.flatMap(role -> role.permissionList.stream())
.peek(permission ->
System.out.println("新的流元素:" + permission))
.distinct()
// .forEach(permission -> System.out.println(permission));
.collect(Collectors.toList());
}
}
标签:Stream,Permission,distinct,列表,案例,Role,new,import,权限 来源: https://blog.csdn.net/weixin_40816738/article/details/117358821
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。