// Copyright 2017 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file // Flags: --allow-natives-syntax --expose-gc new BenchmarkSuite('ManyClosures', [1000], [ new Benchmark('CreateManyClosures', false, true, 1, CreateManyClosures, CreateManyClosures_Setup) ]); // ---------------------------------------------------------------------------- // This program creates many closures and then allocates many arrays in order // to trigger garbage collection cycles. The goal of this micro-benchmark is to // evaluate the overhead of keeping the weak-list of optimized JS functions. // // c.f. https://bugs.chromium.org/p/v8/issues/detail?id=6637#c5 var a = []; %NeverOptimizeFunction(CreateManyClosures_Setup); function CreateManyClosures_Setup() { function g() { return (i) => i + 1; } // Create a closure and optimize. var f = g(); f(0); f(0); %OptimizeFunctionOnNextCall(f); f(0); // Create 2M closures, those will get the optimized code. a = []; for (var i = 0; i < 2000000; i++) { var f = g(); f(); a.push(f); } } %NeverOptimizeFunction(CreateManyClosures); function CreateManyClosures() { // Now cause scavenges. for (var i = 0; i < 50; i++) { gc(true); } }