欢迎来到天天文库
浏览记录
ID:27775596
大小:183.61 KB
页数:17页
时间:2018-12-06
《tcp/ip网络技术基础重点》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、用TCP/IP进行网际互连一一客户-服务器编程与应用1.客户-服务器模式在分布式计算中,一个应用程序被动地等待,而另一个应用程序通过请求启动通信的模式,称为客户-服务器模式。其中:发起通信的应用程序称为客户,等待接收客户通信请求的程序称为服务器。客户和服务器分别指两个应用程序,但在实际工作中,我们也将运行服务器程序的计算机简称为服务器。2.充当客户的服务器在服务器计算某个请求的响应时,它可能需要访问其他的网络服务。因此,服务器也可能充当客户。在一个有许多可供使用的服务器的网络环境中,经常可以发现某个应用的服务器对另一个应用则是客户。3.并发是指真正或表面呈现的同吋计算。真正的并发:D
2、NA计算机、多处理器(Multiprocessing)计算机;表面呈现的并发:通过分时(timesharing)机制,使得单个处理器在多个任务之间足够快地切换,以致从表面上这些计算似乎是在同时进行的,从而获得并发的效果。4.进程vs线程进程:是执行程序的实例,是具有一定独立功能的程序关于某个数据集合上的一次运行活动,而不是程序的静态版本。进程包括一段地址空间和至少一个执行的线程。线程最重要的信息时一个指令指针,它指明该进程正在执行的地址。线程:是进程中执行运算的最小单位,亦即执行处理机调度的基本单位。关系:线程是进程的一个组成部分,线程由进程创建,因此一个进程中至少存在一个线程,线程
3、还可以创建其它线程;进程是资源分配和保护的基本单位,线程只能在进程的地址空间活动,线程只能使用其所在进程的资源;线程作为基本的调度单位,其状态有:就绪、运行、阻塞等;进程屮所有线程共享进程的存储空间和分配资源。线程的特征:动态创建、并发执行、抢先、私有局部变量、共享全局变量、共享文件描述符、协调和同步函数。线程的优点:更高的效率:上下文交换的额外开销减少;共享的存储器:通信开销减少,且更容易构造监控系统。补充:创建和撤消线程的开销非常小:不需要向系统请求独立的地址空间及进行相关的地址空间复制(例如父子进程),因此创建和撤销线程系统的开销要远小于进程。线程的缺点:由于线程间共享存储器和
4、进程状态,一个线程的动作可能对同一进程中的其他线程产生影响:线程安全;健壮性。进程中有多个线程在同时运行,而这些线程可能会同时运行一段代码。如果每次运行结果和单线程运行的结果是一样的,而且其他的变量的值也和预期的是一样的,就是线程安全的。若每个线程中对全局变量、静态变量只有读操作,而无写操作,一般来说,这个全局变量是线程安全的;若有多个线程同时执行写操作,一般都需要考虑线程同步,否则就可能影响线程安全。多个线程操作同一个数据段时,用相应的互斥机制,避免数据段中的数据错误。1.局部和全局变量的共享如果多个线程在同一个进程内执行,则它们各自拥有一份独立的局部变量的副本,且都可以共享进程的
5、全局变量副本。forkO函数:将运行的程序分为两个几乎完全一样的进程。用户执行该并行程序时,OS创建一个含单线程的进程执行代码;当线程执行到forkO调用时,OS复制进程,每个进程都启动一个从代码的同一位置幵始执行的线程,这两个进程中的线程继续执行,就像两个用户同时启动了该应用程序的两个副本。调用fork()函数的进程称为父进程,fork()函数新创建的进程称为子进程。虽然一个进程可以包含多个线程,但fork()函数新创建的进程均为单线程的;fork函数要向它的调用者返回一个值。返回给原来进程的值与返回给新创建进程的值是不同的。在新创建的进程里,fork返回零;在原来的进程里,for
6、k返回一个小的正整数来标识(pid)新创建的进程。#include{printf(“ThevalueofIis%d”,#includei);intsum;fflush(stdout)://在printf()后使用main(){fflush(stdout)的作用是立刻将要输山的内inti;容输出。sum=0;sum+=i;}fork();printf(“Thesumis%d”,sum);for(i=l;i<=5;i++)exit(0);}sthis.”);#include}intsum;else{main(){print
7、f(“Thenewprocessprintsthis.intpid;n”);pid=fork():}if(pid!=O)exit(0);{printf(“Theoriginalprocessprint1.接口的功能分配用于通信的本地资源;指定本地和远程通信端点;(客户端)启动连接;(客户端)发送数据报:(服务器端)等待连接到來;发送或接收数据;判断数据何吋到达;产生紧急数据;处理到达的紧急数据;从容终止连接;处理来自远程端点的连接终止;异常终止通信;处理
此文档下载收益归作者所有