我正在编写一个递归函数,其目的是迭代pList文件。我的代码是
public static void HashMapper(Map lhm1) throws ParseException {
//Set<Object> set = jsonObject.keySet();
for (Object entry : lhm1.entrySet()) {
if(entry instanceof String)
{
System.out.println(entry.toString());
}
else
{
HashMapper((Map) ((Map) entry).keySet()); //getting Exception java.util.HashMap$HashMap Entry cannot be cast to java.util.Map
}
}
}
但是当我调用函数“ HashMapper((Map)((Map)entry).keySet());”时。我有一个例外
java.util.HashMap $ HashMap条目不能转换为java.util.Map
我不知道如何调用函数以及如何将Hashmap条目转换为Map
入境确实不是String
。它是Map.Entry
,因此您可以根据需要将其转换为此类型。
但是,自从大约10年前引入Java 1.5以来,您几乎几乎不需要铸造。而是使用泛型定义映射并使用类型安全的编程。
不幸的是,您的代码不清楚。您是说地图的关键或价值是String
?假设键是字符串,值可以是字符串或映射。(顺便说一句,这是非常糟糕的做法,因此,我建议您询问其他问题,以描述您的任务是什么,并询问如何设计程序。)
但无论如何,到目前为止,我可以为您提供建议:
public static void hashMapper(Map<String, Object> lhm1) throws ParseException {
for (Map.Entry<String, Object> entry : lhm1.entrySet()) {
String key = entry.getKey();
Object value = entry.getValue();
if (value instanceof String) {
System.out.println(value);
} else if (value instanceof Map) {
Map<String, Object> subMap = (Map<String, Object>)value;
hashMapper(subMap);
} else {
throw new IllegalArgumentException(String.valueOf(value));
}
}
}
如果说在任何地方都使用递归,那么可以使用for循环,对吗?如果递归通常比较慢,那么将其用于循环迭代的技术原因是什么? 如果总是可以将递归转换为for循环,那么有经验法则吗?
前面几节介绍了两个可以方便地用递归与迭代实现的函数。本节要比较递归与迭代方法,介绍为什么程序员在不同情况下选择不同方法。 递归与迭代都是基于控制结构:迭代用重复结构,而递归用选择结构。递归与迭代都涉及重复:迭代显式使用重复结构,而递归通过重复函数调用实现重复。递归与迭代都涉及终止测试:迭代在循环条件失败时终止,递归在遇到基本情况时终止。使用计数器控制重复的迭代和递归都逐渐到达终止点:迭代一直修改计
我在scheme中构建了一个递归函数,它将在一些输入上重复给定的函数f,n次。 我需要用尾递归构建这个函数的迭代版本,如果我正确理解尾递归,我认为我做得对。 我的问题是,这真的是迭代的吗?我相信我已经使用尾部递归正确地构建了它,但从技术上讲,它仍然将一系列操作推迟到count=0,在这里,它执行叠加的任意多个组合。
计算机的威力源自其反复执行同一任务或同一任务不同版本的能力。在计算领域,迭代这一主题会以多种形式出现。数据模型中的很多概念(比如表)都是某种形式的重复,比如“表要么为空,要么由一个元素接一个元素,再接一个元素,如此往复而成”。使用迭代,程序和算法可以在不需要单独指定大量相似步骤的情况下,执行重复性的任务,如“执行下一步骤1000次”。编程语言使用像C语言中的while语句和for语句那样的循环结构
问题内容: 前几天,我以为我在jQuery中看到了一个对象迭代器,该对象迭代器具有可以设置为对子对象进行递归迭代的标志。我以为它是jQuery.each()的一部分,但是现在我在文档中看不到该功能。 jQuery中是否有任何此类迭代器可以自动递归? (我知道如何用JavaScript进行操作。只是想知道我是否确实看到了我以为看到的东西。) 非常感谢! 编辑: 要清楚,我在想像jQuery.each
本文向大家介绍递归与迭代之间的区别,包括了递归与迭代之间的区别的使用技巧和注意事项,需要的朋友参考一下 在本文中,我们将了解递归和迭代之间的区别。 递归 它使用选择结构。 如果递归步骤不能将问题缩小为较小的问题,则会发生无限递归。 如果未在特定条件下进行转换,它也将变为无限递归。 此特定条件称为基本情况。 遇到无限递归时,系统崩溃。 当满足基本情况时终止。 它比迭代慢,因为它具有维护和更新堆栈的开