Wiki Page Content

Differences between revisions 10 and 11
Revision 10 as of 2011-04-13 17:54:51
Size: 2192
Editor: SheenaSmith
Comment: minor change
Revision 11 as of 2011-10-03 21:58:31
Size: 2359
Editor: SheenaSmith
Comment: update content for consistency - intro description
Deletions are marked like this. Additions are marked like this.
Line 5: Line 5:
#pragma camelcase off
Line 14: Line 15:
This category contains functions for system independent thread management routines.
Line 16: Line 19:

<<Color2(green,Should SDL_thread.c be hyperlinked?)>>

DRAFT

Thread Management

Include File(s): SDL_thread.h, SDL_mutex.h (contains thread synchronization primitives)

Introduction

This category contains functions for system independent thread management routines.

The SDL thread structure is defined in SDL_thread.c.

  • typedef struct SDL_Thread SDL_Thread;

green

We compile SDL into a DLL. This means that it's the DLL which creates a new thread for the calling process with the SDL_CreateThread() API. There is a problem with this, that only the RTL of the SDL.DLL will be initialized for those threads, and not the RTL of the calling application!

To solve this, we make a little hack here. green

We'll always use the caller's _beginthread() and _endthread() APIs to start a new thread. This way, if it's the SDL.DLL which uses this API, then the RTL of SDL.DLL will be used to create the new thread, and if it's the application, then the RTL of the application will be used.

So, in short: Always use the _beginthread() and _endthread() of the calling runtime library!

green

NOTE: You should not expect to be able to create a window, render, or receive events on any thread other than the main one. For platform-specific exceptions or complicated options ask on the mailing list or forum.

Enumerations

Functions


CategoryCategory

None: CategoryThread (last edited 2017-07-15 21:51:08 by PhilippWiesemann)

(Page Info.)
Feedback
Please include your contact information if you'd like to receive a reply.
Submit