我对Teechart的javascript有问题。
我想在我们的主页中使用Teechart来显示具有〜500.000值的折线图。

我的代码最多可以处理100.000个值,此后会出现错误“超出了最大调用堆栈大小”

teechart.js:72 Uncaught RangeError: Maximum call stack size exceeded
at C (teechart.js:72)
at Tee.Line.Tee.Series.minYValue (teechart.js:130)
at teechart.js:76
at I.eachAxis (teechart.js:134)
at I.minYValue (teechart.js:76)
at x.checkMinMax (teechart.js:39)
at x.adjustRect (teechart.js:113)
at Q.each (teechart.js:79)
at Tee.Chart.draw (teechart.js:150)
at k (teechart-extras.js:24)


我是Java语言的初学者,这是我的第一个测试,但我找不到问题。
我使用的是Teechart VCL,显示这么多值没有问题。

TeeChart for Javascript可以处理这么多值吗?

function draw() {
  Chart1=new Tee.Chart("canvas");
  Series=new Tee.Line(Chart1);
  Chart1.addSeries(Series);

  Series.addRandom(200000);

  Chart1.axes.left.title.text="[hPa]";
  Chart1.axes.bottom.title.text="Date/Time";
  Chart1.axes.bottom.labels.dateFormat = "dd.mm.yy hh:mm";

  Chart1.series.items[0].marks.drawEvery=120;
  Chart1.title.visible = false;
  Chart1.legend.visible = false;
  changeTheme(Chart1, "minimal");
  Chart1.draw();
}

最佳答案

我对teechart一无所知,但错误消息实际上非常清楚。

每种语言都使用“调用堆栈”来管理对函数的调用。每次调用函数时,都必须保存当前的执行环境(所有局部变量,下一步应执行的行等),并且必须设置新的执行环境以使被调用的函数执行(其参数)。 ,局部变量等)。如果那个被调用的函数随后又调用了另一个函数,那么它的当前执行环境也需要保存。

为了管理所有这些信息的保存,我们使用堆栈。拨打电话时,您的信息将保存到堆栈中。当该函数调用另一个函数时,它将被压入堆栈。当它解析其执行时,它会在您之前被拔出,当函数完成执行时,您将被拔出栈。

现在解决您的问题。每次我们将一个新的函数调用压入堆栈时,都会占用一些内存。小,但仍然存在。但是调用栈可以使用有限的内存。因此,如果一个函数调用一个函数调用一个函数....,而我们过于嵌套在函数调用中,则调用堆栈将耗尽内存。一旦发生这种情况,如果您尝试再次调用,则计算机实际上将无法正确执行该命令,因此会发生此错误。



那么我们应该怎么做呢?


在代码中的任何地方,您都有一个递归函数调用,该调用的递归太深了。
或在teechart中的某个地方,有一个使用递归的函数,您传递给它的某些值会导致递归太深。


“问题”功能可能看起来像这样:

function recurse_x_times(x) {
  if (x < 1) {
    return;
  }
  // do some other stuff
  return recurse_x_times(x-1);
}

10-08 04:02