-
Notifications
You must be signed in to change notification settings - Fork 1.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
massive slowdown from new scrollbar #5186
Comments
@jerch timeouts are actually massively inflated in devtools so can't be trusted in a profile. This isn't actually a problem. Back when we could use the JavaScript profiler tab in devtools this could be verified as all the overhead involved in the performance tab could be removed, but they removed this from Chromium unfortunately. |
Having said that, we could add some debouncing or something to the onDidScroll event which would make the profiles much less noisy. Ideally I think a single event per task would run a microtask. |
Oh well, wasn't aware that setTimeout/clearTimeout are that toxic in the profiler. Its prolly the same with my other comment here --> #5176 (comment) |
I am indeed seeing tons of setTimeout/clearTimeout showing up in traces which supposedly contributes quite a bit to overall time spent in JS: But it sounds like you're saying this may not really be true?
anywhere I can find some further reading or examples of this? |
@jtbandes You'd spot that difference, if you do your own timings with the wall clock. e.g: const start = Date.now(); // or performance for better granularity
call_heavy_setTimout_code_here();
console.log(Date.now() - start); then do a run with profiling and a second one without devtools open. The difference between the the time taken will be almost all, what the profiler tells you as runtime for the There is another domain, where devtools in chromium heavily screws up the timing data - heavy IO. Kinda learnt that the hard way scratching my head for some time, when optimizing IO throughput. I only figured it, when I accidently run things without devtools and was like "wut, why is that so much faster?". Turned out that most of the grey piece in the pie chart was made up by the profiler. I ended up doing most IO optimization with that "printf" profiling, as the profiler was not to be trusted, lol. My best guess is, that the chromium profiler has some issues to correctly account runtime for threaded actions (most likely the timer and IO run in a different thread). I tried digging it up, but found nothing about that in v8 docs. @Firefox |
Using this TS playground I observe the following (Chrome 131.0.6778.140, macOS 15.2, M1 Pro):
It does seem like a pretty significant effect! However would still be nice to reduce these unnecessary calls :) |
Repro:
ls -lR /usr
in demo--> massive slowdown with high CPU usage, seems to be caused by tons of setTimeout/clearTimeout calls
The text was updated successfully, but these errors were encountered: