mirror of
https://github.com/denoland/deno.git
synced 2025-01-06 22:35:51 -05:00
perf(core): over-allocate in ModuleMap when running from snapshot (#18083)
This commit changes "ModuleMap" initialization to over-allocate by 16 for vectors storing module information and module V8 handles. In 99% cases there's gonna be at least one additional module loaded, so it's very wasteful to have to reallocate when the module is executed (IIRC Rust will double the size of the vector) and move all of the elements.
This commit is contained in:
parent
f9b43044ef
commit
80d1b29587
2 changed files with 5 additions and 2 deletions
|
@ -1129,7 +1129,8 @@ impl ModuleMap {
|
||||||
|
|
||||||
let info_arr: v8::Local<v8::Array> = info_val.try_into().unwrap();
|
let info_arr: v8::Local<v8::Array> = info_val.try_into().unwrap();
|
||||||
let len = info_arr.length() as usize;
|
let len = info_arr.length() as usize;
|
||||||
let mut info = Vec::with_capacity(len);
|
// Over allocate so executing a few scripts doesn't have to resize this vec.
|
||||||
|
let mut info = Vec::with_capacity(len + 16);
|
||||||
|
|
||||||
for i in 0..len {
|
for i in 0..len {
|
||||||
let module_info_arr: v8::Local<v8::Array> = info_arr
|
let module_info_arr: v8::Local<v8::Array> = info_arr
|
||||||
|
|
|
@ -463,7 +463,6 @@ impl JsRuntime {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut module_handles = vec![];
|
|
||||||
let mut scope = v8::ContextScope::new(scope, context);
|
let mut scope = v8::ContextScope::new(scope, context);
|
||||||
// The 0th element is the module map itself, followed by X number of module
|
// The 0th element is the module map itself, followed by X number of module
|
||||||
// handles. We need to deserialize the "next_module_id" field from the
|
// handles. We need to deserialize the "next_module_id" field from the
|
||||||
|
@ -476,6 +475,9 @@ impl JsRuntime {
|
||||||
info_data.length()
|
info_data.length()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Over allocate so executing a few scripts doesn't have to resize this vec.
|
||||||
|
let mut module_handles =
|
||||||
|
Vec::with_capacity(next_module_id as usize + 16);
|
||||||
for i in 1..=next_module_id {
|
for i in 1..=next_module_id {
|
||||||
match scope
|
match scope
|
||||||
.get_context_data_from_snapshot_once::<v8::Module>(i as usize)
|
.get_context_data_from_snapshot_once::<v8::Module>(i as usize)
|
||||||
|
|
Loading…
Reference in a new issue