diff --git a/faq.php b/faq.php index 681298aa1..a8374a3df 100644 --- a/faq.php +++ b/faq.php @@ -75,6 +75,7 @@
  • How do I use sf::Mutex?
  • Why can't I store my sf::Thread in an STL container?
  • Why doesn't sf::sleep sleep for the amount of time I want it to?
  • +
  • Is SFML thread-safe?
  • Programming in General

    @@ -588,6 +589,10 @@

    One thing to remember is that although the operating system marks your thread as "awake" after it is done sleeping, even for exactly the correct duration, it doesn't mean it resumes execution immediately. It could have just missed the moment at which the scheduler selects which task to execute next and thus must wait for the next transition. In this case, although your thread slept for the correct amount, it will appear to you as if it slept for more. SFML doesn't allow you to sleep for 0 duration, however if you could, you would notice that it in fact takes a slight bit of time as well. This is because it is common for specifying 0 to the operating system to translate to simply yielding your execution time slice to another thread.

    In the end, what this means is that sf::sleep() is merely a guideline, and not a contract. The longer you sleep for, the more accurate it will be. The shorter you sleep for, the less accurate it will be and to a certain extent more dependent on luck it will become.

    +

    Is SFML thread-safe?

    +

    No, SFML objects are not thread-safe by themselves. If you need thread-safety you must protect them. SFML comes with sf::Mutex and sf::Lock for this purpose but you can use other tools you may have available such as C++11's std::mutex and std::lock_guard as you see fit.

    +

    For more information on how to protect you shared data, refer to the official documentation.

    +

    Programming in General

    What is RAII and why does it rock?

    diff --git a/tutorials/2.6/graphics-draw-fr.php b/tutorials/2.6/graphics-draw-fr.php index 396dbc1c4..84a21f1be 100644 --- a/tutorials/2.6/graphics-draw-fr.php +++ b/tutorials/2.6/graphics-draw-fr.php @@ -182,11 +182,19 @@ }

    - Comme vous pouvez le voir, vous n'avez même pas besoin d'activer la fenêtre dans le thread de dessin, SFML le fait automatiquement pour vous dès que nécessaire. + Remarque : vous n'avez pas besoin d'activer la fenêtre dans le thread de dessin, SFML le fait automatiquement pour vous dès que nécessaire à condition + que le contexte OpenGL ait été correctement désactivé auparavant.

    Souvenez-vous : il faut toujours créer la fenêtre et gérer ses évènements dans le thread principal, pour un maximum de portabilité, comme expliqué dans le - tutoriel sur les fenêtres. + tutoriel sur les fenêtres. +

    +

    + L'exemple présentée ici n'est pas complètement thread-safe car un thread pourrait fermer la fenêtre pendant que l'autre l'utilise encore. + De manière générale, les objets SFML ne sont pas eux-mêmes thread-safes et vous devez vous-mêmes + protéger les données partagées.
    + Notez que vous pouvez dessiner et gérer les évènements d'une fenêtre dans deux threads différents sans soucis car ces + deux fonctionnalités sont complètement indépendantes.

    - As you can see, you don't even need to bother with the activation of the window in the rendering thread, SFML does it automatically for you whenever it needs to be done. + Note that you don't need to activate the window in the rendering thread, SFML does it automatically for you whenever it needs + to be done, as long as the OpenGL context is properly deactivate beforehand.

    Remember to always create the window and handle its events in the main thread for maximum portability. This is explained in the - window tutorial. + window tutorial. +

    +

    + The example shown here is not completely thread-safe because a thread could close the window while another still uses it. + Generally speaking, SFML objects are not themselves thread-safe and you need to + protect the shared data yourself.
    + Note that you can draw and handle the events of a window in two different threads without issues because these + two functionalities are independent.

    thread-safe, le résultat sera indéterminé (c'est-à-dire que cela pourrait planter ou corrompre des données).

    +

    + Les objets SFML ne sont en général pas thread-safe. Vous devez les protéger si vous les utilisez dans plusieurs threads en même temps ! +

    Il existe plusieurs outils de programmation pour vous aider à protéger les variables partagées et rendre votre code thread-safe, ils sont appelés "primitives de synchronisation". Les plus communs sont les mutexs, les sémaphores, les conditions d'attente et les spin locks. diff --git a/tutorials/2.6/system-thread.php b/tutorials/2.6/system-thread.php index 193b1aa4d..ed12e7aff 100644 --- a/tutorials/2.6/system-thread.php +++ b/tutorials/2.6/system-thread.php @@ -222,6 +222,9 @@ classes are a good solution. since threads run in parallel, it means that a variable or function might be used concurrently from several threads at the same time. If the operation is not thread-safe, it can lead to undefined behavior (ie. it might crash or corrupt data).

    +

    + SFML objects are usually not thread-safe. You must protect them to use them in multiple threads at the same time! +

    Several programming tools exist to help you protect shared data and make your code thread-safe, these are called synchronization primitives. Common ones are mutexes, semaphores, condition variables and spin locks. They are all variants of the same concept: they protect a piece of code by allowing only