- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想在递归中使用索引变量,而不是在调用函数时将其作为参数发送。但是,如果我在开始时重置它(例如 i = 0),它会在每次运行时重置。我想将它用作计数器(计算函数运行次数)。
最佳答案
首先,您显然只想将其初始化一次。递归中的一个常见模式是:
public void run(int opt) {
run_helper(opt, 0);
}
private void run(int opt, int depth) {
if (whatever) { run(opt, depth + 1); }
}
外部方法只做一些初始化。
您经常会看到建议的“解决方案”(例如,在对您的问题的第一条评论中)是使用静态变量。这种方法是一种糟糕的风格,一旦您添加多线程(例如,通过制作 UI 版本,或在多线程 Web 服务器中运行它),将导致您的程序以各种奇怪的方式失败。最糟糕的是,它可能一开始似乎可以正常工作,但只有在有很多用户时才开始微妙地行为不端。 因此除了常量之外,一切都远离“静态”!
对于“静态”,它通常看起来像这样:
static int counter;
public void start() {
counter = 0;
recurse();
}
public void recurse() {
counter += 1;
if (whatever) { recurse(); }
}
现在假设两个用户同时调用 start
。 它们将覆盖彼此的计数器!因为静态意味着它在线程和用户之间共享。
这是一个非常简单易懂的解决方案:
class MyTask {
int counter = 0;
public void recurse() {
counter++;
if (whatever) { recurse(); }
}
public int getIterations() {
return counter;
}
}
public void run() {
MyTask task = new MyTask();
task.run();
System.out.println("Task took "+task.getIterations()+" itertions.");
}
然后您创建一个任务,运行它,并在最后检索计数器。干净、简单、高效和可靠。 如果您有多个线程/用户,每个线程/用户都有一个单独的 MyTask 对象,您不会遇到任何问题。
另外,您可以添加额外的统计信息,它们都干净利落地包装在任务对象中。 “每次迭代的平均时间”? “平均递归深度”?没问题。任务对象也可用于存储您的结果。
这里建议使用ThreadLocal
。我不同意这一点。它根本不提供任务对象的任何好处。只需尝试使用 ThreadLocal
和任务对象来实现它,您就会发现不同之处。另外,根据经验,ThreadLocal
比访问堆值慢 10 倍(参见 https://stackoverflow.com/a/4756605/1060350)。对于 int
,情况可能更糟。因此,永远不要在性能关键代码路径中调用 ThreadLocal#get
。如果您打算使用 ThreadLocal
,请在此代码路径之外使用它,并使用局部变量(或任务对象)将“局部静态”变量提供给您的关键代码路径。
关于java - 如何在递归中使用索引变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10567102/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How to nest OR statements in JavaScript? 有没有办法做到这一点:
在 JavaScript 中有没有办法让一个变量总是等于一个变量?喜欢var1 = var2但是当var2更新,也是var1 . 例子 var var1 = document.getElementBy
我正在努力理解这代表什么 var1 = var2 == var3 我的猜测是这等同于: if (var2 == var3): var1 = var2 最佳答案 赋值 var1 = var2
这个问题已经有答案了: What does the PHP error message "Notice: Use of undefined constant" mean? (2 个回答) 已关闭 8
我在临时表中有几条记录,我想从每条记录中获取一个值并将其添加到一个变量中,例如 color | caption -------------------------------- re
如何将字符串转为变量(字符串变量--> $variable)? 或者用逗号分隔的变量列表然后转换为实际变量。 我有 2 个文件: 列名文件 行文件 我需要根据字符串匹配行文件中的整行,并根据列名文件命
我有一个我无法解决的基本 php 问题,我也想了解为什么! $upperValueCB = 10; $passNodeMatrixSource = 'CB'; $topValue= '$uppe
这可能吗? php $variable = $variable1 || $variable2? 如果 $variable1 为空则使用 $variable2 是否存在类似的东西? 最佳答案 PHP 5
在 Perl 5.20 中,for 循环似乎能够修改模块作用域的变量,但不能修改父作用域中的词法变量。 #!/usr/bin/env perl use strict; use warnings; ou
为什么这不起作用: var variable; variable = variable.concat(variable2); $('#lunk').append(variable) 我无法弄清楚这一点
根据我的理解,在32位机器上,指针的sizeof是32位(4字节),而在64位机器上,它是8字节。无论它们指向什么数据类型,它们都有固定的大小。我的计算机在 64 位上运行,但是当我打印包含 * 的大
例如: int a = 10; a += 1.5; 这运行得很完美,但是 a = a+1.5; 此作业表示类型不匹配:无法从 double 转换为 int。所以我的问题是:+= 运算符 和= 运算符
您好,我写了这个 MySQL 存储过程,但我一直收到这个语法错误 #1064 - You have an error in your SQL syntax; check the manual that
我试图在我的场景中显示特定的奖牌,这取决于你的高分是基于关卡的目标。 // Get Medal Colour if levelHighscore goalScore { sc
我必须维护相当古老的 Visual C++ 源代码的大型代码库。我发现代码如下: bIsOk = !!m_ptr->isOpen(some Parameters) bIsOk的数据类型是bool,is
我有一个从 MySQL 数据库中提取的动态产品列表。在 list 上有一个立即联系 按钮,我正在使用一个 jquery Modal 脚本,它会弹出一个表单。 我的问题是尝试将产品信息变量传递给该弹出窗
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: What is the difference between (type)value and type(va
jQuery Core Style Guidelines建议两种不同的方法来检查变量是否已定义。 全局变量:typeof variable === "undefined" 局部变量:variable
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: “Variable” Variables in Javascript? 我想肯定有一种方法可以在 JavaScrip
在语句中使用多重赋值有什么优点或缺点吗?在简单的例子中 var1 = var2 = true; 赋值是从右到左的(我相信 C# 中的所有赋值都是如此,而且可能是 Java,尽管我没有检查后者)。但是,
我是一名优秀的程序员,十分优秀!