aboutsummaryrefslogtreecommitdiff
path: root/files/de/web/javascript/reference/fehler/too_much_recursion/index.html
blob: 0010afd90ae7c68319b262f812116a8370903b24 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
---
title: 'InternalError: too much recursion'
slug: Web/JavaScript/Reference/Fehler/Too_much_recursion
tags:
  - Errors
  - InternalError
  - JavaScript
translation_of: Web/JavaScript/Reference/Errors/Too_much_recursion
---
<div>{{jsSidebar("Errors")}}</div>

<h2 id="Fehlermeldung">Fehlermeldung</h2>

<pre class="syntaxbox">InternalError: too much recursion
</pre>

<h2 id="Fehlertyp">Fehlertyp</h2>

<p>{{jsxref("InternalError")}}.</p>

<h2 id="Was_ist_falsch_gelaufen">Was ist falsch gelaufen?</h2>

<p>Eine Funktion, die sich selbst aufruft, wird rekursive Funktion genannt. In manchen Fällen ist Rekursion mit einer Schleife vergleichbar. Beide führen den gleichen Code mehrfach aus und beide brauchen eine Abbruchbedingung (um Endlosschleifen bzw. Endlosrekursion zu vermeiden). Wenn zu tiefe Rekursion oder Endlosrekursion auftritt, erzeugt JavaScript diesen Fehler.</p>

<h2 id="Beispiele">Beispiele</h2>

<p>Diese rekursive Methode wird bis zur Abbruchbedingung 10 mal durchlaufen.</p>

<pre class="brush: js">function schleife(x) {
  if (x &gt;= 10) // "x &gt;= 10" ist die Abbruchsbedingung
    return;
  // zu wiederholende Codezeilen
  schleife(x + 1); // rekursiver Methodenaufruf
}
schleife(0);</pre>

<p>Wird die Abbruchsbedingung auf eine zu hohe Wert gesetzt, ist die Rekursionstiefe zu hoch und es wird einen Fehler erzeugt:</p>

<pre class="brush: js example-bad">function boeseSchleife(x) {
  if (x &gt;= 1000000000000)
    return;
  // zu wiederholende Codezeilen
  boeseSchleife(x + 1);
}
boeseSchleife(0);

// InternalError: too much recursion</pre>

<h2 id="Siehe_auch">Siehe auch</h2>

<ul>
 <li>{{Glossary("Recursion")}}</li>
 <li><a href="/de/docs/Web/JavaScript/Guide/Funktionen">Rekursive Methoden</a></li>
</ul>