首页 / 缓存 / c# – 缓存查找性能
c# – 缓存查找性能
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 缓存查找性能,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含959字,纯文字阅读大概需要2分钟。
内容图文
我们有一个很棒的winforms C#应用程序,它基本上是一些数据库的前端(CRUD东西),我正在尝试在业务对象的内存缓存中实现一些.
就像是:
List<Customer> customerCache; // Loaded during app. startup
我已经创建了一些代码来使缓存与数据库保持同步.这段代码一直在一个单独的线程上运行,并且工作得非常好.
我的问题是,根据缓存的大小,在数据库中执行’select * from user = id’比使用foreach(在customerCache中使用forec客户cmr)循环缓存更快更快找到特定对象…
有没有办法快速搜索缓存中的特定对象?我打算尝试一些算法或改变我的收藏类型,但我希望听听你的建议.
请注意,我们有几个’List xxxCache’,一切都很快(对于小N,当然).但是当缓存的itens数量增加(通常> 3000)时,从数据库中读取的速度更快.
循环查看缓存项目以查找特定项目的最佳方法是什么?所有业务项都继承自共同的祖先,并具有“ID”属性(整数,唯一).
抱歉我的英语不好,这不是我的主要语言.
最好的祝福,
来自巴西的问候.
解决方法:
使用字典< int,Customer>代替.它支持基于密钥的O(1)查找.在这种情况下,密钥将是Customer.Id.
您可能还想查看.Net的其他预构建数据库缓存解决方案.
内容总结
以上是互联网集市为您收集整理的c# – 缓存查找性能全部内容,希望文章能够帮你解决c# – 缓存查找性能所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。