套接字编程

网络编程:从某种程度上说就是进程间通信套接口类似于进程ID通过IP地址指定通信间的主机通过端口号和主机上的哪个进程通信,也就是通过IP+端口号唯一指定了通信的进程。

socket--创建一个套接字

close--销毁一个套接字

connect--在两个套接字之间创建连接

bind--新创建的套接字没有网络地址,通过BIND原语可以为套接字分配地址将一个服务器套接字绑定一个本地地址

connect函数:在处理面向连接的网络服务时,例如TCP,交换数据前必须在请求的进程套接字和提供服务的进程套接字之间建立连接。TCP客户端可以调用函数connect来建立与TCP服务器端的一个连接。

listen函数:服务器进程不知道要与谁连接,因此,他不会主动地要求与某个进程连接,只是一直监听是否有其他客户进程与之连接,然后响应该连接请求,并对它作出处理,一个服务进程可以同时处理多个客户进程的连接。

SEND:通过连接发送一些数据

RECEIVE:从连接上接收一些数据。


要通过Internet 进行通信,至少需要一对套接字,其中一个运行在客户端,称之为ClientSocket,另一个运行于服务器端,称之为ServerSocket。根据连接启动的方式以及本地要连接的目标,套接字之间的连接过程可以分为三个步骤:服务器监听,客户端请求,连接确认


服务器监听是指服务器端套接字并不定位于具体的客户端套接字,而是处于等待连接的状态,实时监控网络状态。

客户端请求是由客户端的套接字提出连接请求,要连接的目标是服务器端套接字。为此,客户端的套接字必须首先描述它要连接的服务器的套接字,指出服务器套接字的地址和端口号,然后再向服务器端套接字提出连接请求。

连接确认是当服务器端套接字监听到或者说接收到客户端套接字的连接请求时,它就响应客户端套接字的请求,建立一个新的线程,把服务器端套接字的信息发送给客户端,一旦客户端确认了此连接,连接即可建立。而服务器端继续处于监听状态,继续接收其他客户端的连接请求。

使用套接字进行数据处理有两种基本模式:同步和异步。
同步模式:
同步模式的特点是在通过Socket进行连接、接收、发送数据时,客户机和服务器在接收到对方响应前会处于阻塞状态即一直等到收到对方请求才继续执行下面的语句。可见,同步模式只适用于数据处理不太多的场合。当程序执行的任务很多时,长时间的等待可能会让用户无法忍受
异步模式:
异步模式的特点是在通过Socket进行连接、接收、发送操作时,客户机或服务器不会处于阻塞方式,而是利用callback机制进行连接、接收、发送处理,这样就可以在调用发送或接收的方法后直接返回,并继续执行下面的程序。可见,异步套接字特别适用于进行大量数据处理的场合。

套接字编程_第1张图片



你可能感兴趣的:(套接字编程)