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

Side by Side Diff: base/platform_thread.h

Issue 40133: Adding support for non joinable threads to PlatformThread (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 | « no previous file | base/platform_thread_posix.cc » ('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 // WARNING: You should *NOT* be using this class directly. PlatformThread is 5 // WARNING: You should *NOT* be using this class directly. PlatformThread is
6 // the low-level platform-specific abstraction to the OS's threading interface. 6 // the low-level platform-specific abstraction to the OS's threading interface.
7 // You should instead be using a message-loop driven Thread, see thread.h. 7 // You should instead be using a message-loop driven Thread, see thread.h.
8 8
9 #ifndef BASE_PLATFORM_THREAD_H_ 9 #ifndef BASE_PLATFORM_THREAD_H_
10 #define BASE_PLATFORM_THREAD_H_ 10 #define BASE_PLATFORM_THREAD_H_
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after
58 // that the default stack size should be used. Upon success, 58 // that the default stack size should be used. Upon success,
59 // |*thread_handle| will be assigned a handle to the newly created thread, 59 // |*thread_handle| will be assigned a handle to the newly created thread,
60 // and |delegate|'s ThreadMain method will be executed on the newly created 60 // and |delegate|'s ThreadMain method will be executed on the newly created
61 // thread. 61 // thread.
62 // NOTE: When you are done with the thread handle, you must call Join to 62 // NOTE: When you are done with the thread handle, you must call Join to
63 // release system resources associated with the thread. You must ensure that 63 // release system resources associated with the thread. You must ensure that
64 // the Delegate object outlives the thread. 64 // the Delegate object outlives the thread.
65 static bool Create(size_t stack_size, Delegate* delegate, 65 static bool Create(size_t stack_size, Delegate* delegate,
66 PlatformThreadHandle* thread_handle); 66 PlatformThreadHandle* thread_handle);
67 67
68 // CreateNonJoinable() does the same thing as Create() except the thread
69 // cannot be Join()'d. Therefore, it also does not output a
70 // PlatformThreadHandle.
71 static bool CreateNonJoinable(size_t stack_size, Delegate* delegate);
72
68 // Joins with a thread created via the Create function. This function blocks 73 // Joins with a thread created via the Create function. This function blocks
69 // the caller until the designated thread exits. This will invalidate 74 // the caller until the designated thread exits. This will invalidate
70 // |thread_handle|. 75 // |thread_handle|.
71 static void Join(PlatformThreadHandle thread_handle); 76 static void Join(PlatformThreadHandle thread_handle);
72 77
73 private: 78 private:
74 DISALLOW_IMPLICIT_CONSTRUCTORS(PlatformThread); 79 DISALLOW_IMPLICIT_CONSTRUCTORS(PlatformThread);
75 }; 80 };
76 81
77 #endif // BASE_PLATFORM_THREAD_H_ 82 #endif // BASE_PLATFORM_THREAD_H_
78
OLDNEW
« no previous file with comments | « no previous file | base/platform_thread_posix.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698