Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(283)

Side by Side Diff: base/condition_variable.h

Issue 46039: Removed unneeded includes of base/scoped_ptr.h. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 11 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « base/command_line.h ('k') | base/histogram.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // ConditionVariable wraps pthreads condition variable synchronization or, on 5 // ConditionVariable wraps pthreads condition variable synchronization or, on
6 // Windows, simulates it. This functionality is very helpful for having 6 // Windows, simulates it. This functionality is very helpful for having
7 // several threads wait for an event, as is common with a thread pool managed 7 // several threads wait for an event, as is common with a thread pool managed
8 // by a master. The meaning of such an event in the (worker) thread pool 8 // by a master. The meaning of such an event in the (worker) thread pool
9 // scenario is that additional tasks are now available for processing. It is 9 // scenario is that additional tasks are now available for processing. It is
10 // used in Chrome in the DNS prefetching system to notify worker threads that 10 // used in Chrome in the DNS prefetching system to notify worker threads that
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
59 // may improve performance, as the selected thread may have a greater chance of 59 // may improve performance, as the selected thread may have a greater chance of
60 // having some of its stack data in various CPU caches. 60 // having some of its stack data in various CPU caches.
61 // 61 //
62 // For a discussion of the many very subtle implementation details, see the FAQ 62 // For a discussion of the many very subtle implementation details, see the FAQ
63 // at the end of condition_variable_win.cc. 63 // at the end of condition_variable_win.cc.
64 64
65 #ifndef BASE_CONDITION_VARIABLE_H_ 65 #ifndef BASE_CONDITION_VARIABLE_H_
66 #define BASE_CONDITION_VARIABLE_H_ 66 #define BASE_CONDITION_VARIABLE_H_
67 67
68 #include "base/lock.h" 68 #include "base/lock.h"
69 #include "base/scoped_ptr.h"
70 #include "base/time.h" 69 #include "base/time.h"
71 70
72 class ConditionVariable { 71 class ConditionVariable {
73 public: 72 public:
74 // Construct a cv for use with ONLY one user lock. 73 // Construct a cv for use with ONLY one user lock.
75 explicit ConditionVariable(Lock* user_lock); 74 explicit ConditionVariable(Lock* user_lock);
76 75
77 ~ConditionVariable(); 76 ~ConditionVariable();
78 77
79 // Wait() releases the caller's critical section atomically as it starts to 78 // Wait() releases the caller's critical section atomically as it starts to
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after
163 162
164 pthread_cond_t condition_; 163 pthread_cond_t condition_;
165 pthread_mutex_t* user_mutex_; 164 pthread_mutex_t* user_mutex_;
166 165
167 #endif 166 #endif
168 167
169 DISALLOW_COPY_AND_ASSIGN(ConditionVariable); 168 DISALLOW_COPY_AND_ASSIGN(ConditionVariable);
170 }; 169 };
171 170
172 #endif // BASE_CONDITION_VARIABLE_H_ 171 #endif // BASE_CONDITION_VARIABLE_H_
OLDNEW
« no previous file with comments | « base/command_line.h ('k') | base/histogram.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698