瀏覽代碼

LibJS: Share argument values buffer between calls

This buffer is being created and then immediately destroyed,
let's reuse it to reduce memory allocations.
Jonne Ransijn 8 月之前
父節點
當前提交
80f0900565
共有 2 個文件被更改,包括 8 次插入3 次删除
  1. 2 3
      Userland/Libraries/LibJS/Bytecode/Interpreter.cpp
  2. 6 0
      Userland/Libraries/LibJS/Bytecode/Interpreter.h

+ 2 - 3
Userland/Libraries/LibJS/Bytecode/Interpreter.cpp

@@ -2545,10 +2545,9 @@ ThrowCompletionOr<void> Call::execute_impl(Bytecode::Interpreter& interpreter) c
         return {};
     }
 
-    Vector<Value> argument_values;
-    argument_values.ensure_capacity(m_argument_count);
+    auto argument_values = interpreter.allocate_argument_values(m_argument_count);
     for (size_t i = 0; i < m_argument_count; ++i)
-        argument_values.unchecked_append(interpreter.get(m_arguments[i]));
+        argument_values[i] = interpreter.get(m_arguments[i]);
     interpreter.set(dst(), TRY(perform_call(interpreter, interpreter.get(m_this_value), call_type(), callee, argument_values)));
     return {};
 }

+ 6 - 0
Userland/Libraries/LibJS/Bytecode/Interpreter.h

@@ -77,6 +77,11 @@ public:
     Executable& current_executable() { return *m_current_executable; }
     Executable const& current_executable() const { return *m_current_executable; }
     Optional<size_t> program_counter() const { return m_program_counter; }
+    Span<Value> allocate_argument_values(size_t argument_count)
+    {
+        m_argument_values_buffer.resize_and_keep_capacity(argument_count);
+        return m_argument_values_buffer.span();
+    }
 
     ExecutionContext& running_execution_context() { return *m_running_execution_context; }
 
@@ -98,6 +103,7 @@ private:
     Optional<size_t&> m_program_counter;
     Span<Value> m_arguments;
     Span<Value> m_registers_and_constants_and_locals;
+    Vector<Value> m_argument_values_buffer;
     ExecutionContext* m_running_execution_context { nullptr };
 };