- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 TCP/UDP 端口号及其字符串描述的列表:
http://en.wikipedia.org/wiki/List_of_TCP_and_UDP_port_numbers
现在它的形式是HashMap,其中端口号作为键,字符串描述作为值。它可能不是那么大,但我必须在数据包到来时实时查找端口描述,正如您可以想象的那样,这需要有效的检索,否则会大大减慢处理速度。
最初我想实现巨大的 switch case/break 逻辑或者 if, else if 但这听起来太破旧了,所以我想出了这个 hashMap。
现在我想知道如果查询始终相同,Java 是否有类似缓存机制的东西来加速?大多数情况下,查询的端口是 80、443、23、22 等,很少有其他服务类型的数据包到达。
我的选项:
对于大多数情况,我应该在开始时进行一些 else-if 检查吗?常见类型,如果之前没有找到,则恢复到此 hashMap
我应该继续使用这个 hashMap 来为我进行搜索
我应该恢复到其他一些聪明的方式来做到这一点吗?
请提出建议。
最佳答案
您测量过这需要多长时间吗?我怀疑,与您正在执行的其他操作相比,在具有合理数量的存储桶的 HashMap 中进行查找将可以忽略不计。
与此类问题一样,在解决假设的性能问题之前,非常值得对其进行衡量。 过早的优化是万恶之源,如they say .
关于java - Java中大查找值的高效实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12582967/
我们在 RedHat 中使用 Postgres 9.2。我们有一个类似于以下的表: CREATE TABLE BULK_WI ( BULK_ID INTEGER NOT NULL, U
根据我的计算,将浮点值转换为计算机存储的二进制值(符号、指数、尾数格式),在 32 位中,1 位用于符号,8 位用于指数。 所以只剩下 23 位来表示数字。 所以我认为具有正确行为的浮点值范围仅为 0
我有一个像这样的临时表: CREATE TABLE `staging` ( `created_here_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTA
下面是我的 HTML: Fact Sheet Facilities and Administrative (F&A) Cost Agreem
我想知道为什么 .add(i, E) 是 O(n) 而 .get(i) 是 O(1)?是不是因为 n 元素在插入后必须向右移动? 最佳答案 记住大 O 表示法显示问题的数量级而不是最佳情况解决方案..
我在装有 GCC 4.8.2 的 Windows 8.1、Intel i7-3517U 64 位笔记本电脑上测试这个简单的 C++ 代码。 #include using namespace std;
我是一名优秀的程序员,十分优秀!