除了增强的for循环使代码简洁大气,结构清晰外,我们还可以看到对Map键值不同的取值方式的效率介绍。
在这儿也是对增强for循环的相见恨晚啊!
之前的使用情况
package map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class EntryOfMap {
/*
* Set<Map.Entry<K,V>>entrySet() 返回此映射中包含的映射关系的 set 视图。
*
*/
public static void main(String[] args) {
String str[] = "java java platform is is is is perfect".split(" ");
statistics(str);
}
public static void statistics(String str[]) {
Map<String, Integer> m = new HashMap<String, Integer>();// 用HashMap,因为Hash的查找快
for (int i = 0; i < str.length; i++) {
Integer freq = m.get(str[i]);
m.put(str[i], freq == null ? 1 : freq + 1);
}
// 效率高
Set<Map.Entry<String, Integer>> set = m.entrySet();
Iterator<Map.Entry<String, Integer>> it = set.iterator();
// 下面这一句等价于上面的两句
// Iterator<Map.Entry<String, Integer>> it = m.entrySet().iterator();
while (it.hasNext()) {
Map.Entry<String, Integer> me = it.next();
System.out.println(me.getKey() + " " + me.getValue());// 直接获取键和值
}
// 效率低
Iterator<String> iter = m.keySet().iterator();
while (iter.hasNext()) {
String s = iter.next();
System.out.println(s + " " + m.get(s));
}
}
}
使用增强的for循环
package map;
import java.util.HashMap;
import java.util.Map;
public class EntryOfMap2{
/*
* 在EntryOfMap.java的基础上使用增强for循环对代码进行了优化
* 由于增强for循环的使用:这样的代码就非常的简洁了哦
*/
public static void main(String[] args) {
String str[] = "java java platform is is is is perfect".split(" ");
statistics(str);
}
public static void statistics(String str[]) {
Map<String, Integer> m = new HashMap<String, Integer>();// 用HashMap,因为Hash的查找快
for (int i = 0; i < str.length; i++) {
Integer freq = m.get(str[i]);
m.put(str[i], freq == null ? 1 : freq + 1);
}
// 用Map.Entry效率高
for (Map.Entry<String, Integer> me : m.entrySet())
System.out.println(me.getKey() + " " + me.getValue());
// 通过键来取值效率低
for (String s : m.keySet())
System.out.println(s + " " + m.get(s));
}
}
也就是比较这两段代码
1.
// 效率高
Set<Map.Entry<String, Integer>> set = m.entrySet();
Iterator<Map.Entry<String, Integer>> it = set.iterator();
// 下面这一句等价于上面的两句
// Iterator<Map.Entry<String, Integer>> it = m.entrySet().iterator();
while (it.hasNext()) {
Map.Entry<String, Integer> me = it.next();
System.out.println(me.getKey() + " " + me.getValue());// 直接获取键和值
}
// 效率低
Iterator<String> iter = m.keySet().iterator();
while (iter.hasNext()) {
String s = iter.next();
System.out.println(s + " " + m.get(s));
}
------------------这个比较式非常的明显啊---------------------------------2.
// 用Map.Entry效率高
for (Map.Entry<String, Integer> me : m.entrySet())
System.out.println(me.getKey() + " " + me.getValue());
// 通过键来取值效率低
for (String s : m.keySet())
System.out.println(s + " " + m.get(s));
.
分享到:
相关推荐
"专业大气"暗示代码可能包含高级的设计元素和功能,如过渡效果、自定义控制、自动播放等,同时保持简洁和用户友好的界面。 【标签解析】:“JS特效-图片相册”标签揭示了代码的核心功能,即利用JavaScript实现一种...
以上代码展示了如何在实际项目中使用Slider.js插件,通过调整配置参数和处理事件,我们可以轻松定制出符合自己需求的焦点图轮播效果。 总结,Slider.js是一款实用且易于定制的焦点图轮播插件,它结合了jQuery的强大...
描述中提到的是一个基于jQuery的图片左右滚动切换效果,这种效果常见于许多网站,特别是大型门户网站,因为它简洁、大气且具有良好的浏览器兼容性。现在,我们将深入探讨这个效果背后的关键知识点。 1. **jQuery**...
晋城市-晋城市-街道行政区划_140500_Shp数据-wgs84坐标系.rar
内容概要:本文档汇总了46个经典的Linux面试题及其答案,涵盖了Linux系统操作的基本命令和概念。内容涉及路径表示与目录切换、进程管理、文件和目录操作、权限设置、文件内容查看等多个方面。每个问题都给出了明确的答案,旨在帮助面试者全面掌握Linux命令行操作技能,同时加深对Linux系统原理的理解。 适合人群:准备Linux相关职位面试的求职者,尤其是有一定Linux基础但缺乏实战经验的技术人员。 使用场景及目标:①用于个人自学或面试前复习,巩固Linux基础知识;②作为企业内部培训资料,帮助员工提升Linux操作水平;③为初学者提供系统化的学习指南,快速入门Linux命令行操作。 其他说明:文档内容侧重于实际操作命令的讲解,对于每个命令不仅提供了基本语法,还解释了具体应用场景,有助于读者更好地理解和记忆。建议读者在学习过程中多加练习,将理论知识转化为实际操作能力。
街道级行政区划shp数据,wgs84坐标系,直接下载使用。
内容概要:本文提供了10道华中杯C++竞赛真题的详细解析,涵盖多种基础编程技能与高级特性。每道题目不仅包含详细的解题思路和代码实现,还附带了完整的运行结果。具体包括:函数参数传递(指针实现)、宏定义比较、数组元素打印、几何图形面积计算、字符串拼接、素数判断、多态的实现、文件操作、简单计算器和学生信息管理。这些题目帮助读者深入理解C++语言的核心概念和技术应用。 适合人群:对C++有一定了解的编程初学者和中级开发者,尤其是准备参加编程竞赛的学生或程序员。 使用场景及目标:①作为编程练习和竞赛备考资料,帮助读者掌握C++的基本语法和常用算法;②通过实际代码示例加深对C++特性的理解,如指针、宏定义、面向对象编程等;③提供完整的源码供读者参考和调试,增强动手能力和问题解决能力。 阅读建议:建议读者按照题目难度逐步学习,先理解题目背景和解题思路,再仔细研读代码实现,并尝试独立编写和调试代码。同时,鼓励读者扩展思考,探索更多可能的解决方案,以提高编程水平。
街道级行政区划shp数据,wgs84坐标系,直接使用。
街道级行政区划shp数据,wgs84坐标系,直接使用。
通用计算器的设计FPGA.doc
晋城市-沁水县-街道行政区划_140521_Shp数据-wgs84坐标系.rar
赤峰市-松山区-街道行政区划_150404_Shp数据-wgs84坐标系.rar
JAVA中Stream编程常见的方法分类
街道级行政区划shp数据,wgs84坐标系,直接使用。
大同市-浑源县-街道行政区划_140225_Shp数据-wgs84坐标系.rar
包头市-昆都仑区-街道行政区划_150203_Shp数据-wgs84坐标系.rar
街道级行政区划shp矢量数据,wgs84坐标系,下载直接使用
街道级行政区划shp数据,wgs84坐标系,直接下载使用。
内容概要:本文详细介绍了车载电子电器架构中的网络拓扑开发,涵盖开发概述、车载网络总线、网络设计原则、开发流程及小结。网络拓扑开发是汽车电气架构中的重要环节,旨在设计合理的网络结构以确保各电子控制单元(ECU)之间的高效通信。文中阐述了通信协议选择、网络节点布局、通信介质选择、拓扑结构设计及安全性考虑等关键要素,并强调了仿真与验证的重要性。此外,还讨论了网络设计的原则,如前瞻性、兼容性、拓展性、实时性、可靠性和安全性,以及网络负载的优化措施。最后,总结了网络拓扑开发的流程,包括需求分析、设计、仿真验证、优化迭代及文档记录。 适合人群:汽车电子工程师、各域功能工程师、子系统及零部件开发者、测试工程师等从事汽车电气架构开发的相关人员。 使用场景及目标:①帮助工程师理解汽车网络拓扑开发的关键步骤和技术要点;②指导工程师在设计过程中遵循科学合理的设计原则,确保网络拓扑的高性能和可靠性;③提供网络负载优化的措施,确保数据传输的实时性和效率。 其他说明:网络拓扑开发不仅需要考虑技术层面的因素,还需兼顾成本效益,以适应不断变化的市场需求和技术趋势。本文建议读者在实践中不断积累经验,关注新技术的应用和发展,以应对未来的挑战和机遇。