list分区后,转map

public static void main(String[] args) {
        List<NewTagDto> list = new ArrayList<NewTagDto>();
        NewTagDto dto1 = new NewTagDto();
        dto1.setId(1L);
        dto1.setTagName("A");
        NewTagDto dto2 = new NewTagDto();
        dto2.setId(1L);
        dto2.setTagName("C");
        list.add(dto1);
        list.add(dto2);
        NewTagDto dto3 = new NewTagDto();
        dto3.setId(2L);
        dto3.setTagName("B");
        NewTagDto dto4 = new NewTagDto();
        dto4.setId(2L);
        dto4.setTagName("D");
        list.add(dto3);
        list.add(dto4);
	Map<Long, List<NewTagDto>> map = list.stream().collect(Collectors.groupingBy(NewTagDto::getId));

        Map<Long, Map<String, NewTagDto>> map = list.stream().collect(Collectors.groupingBy(NewTagDto::getId,
                                                    Collectors.collectingAndThen(Collectors.toList(),
                                                                                 list1 -> getListNameMap(list))));

	
Map<Long, Map<String, NewTagDto>> map = list.stream().collect(Collectors.groupingBy(NewTagDto::getId,
                                              Collectors.collectingAndThen(Collectors.toList(),
                                                                                 list1 -> list1.stream().collect(Collectors.toMap(NewTagDto::getTagName, dto ->dto)))));
        System.out.println(map);
    }

        System.out.println(map);
    }

    private static Map<String, NewTagDto> getListNameMap(List<NewTagDto> list1) {
        Map<String, NewTagDto> map = new HashMap<String, NewTagDto>();
        String name = list1.stream().map(dto -> {return dto.getTagName();}).collect(Collectors.joining(","));
        map.put(name, list1.get(0));
        return map;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用Java语言实现的Kafka分区重分配的Demo,供您参考: ```java public class KafkaPartitionReassignDemo { private static final String TOPIC_NAME = "test_topic"; private static final String BROKER_LIST = "localhost:9092"; private static final String GROUP_ID = "test_group"; public static void main(String[] args) { Properties props = new Properties(); props.put("bootstrap.servers", BROKER_LIST); props.put("group.id", GROUP_ID); props.put("enable.auto.commit", "false"); KafkaConsumer<String, String> consumer = new KafkaConsumer<>(props); consumer.subscribe(Collections.singletonList(TOPIC_NAME)); while (true) { ConsumerRecords<String, String> records = consumer.poll(Duration.ofMillis(100)); // 处理消息 // 获取当前消费者组的成员信息 Map<String, List<PartitionInfo>> currentAssignment = consumer.listTopics().entrySet().stream() .filter(e -> e.getKey().equals(TOPIC_NAME)) .flatMap(e -> e.getValue().stream()) .collect(Collectors.groupingBy(PartitionInfo::topic, Collectors.toList())); // 重新分配分区 Map<String, List<Integer>> newAssignment = new HashMap<>(); currentAssignment.forEach((topic, partitions) -> { List<Integer> partitionIds = partitions.stream() .map(PartitionInfo::partition) .collect(Collectors.toList()); newAssignment.put(topic, partitionIds); }); // 执行分区重分配 AdminClient adminClient = AdminClient.create(props); Map<String, KafkaFuture<Void>> futureMap = adminClient.alterConsumerGroupOffsets(GROUP_ID, newAssignment); futureMap.forEach((topic, future) -> { try { future.get(); } catch (InterruptedException | ExecutionException e) { e.printStackTrace(); } }); } } } ``` 该Demo中,首先创建了一个Kafka消费者,然后在循环中轮询消息,并处理消息。在处理完消息后,获取当前消费者组的成员信息,然后重新分配分区并执行分区重分配。具体的分区重分配操作使用了Kafka的AdminClient API来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值