Performance
- Added std::vector::reserve calls to reduce allocations and copying.
This commit is contained in:
18
src/TDB2.cpp
18
src/TDB2.cpp
@@ -271,6 +271,9 @@ void TF2::load_tasks ()
|
|||||||
int line_number = 0;
|
int line_number = 0;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
// Reduce unnecessary allocations/copies.
|
||||||
|
_tasks.reserve (_lines.size ());
|
||||||
|
|
||||||
std::vector <std::string>::iterator i;
|
std::vector <std::string>::iterator i;
|
||||||
for (i = _lines.begin (); i != _lines.end (); ++i)
|
for (i = _lines.begin (); i != _lines.end (); ++i)
|
||||||
{
|
{
|
||||||
@@ -1519,6 +1522,10 @@ int TDB2::gc ()
|
|||||||
std::vector <Task> pending_tasks_after;
|
std::vector <Task> pending_tasks_after;
|
||||||
std::vector <Task> completed_tasks_after;
|
std::vector <Task> completed_tasks_after;
|
||||||
|
|
||||||
|
// Reduce unnecessary allocation/copies.
|
||||||
|
pending_tasks_after.reserve (pending_tasks.size ());
|
||||||
|
completed_tasks_after.reserve (completed_tasks.size ());
|
||||||
|
|
||||||
// Scan all pending tasks, looking for any that need to be relocated to
|
// Scan all pending tasks, looking for any that need to be relocated to
|
||||||
// completed, or need to be 'woken'.
|
// completed, or need to be 'woken'.
|
||||||
Date now;
|
Date now;
|
||||||
@@ -1624,8 +1631,15 @@ int TDB2::next_id ()
|
|||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
const std::vector <Task> TDB2::all_tasks ()
|
const std::vector <Task> TDB2::all_tasks ()
|
||||||
{
|
{
|
||||||
std::vector <Task> all = pending.get_tasks ();
|
std::vector <Task> all (pending._tasks.size () +
|
||||||
std::vector <Task> extra = completed.get_tasks ();
|
pending._added_tasks.size () +
|
||||||
|
completed._tasks.size () +
|
||||||
|
completed._added_tasks.size ());
|
||||||
|
all = pending.get_tasks ();
|
||||||
|
|
||||||
|
std::vector <Task> extra (completed._tasks.size () +
|
||||||
|
completed._added_tasks.size ());
|
||||||
|
extra = completed.get_tasks ();
|
||||||
|
|
||||||
std::vector <Task>::iterator task;
|
std::vector <Task>::iterator task;
|
||||||
for (task = extra.begin (); task != extra.end (); ++task)
|
for (task = extra.begin (); task != extra.end (); ++task)
|
||||||
|
|||||||
Reference in New Issue
Block a user