Try/Catch performance overhead

JavaScript performance comparison

Revision 9 of this test case created

Info

Using try/catch inside of functions that allocate lots of variables introduces significant overhead. See this discussion related to node.js https://groups.google.com/forum/#!topic/nodejs-dev/E-Re9KDDo5w

Interestingly, other js engines don't have this overhead. All test runs have pretty uniform performance. But they are also significantly slower than the v8 control case.

Preparation code

<script>
  var tries = 10000;
 
  function test1() {
   function test(j) {
    var s = 0;
    for (var i = 0; i < j; i++) s = i;
    for (var i = 0; i < j; i++) s = i;
    for (var i = 0; i < j; i++) s = i;
    for (var i = 0; i < j; i++) s = i;
    return s;
   }
 
   test(tries);
  }
 
  function test2() {
   function test(j) {
    try {
     var s = 0;
     for (var i = 0; i < j; i++) s = i;
     for (var i = 0; i < j; i++) s = i;
     for (var i = 0; i < j; i++) s = i;
     for (var i = 0; i < j; i++) s = i;
     return s;
    }
    catch (ex) {}
   }
 
   test(tries);
  }
 
  function test3() {
   function test(j) {
    var s = 0;
    for (var i = 0; i < j; i++) s = i;
    for (var i = 0; i < j; i++) s = i;
    for (var i = 0; i < j; i++) s = i;
    for (var i = 0; i < j; i++) s = i;
    return s;
   }
 
   try {
    test(tries);
   }
   catch (ex) {}
  }

  function test4() {
    function test(j) {
     var i, s;
     for(i = 0; i < j; i++) {
         try {
            s = i;  
         }
         catch (ex) {}
     }
     for(i = 0; i < j; i++) {
         try {
            s = i;  
         }
         catch (ex) {}
     }
     for(i = 0; i < j; i++) {
         try {
            s = i;  
         }
         catch (ex) {}
     }
     for(i = 0; i < j; i++) {
         try {
            s = i;  
         }
         catch (ex) {}
     }

     return s;
   }

   test(tries);
  }
</script>

Test runner

Warning! For accurate results, please disable Firebug before running the tests. (Why?)

Java applet disabled.

Testing in unknown unknown
Test Ops/sec
control - no try/catch
test1();
pending…
try/catch inside function
test2();
pending…
try/catch outside function
test3();
pending…
try/catch inside for loop
test4()
pending…

Compare results of other browsers

Revisions

You can edit these tests or add even more tests to this page by appending /edit to the URL. Here’s a list of current revisions for this page:

0 comments

Add a comment