1. ► setjmp and longjmp do not save the context before making the jump, they are analogus to a non-local go to.
2. ► Processes must acquire a lock before modifying a shared data-structure.
3. ► One cannot register a handler on the SIGTERM signal.
4. ► A thread is a light-weight process.
5. ► It is possible to define a *payload data* for signals.
6. ► fork on Linux is not very efficient and hence vfork should be used.
7. ► Daemon processes must leave control of the terminal from which they were launched.
8. ► Init process on UNIX is only responsible for starting new processes.
9. ► General signals do not have a time-guarantee for delivery.
10. ► wait function can be used to wait on at most one child.
11. ► Zombie processes are those whose parents have died.
12. ► dlsym function checks for type mismatch before assigning it to the function pointer and will fail if the types mismatch.
13. ► Race conditions and deadlocks have due to same reason.
14. ► sigsuspend takes as input the inverse of the mask to be applied to the incoming signals.
15. ► It is not possible to pass arguments to the functions registered using atexit call.
16. ► pthread_join will wait for all the threads to complete before returning.
17. ► Threads can access all the data of their parent process.
18. ► The maximum nice value which a process can have is 30.
19. ► One cannot register a handler on the SIGKILL signal.
20. ► system function is identical to exec barring the way the arguments are passed to the underlying command.