码迷,mamicode.com
首页 > 编程语言 > 详细

C/C++网络编程6——实现基于UDP的服务器端/客户端

时间:2019-10-22 00:47:23      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:客户端   管理   无法   多个   turn   alt   内存   space   fork   

  通过前面几节的内容,我们已经可以实现基本的C/S结构的程序了,但是当多个客户端同时向服务器端请求服务时,服务器端只能按顺序一个一个的服务,这种情况下,客户端的用户是无法忍受的。所以虚实现并发的服务器端。

并发服务器端的实现方法:

  1:多进程服务器端:通过创建多个进程提供服务。

  2:多路复用服务器:用过捆绑并统一管理I/O对象提供服务。

  3:多线程服务器:通过生成与客户端等量的线程提供服务。

 

多进程服务器端:

  进程:可执行程序的一次执行过程。

  在linux下可通过fork()函数创建一个进程。

#include <unistd.h>

pid_t fork(void)
// 成功返回时父进程返回子进程的id,子进程返回0,失败时返回-1

  通过fork()函数创建进程以后,父进程和子进程拥有完全独立的内存空间。举例:

#include <iostream>
#include <unistd.h>

using namespace std;

int g_count = 10;

int main()
{
    int l_count = 20;
    g_count++;
    l_count++;

    pid_t pid = fork();

    if (pid < 0) {
        cout << "fork() failed" << endl;
        return 0;
    }

    if (pid == 0) {
        g_count += 5;
        l_count += 5;
    } else {
        g_count -= 5;
        l_count -= 5;
    }

    if (pid == 0) {
        cout << "child: " << g_count <<" " << l_count << endl;
    } else {
        cout << "parent: " << g_count <<" " << l_count << endl;
    }

    return 0;
}

技术图片

 

C/C++网络编程6——实现基于UDP的服务器端/客户端

标签:客户端   管理   无法   多个   turn   alt   内存   space   fork   

原文地址:https://www.cnblogs.com/418ks/p/11717105.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!