详解怎么检测和防止JavaScript死循环

目录
  • 前言
  • 在 for 语句中修复无限循环
  • 在 while 语句中修复无限循环
  • 总结

前言

Js死循环是怎么造成的呢!其实在我们写代码时一些不注意或漏写,就写出死循环,就如下面代码:

如果i++没有写上,这个就是死循环了,死循环的后果想知道的自己不防去试试。

死循环就是一段错误的阻止终止循环条件JavaScript代码。

无限循环是危险的,因为它会导致您运行代码的环境(浏览器或 NodeJS 服务器)崩溃或冻结您的计算机,导致它停止响应。

for和while语句是一个无限循环的常见原因,所以本教程将帮助您了解如何检测和修复所造成的语句无限循环。

让我们从修复for语句中的无限循环开始。

在 for 语句中修复无限循环

一个for语句可能会导致一个无限循环,当你错误的第二表达式把赋值运算符,而不是一个比较运营商(在条件表达式)

下面是一个for会导致无限循环的语句示例。注意第二个表达式是如何i = 10:

for (let i = 0; i = 10; i++) {
  console.log("Infinite loop");
}

该for语句要求第二个表达式的计算结果false为终止循环。在上面的示例中,赋值运算符i = 10被放置为条件表达式,而不是像i < 10or之类的比较运算符i > 10。

由于赋值运算符的计算结果始终为true,因此该for语句不会停止打印"Infinite loop"到控制台,这可能会导致您的计算机死机。

要修复for上面的语句,您需要将第二个表达式替换为该for语句可以达到的内容。一个例子是使用比较运算符 ( =<, <, >, >=)

// the second expression is replaced with <
for (let i = 0; i < 10; i++) {
  console.log("Infinite loop");
}

同样的错误还有另一个版本。这一次,第一个表达式和第二个表达式导致无限循环:

for (let i = 5; i > 0; i++) {
  console.log("Infinite loop");
}

从上面的代码可以看出,只要变量i大于,循环就会继续0。

由于 的值i已经大于0初始化时的值,因此第二个表达式将始终计算为true,从而导致无限循环。

为了修复上面的代码,第三个表达式必须减少i而不是增加它的值:

for (let i = 5; i > 0; i--) {
  console.log("Infinite loop");
}

另一个for可能导致无限循环的语句示例是省略括号内的所有三个表达式,如下所示:

for (;;) {
  console.log("Infinite loop");
}

但是上面的代码只能是故意写的,所以除非你想让你的电脑崩溃,否则你不应该在你的项目中使用它。

尽管for您编写的语句肯定会比上面的示例更复杂,但您仍然可以使用相同的原则来查找和修复语句中的错误。

首先,您需要确保放在for语句中的第二个表达式实际上可以计算为false.

如果第二个表达式已经正确,则开始检查第一个和第三个表达式。第一个表达式是否初始化了一个true在执行第二个表达式时始终计算为的值?

最后,第三个表达式是否正确递增或递减第一个表达式中初始化的变量的值?

总结一下:首先检查你的第二个表达式,然后按顺序检查第一个和第三个表达式。

接下来,让我们学习如何修复由while语句引起的无限循环。

在 while 语句中修复无限循环

一个while语句可以导致无限循环,当条件表达式括号始终计算里面放true:

while (true) {
  console.log("Infinite loop");
}

为了防止无限循环,while 语句的条件表达式必须能够计算为false。

编写while语句时最常见的错误之一是忘记修改用于条件表达式的变量的值。

请注意i以下示例中 never的值如何更改:

let i = 0;

while (i < 6) {
  console.log("Infinite loop");
}

您需要增加语句体i内部的值,while以便在false执行循环时条件表达式的计算结果为:

let i = 0;

while (i < 6) {
  console.log("Infinite loop");
  i++;
}

无论您的while语句多么复杂,您都需要确保括号内的条件表达式while()可以计算为false.

如果仍然找不到导致无限循环的原因,则可以使用该console.log()语句打印条件表达式使用的变量的值:

let i = 0;

while (i < 6) {
  console.log("Infinite loop");
  i++;
  console.log(i);
}

控制台日志可以帮助您查明错误的代码行并修复它。

总结

