Skip to content

Commit

Permalink
exit: explain our expectations for the exit handlers registered in a …
Browse files Browse the repository at this point in the history
…Rust program
  • Loading branch information
RalfJung committed Aug 25, 2024
1 parent 8dafd33 commit b392703
Showing 1 changed file with 9 additions and 0 deletions.
9 changes: 9 additions & 0 deletions std/src/process.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2296,6 +2296,15 @@ impl Child {
/// }
/// ```
///
/// In its current implementation, this function will execute exit handlers registered with `atexit`
/// as well as other platform-specific exit handlers (e.g. `fini` sections of ELF shared objects).
/// This means that Rust requires that all exit handlers are safe to execute at any time. In
/// particular, if an exit handler cleans up some state that might be concurrently accessed by other
/// threads, it is required that the exit handler performs suitable synchronization with those
/// threads. (The alternative to this requirement would be to not run exit handlers at all, which is
/// considered undesirable. Note that returning from `main` also calls `exit`, so making `exit` an
/// unsafe operation is not an option.)
///
/// ## Platform-specific behavior
///
/// **Unix**: On Unix-like platforms, it is unlikely that all 32 bits of `exit`
Expand Down

0 comments on commit b392703

Please # to comment.