关于bitmap
当我们需要统计大量随机数的生成情况时,使用HashMap以随机数作为键可能会导致内存消耗过大。每个键值对都需要额外的内存来存储键和值之间的关联,而一个整型随机数通常需要占用4个字节(32位)。在处理大数据量时,这种内存开销可能会变得不可承受。
而BitMap用位来标记随机数是否生成,1个字节就能表示8个数字是否生成。因此,Bitmap它在内存占用方面的优势使得它成为处理大规模数据的一种可行选择
public class Main { //0-320 private static int[] bitmap = new int[10]; public static void main(String[] args) { for (int i = 0; i < 100; i++) { int r = new Random().nextInt(311); int x = r / 31; int y = r % 32; if((bitmap[x] & (1 << y)) == 0){ System.out.println(r); bitmap[x] = bitmap[x] | (1 << y); }else{ System.out.println("重复" + r); } } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)