到此这篇关于怎么检测和防止JavaScript死循环的文章就介绍到这了,更多相关检测和防止js死循环内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 如何检测JavaScript中的死循环示例详解

    前言 如果我们需要执行用户写的代码,如和避免死循环?我们最近遇到了这个问题,因为写错代码很常见,所以我们进行了一下尝试. 首先我们需要使用iframe 这主要是安全考虑,我们需要一个sandbox环境来执行JavaScript,避免影响到整体.iframe的sandbox属性可以用来禁止弹窗等等,非常有用. 地址可以选择Blob url,不过blob url会持有当前web page的origin,如果用户拷贝一些乱七八糟的代码不小心执行的话,会有安全问题.所以最终决定用data URI. if

  • 详解怎么检测和防止JavaScript死循环

    目录 前言 在 for 语句中修复无限循环 在 while 语句中修复无限循环 总结 前言 Js死循环是怎么造成的呢!其实在我们写代码时一些不注意或漏写,就写出死循环,就如下面代码: 如果i++没有写上,这个就是死循环了,死循环的后果想知道的自己不防去试试. 死循环就是一段错误的阻止终止循环条件JavaScript代码. 无限循环是危险的,因为它会导致您运行代码的环境(浏览器或 NodeJS 服务器)崩溃或冻结您的计算机,导致它停止响应. for和while语句是一个无限循环的常见原因,所以本教

  • 详解Android 检测权限的三种写法

    本文介绍了详解Android 检测权限的三种写法,小编觉得挺不错的,现在分享给大家,也给大家做个参考.一起跟随小编过来看看吧 权限检测生效条件: targetSdkVersion 以及 compileSdkVersion 升级到 23 及以上 运行 Android 系统 6.0 及以上 三种检测权限写法: public static boolean checkPermission1(Context context, String[] permissions) { PackageManager p

  • MySQL死锁使用详解及检测和避免方法

    目录 前言 锁的释放与阻塞 死锁的发生和检测 查看锁信息(日志) 死锁的避免 前言 上一篇博客我们知道的Mysql事务的隔离机制和实现,以及锁的详细解析 链接: MySQL脏读幻读不可重复读及事务的隔离级别和MVCC.LBCC实现 在我们使用锁的时候,有一个问题是需要注意和避免的,我们知道,排它锁有互斥的特性.一个事务或者说一个线程持有锁的时候,会阻止其他的线程获取锁,这个时候会造成阻塞等待,如果循环等待,会有可能造成死锁. 这个问题我们需要从几个方面来分析,一个是锁为什么不释放,第二个是被阻塞

  • 详解用函数式编程对JavaScript进行断舍离

    我和JavaScript 从1997年网景的Navigator 3浏览器开始就开始使用JavaScript.当时,JavaScript还只能做一些很简单的事情.我记得最酷的就是用JavaScript实现mouseover特性,在那个时候已经算得上是高科技了!当鼠标移过去之后,文本内容就神奇的改变了.因为当时都是pre-DHTML,你根本不需要隐藏或则显示DOM元素. 关于DHTML DHTML是Dynamic HTML的简称,就是动态的html(标准通用标记语言下的一个应用),是相对传统的静态的

  • 详解Struts2中json 相互引用死循环解决办法

    方法1 :利用Struts 2的支持的可配置结果,可以达到过滤器的效果.Action的处理结果配置支持正则表达式. 但是如果返回的对象是一个数组格式的Json数据.比如peson Bean中有对象persion1-person9,而我只要person1的json数据, 则可以用如下的正则表达式. <struts> <constant name="struts.objectFactory" value="spring"/> <includ

  • java中DecimalFormat四舍五入用法详解

    DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字.它可以支持不同类型的数,包括整数 (123).定点数 (123.4).科学记数法表示的数 (1.23E4).百分数 (12%) 和金额 ($123)这些内容的本地化. 下边先介绍下DecimalFormat的用法: import java.text.*; import java.util.*; public class DecimalFormatDemo { public static void ma

  • Java中DecimalFormat用法详解

    我们经常要将数字进行格式化,比如取2位小数,这是最常见的.Java 提供DecimalFormat类,帮你用最快的速度将数字格式化为你需要的样子.下面是一个例子: importjava.text.DecimalFormat; public class TestNumberFormat{ public static void main(String[]args){ doublepi=3.1415927; //圆周率 //取一位整数 System.out.println(newDecimalForm

  • java.text.DecimalFormat用法详解

    简要 DecimalFormat 的 pattern 都包含着 正负子 pattern ,例如 "#,##0.00;(#,##0.00)": /** * Created by Shuai on 2016/7/11. */ public class Main { public static void main(String[] args) { // 正值 BigDecimal bigDecimal = BigDecimal.valueOf(-12211151515151.541666);

  • DecimalFormat数字格式化用法详解

    DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字. DecimalFormat 包含一个模式 和一组符号 符号含义: 下列字符用在非本地化的模式中.已本地化的模式使用从此 formatter 的 DecimalFormatSymbols 对象中获得的相应字符,这些字符已失去其特殊状态.两种例外是货币符号和引号,不将其本地化. import java.text.DecimalFormat; public class TestDecimalFormat

  • DecimalFormat多种用法详解

    NumberFormat.getInstance()方法返回NumberFormat的一个实例(实际上是NumberFormat具体的一个子类,例如DecimalFormat), 这适合根据本地设置格式化一个数字.你也可以使用非缺省的地区设置,例如德国.然后格式化方法根据特定的地区规则格式化数字.这个程序也可以使用一个简单的形式: NumberFormat.getInstance().format(1234.56) 但是保存一个格式然后重用更加有效.国际化是格式化数字时的一个大问题. 另一个是对

随机推荐