V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
ne6rd
V2EX  ›  问与答

请教一个集合 ChunkBySize 的算法

  •  
  •   ne6rd · 1 天前 · 317 次点击

    假设存储端有一个 2MB 的文件大小限制。 内存中有一个集合,IEnumerable<T>, 想要实现一个 ChunkBySzie 的方法,maxSzie 假设为 1.8MB ,把集合分成多个小组,每个都不超过 maxSize,同时又保证小组数量小。 集合的范围可能是 100~1M

    目前想到两种思路:

    1. 估算,取前 n 个 item ,计算平均 size ,然后估算,但是不确定
    2. 枚举,计算每个 item 的 size ,最准,但是消耗性能

    语言是 C#,大家有啥建议吗?

    1 条回复    2025-10-24 15:45:09 +08:00
    newaccount
        1
    newaccount  
       1 天前
    超过限制会报错不?
    会的话
    估算插入,如果抛错就拆成两个再插入
    关于   ·   帮助文档   ·   自助推广系统   ·   博客   ·   API   ·   FAQ   ·   Solana   ·   2397 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 19ms · UTC 11:37 · PVG 19:37 · LAX 04:37 · JFK 07:37
    ♥ Do have faith in what you're doing.