基于Kryo的深拷贝

1 篇文章 0 订阅

import com.esotericsoftware.kryo.Kryo;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
import java.util.stream.Collectors;

public class CopyUtils {

    private static final ThreadLocal<Kryo> KRYO_THREAD_LOCAL = ThreadLocal.withInitial(
            () -> {
                Kryo kryo = new Kryo();
                kryo.setRegistrationRequired(false);
                return kryo;
            });

    private static final ForkJoinPool COPY_THREAD_POOL = new ForkJoinPool(10);

    /**
     * 基于kryo的深拷贝
     * @param target
     * @param <T>
     * @return
     */
    public static <T> T deepCopyByKryo(T target) {
        Callable<T> copyTask = () -> {
            Kryo kryoInstance = KRYO_THREAD_LOCAL.get();
            return kryoInstance.copy(target);
        };
        T copy;
        try {
            copy = COPY_THREAD_POOL.submit(copyTask).get();
        } catch (ExecutionException | InterruptedException e) {
            throw RuntimeException(e);
        }
        return copy;
    }

    /**
     * 基于kryo的List深拷贝
     * @param targetList
     * @param <T>
     * @return
     */
    public static <T> List<T> deepCopyByKryo(List<T> targetList) {
        Callable<List<T>> copyTask = () -> targetList
                .parallelStream()
                .map(target -> {
                    Kryo kryoInstance = KRYO_THREAD_LOCAL.get();
                    return kryoInstance.copy(target);
                })
                .collect(Collectors.toList());
        List<T> copyList;
        try {
            copyList = COPY_THREAD_POOL.submit(copyTask).get();
        } catch (ExecutionException | InterruptedException e) {
            throw RuntimeException(e);
        }
        return copyList;
    }

}
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值