Whenever we perform some operation on a socket, it may not be able to complete immediately and return control back to your program.
For example:
A read on a socket cannot complete until some data has been sent by the remote host.If there is no data waiting to be read, one of the two things can happen,
The first case is called "Synchronous or blocking socket".For example:
A read on a socket cannot complete until some data has been sent by the remote host.If there is no data waiting to be read, one of the two things can happen,
- The function can wait until some data has been written on the socket, OR
- It can return immediately with an error that indicates that there is no data to be read.
The program is "blocked" until the request for the data has been satisfied. When the remote system does write some data on the socket, the read operation will complete and execution of the program will resume.
The second case is called an "Asynchronous or non-blocking socket", and requires that the application recognize the error condition and handle the situation properly.