1
0
Fork 0
mirror of https://git.suyu.dev/suyu/sirit.git synced 2025-01-03 09:26:03 +00:00

op: Use std::vector's insert member function within vector variant of Add()

While looping here does work fine, it's mildly inefficient, particularly
if the number of members being added is large, because it can result in
multiple allocations over the period of the insertion, depending on how
much extra memory push_back may allocate for successive elements.

Instead, we can just tell the std::vector that we want to slap the whole
contained sequence at the back of it with insert, which lets it allocate
the whole memory block in one attempt.
This commit is contained in:
Lioncash 2019-03-14 03:12:55 -04:00 committed by ReinUsesLisp
parent 6fd44e494c
commit f6f5913b5f

View file

@ -115,9 +115,7 @@ void Op::Add(std::string string) {
} }
void Op::Add(const std::vector<Id>& ids) { void Op::Add(const std::vector<Id>& ids) {
for (Id op : ids) { operands.insert(operands.end(), ids.begin(), ids.end());
Add(op);
}
} }
u16 Op::WordCount() const { u16 Op::WordCount() const {