/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set ts=8 sts=2 et sw=2 tw=80: */ // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file.
for (;;) {
ScopedNSAutoreleasePool autorelease_pool;
hangMonitor.NotifyActivity(); bool did_work = delegate->DoWork(); if (!keep_running_) break;
hangMonitor.NotifyActivity();
did_work |= delegate->DoDelayedWork(&delayed_work_time_); if (!keep_running_) break;
if (did_work) continue;
hangMonitor.NotifyActivity();
did_work = delegate->DoIdleWork(); if (!keep_running_) break;
if (did_work) continue;
if (delayed_work_time_.is_null()) {
hangMonitor.NotifyWait();
AUTO_PROFILER_LABEL("MessagePumpDefault::Run:Wait", IDLE);
{
AUTO_PROFILER_THREAD_SLEEP;
event_.Wait();
}
} else {
TimeDelta delay = delayed_work_time_ - TimeTicks::Now(); if (delay > TimeDelta()) {
hangMonitor.NotifyWait();
AUTO_PROFILER_LABEL("MessagePumpDefault::Run:Wait", IDLE);
{
AUTO_PROFILER_THREAD_SLEEP;
event_.TimedWait(delay);
}
} else { // It looks like delayed_work_time_ indicates a time in the past, so we // need to call DoDelayedWork now.
delayed_work_time_ = TimeTicks();
}
} // Since event_ is auto-reset, we don't need to do anything special here // other than service each delegate method.
}
void MessagePumpDefault::ScheduleWork() { // Since this can be called on any thread, we need to ensure that our Run // loop wakes up.
event_.Signal();
}
void MessagePumpDefault::ScheduleDelayedWork( const TimeTicks& delayed_work_time) { // We know that we can't be blocked on Wait right now since this method can // only be called on the same thread as Run, so we only need to update our // record of how long to sleep when we do sleep.
delayed_work_time_ = delayed_work_time;
}
} // namespace base
Messung V0.5
¤ Dauer der Verarbeitung: 0.8 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.