wxCriticalSectionLocker 2. New overviews: Threads overview, Container classes overview 3. A modest update of wxList/wxNode docs to bring them up to date with the new classes (array.tex is simply empty for the moment) git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@1311 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			133 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
| \section{\class{wxThread}}\label{wxthread}
 | |
| 
 | |
| A thread is basically a path of execution through a program. Threads are also
 | |
| sometimes calls {\it light-wight processes}, but the fundamental difference
 | |
| between threads and processes is that memory spaces of different processes are
 | |
| separated while all threads share the same address space. While it makes it
 | |
| much easier to share common data between several threads, it also makes much
 | |
| easier to shoot oneself in a leg, so careful use of synchronization objects
 | |
| such as \helpref{mutexes}{wxmutex} and/or \helpref{critical 
 | |
| sections}{wxcriticalsection} is recommended.
 | |
| 
 | |
| \wxheading{Derived from}
 | |
| 
 | |
| None.
 | |
| 
 | |
| \wxheading{See also}
 | |
| 
 | |
| \helpref{wxMutex}{wxmutex}, \helpref{wxCondition}{wxcondition}
 | |
| 
 | |
| \latexignore{\rtfignore{\wxheading{Members}}}
 | |
| 
 | |
| \membersection{wxThread::wxThread}\label{wxthreadconstr}
 | |
| 
 | |
| \func{}{wxThread}{\void}
 | |
| 
 | |
| Default constructor.
 | |
| 
 | |
| \membersection{wxThread::\destruct{wxThread}}
 | |
| 
 | |
| \func{}{\destruct{wxThread}}{\void}
 | |
| 
 | |
| Destroys the wxThread object.
 | |
| 
 | |
| \membersection{wxThread::Create}\label{wxthreadcreate}
 | |
| 
 | |
| \func{wxThreadError}{Create}{\void}
 | |
| 
 | |
| Creates a thread control.
 | |
| 
 | |
| \wxheading{Return value}
 | |
| 
 | |
| One of:
 | |
| 
 | |
| \twocolwidtha{7cm}
 | |
| \begin{twocollist}\itemsep=0pt
 | |
| \twocolitem{{\bf wxTHREAD\_NO\_ERROR}}{There was no error.}
 | |
| \twocolitem{{\bf wxTHREAD\_NO\_RESOURCE}}{There were insufficient resources to create a new thread.}
 | |
| \twocolitem{{\bf wxTHREAD\_RUNNING}}{The thread is already running.}
 | |
| \end{twocollist}
 | |
| 
 | |
| \membersection{wxThread::DeferDestroy}\label{wxthreaddeferdestroy}
 | |
| 
 | |
| \func{void}{DeferDestroy}{\param{bool}{ defer}}
 | |
| 
 | |
| If {\it defer} is TRUE, defers thread destruction. This function affects the
 | |
| calling thread.
 | |
| 
 | |
| \membersection{wxThread::Destroy}\label{wxthreaddestroy}
 | |
| 
 | |
| \func{wxThreadError}{Destroy}{\void}
 | |
| 
 | |
| Destroys the thread immediately unless the application has specified deferral via \helpref{wxThread::DeferDestroy}{wxthreaddeferdestroy}.
 | |
| 
 | |
| \wxheading{Return value}
 | |
| 
 | |
| One of:
 | |
| 
 | |
| \twocolwidtha{7cm}
 | |
| \begin{twocollist}\itemsep=0pt
 | |
| \twocolitem{{\bf wxTHREAD\_NO\_ERROR}}{There was no error.}
 | |
| \twocolitem{{\bf wxTHREAD\_NOT\_RUNNING}}{The thread is not running.}
 | |
| \end{twocollist}
 | |
| 
 | |
| \membersection{wxThread::GetID}\label{wxthreadgetid}
 | |
| 
 | |
| \constfunc{unsigned long}{GetID}{\void}
 | |
| 
 | |
| Gets the thread identifier.
 | |
| 
 | |
| \membersection{wxThread::GetPriority}\label{wxthreadgetpriority}
 | |
| 
 | |
| \constfunc{int}{GetPriority}{\void}
 | |
| 
 | |
| Gets the priority of the thread, between zero and 100.
 | |
| 
 | |
| The following priorities are already defined:
 | |
| 
 | |
| \twocolwidtha{7cm}
 | |
| \begin{twocollist}\itemsep=0pt
 | |
| \twocolitem{{\bf WXTHREAD\_MIN\_PRIORITY}}{0}
 | |
| \twocolitem{{\bf WXTHREAD\_DEFAULT\_PRIORITY}}{50}
 | |
| \twocolitem{{\bf WXTHREAD\_MAX\_PRIORITY}}{100}
 | |
| \end{twocollist}
 | |
| 
 | |
| \membersection{wxThread::IsAlive}\label{wxthreadisalive}
 | |
| 
 | |
| \constfunc{bool}{IsAlive}{\void}
 | |
| 
 | |
| Returns TRUE if the thread is alive.
 | |
| 
 | |
| \membersection{wxThread::IsMain}\label{wxthreadismain}
 | |
| 
 | |
| \constfunc{bool}{IsMain}{\void}
 | |
| 
 | |
| Returns TRUE if the calling thread is the main application thread.
 | |
| 
 | |
| \membersection{wxThread::Join}\label{wxthreadjoin}
 | |
| 
 | |
| \func{void*}{Join}{\void}
 | |
| 
 | |
| Waits for the termination of the thread. Returns a platform-specific exit code. TODO
 | |
| 
 | |
| \membersection{wxThread::OnExit}\label{wxthreadonexit}
 | |
| 
 | |
| \func{void}{OnExit}{\void}
 | |
| 
 | |
| Called when the thread exits. The default implementation calls \helpref{wxThread::Join}{wxthreadjoin}.
 | |
| 
 | |
| \membersection{wxThread::SetPriority}\label{wxthreadsetpriority}
 | |
| 
 | |
| \func{void}{SetPriority}{\param{int}{ priority}}
 | |
| 
 | |
| Sets the priority of the thread, between zero and 100. This must be set before the thread is created.
 | |
| 
 | |
| The following priorities are already defined:
 | |
| 
 | |
| \twocolwidtha{7cm}
 | |
| \begin{twocollist}\itemsep=0pt
 | |
| \twocolitem{{\bf WXTHREAD\_MIN\_PRIORITY}}{0}
 | |
| \twocolitem{{\bf WXTHREAD\_DEFAULT\_PRIORITY}}{50}
 | |
| \twocolitem{{\bf WXTHREAD\_MAX\_PRIORITY}}{100}
 | |
| \end{twocollist}
 |