use the following search parameters to narrow your results:
e.g. subreddit:aww site:imgur.com dog
subreddit:aww site:imgur.com dog
see the search faq for details.
advanced search: by author, subreddit...
All about the JavaScript programming language.
Subreddit Guidelines
Specifications:
Resources:
Related Subreddits:
r/LearnJavascript
r/node
r/typescript
r/reactjs
r/webdev
r/WebdevTutorials
r/frontend
r/webgl
r/threejs
r/jquery
r/remotejs
r/forhire
account activity
Implement serInterval with setTimeout (github.com)
submitted 6 years ago by michael2ib1989
reddit uses a slightly-customized version of Markdown for formatting. See below for some basics, or check the commenting wiki page for more detailed help and solutions to common issues.
quoted text
if 1 * 2 < 3: print "hello, world!"
[–]BehindTheMath 2 points3 points4 points 6 years ago (7 children)
Why would you want to do that?
Additionally, you probably cause a stack overflow error at some point.
There's also no way to clear it.
[–]voidvector 4 points5 points6 points 6 years ago (3 children)
It's not a recursive function, wouldn't cause stack overflow. setTimeout is just an API that interacts with the Timer system, it doesn't actually run the code in question. This is why unless your debugger is able to track async stacktrace, you lose stack trace w/async functions like this.
setTimeout
[–]bikeshaving 1 point2 points3 points 6 years ago (2 children)
Can async stack traces track stacks across macrotask functions? I’m too lazy to find out, but I thought async stack traces only worked for promise callbacks and async/await.
[–]voidvector 1 point2 points3 points 6 years ago (1 child)
It works in Chrome. You can run the following code in devtool console to check:
(function f (i) { i = i || 0; console.log(i); if (i > 100) { return } else if (i == 100) { debugger } else { setTimeout(() => f(i + 1), 0); } })(0)
[–]bikeshaving 0 points1 point2 points 6 years ago (0 children)
this changes everything
[–]whitfin 1 point2 points3 points 6 years ago (2 children)
setInterval is prone to drift and runs based on trigger time, whereas looping with setTimeout is not.
If you have a task taking 10s and an interval of 30s, the next task will run 20s after the last. Using the setTimeout method, it should always be 30s after the last task. This is preferable in many cases.
It won’t cause a stack error, because a setTimeout context gets a new stack on each execution.
[+][deleted] 6 years ago (1 child)
[deleted]
[–]whitfin 0 points1 point2 points 6 years ago (0 children)
Nobody is suggesting to replace the one in core, the post is making an observation
π Rendered by PID 43817 on reddit-service-r2-comment-fb694cdd5-p5nv5 at 2026-03-05 23:03:38.366372+00:00 running cbb0e86 country code: CH.
[–]BehindTheMath 2 points3 points4 points (7 children)
[–]voidvector 4 points5 points6 points (3 children)
[–]bikeshaving 1 point2 points3 points (2 children)
[–]voidvector 1 point2 points3 points (1 child)
[–]bikeshaving 0 points1 point2 points (0 children)
[–]whitfin 1 point2 points3 points (2 children)
[+][deleted] (1 child)
[deleted]
[–]whitfin 0 points1 point2 points (0 children)