File: do_work_500ms.html

package info (click to toggle)
firefox 147.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,683,320 kB
  • sloc: cpp: 7,607,359; javascript: 6,533,295; ansic: 3,775,223; python: 1,415,500; xml: 634,561; asm: 438,949; java: 186,241; sh: 62,752; makefile: 18,079; objc: 13,092; perl: 12,808; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10; exp: 6
file content (41 lines) | stat: -rw-r--r-- 1,077 bytes parent folder | download | duplicates (24)
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
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Do some work for 500ms</title>
  <script>
    const milliseconds = 500;
    const millisecondsPerBatch = 10;
    const end = Date.now() + milliseconds;
    window.total = 0;
    let i = 0;

    /**
     * Do work for a set number of milliseconds, but only do the work in batches
     * so the browser does not get unresponsive.
     */
    function doWork() {
      const batchEnd = Date.now() + millisecondsPerBatch;
      // Do some work for a set amount of time.
      while (Date.now() < end) {
        // Do some kind of work that is non-deterministic to guard against optimizations.
        window.total += Math.random();
        i++;

        // Check if a batch is done yet.
        if (Date.now() > batchEnd) {
          // Defer the rest of the work into a micro task. Keep on doing this until
          // the total milliseconds have elapsed.
          setTimeout(doWork, 0);
          return;
        }
      }
    }

    doWork();
  </script>
</head>
<body>
  Do some work for 500ms.
</body>
</html>