| // 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(); |
| |
| %PrepareFunctionForOptimization(f); |
| 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); |
| } |
| } |