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