• 阶段3-团队合作项目-网络安全传输系统sprint2-线程池技术优化


    之前问题的存在,之前只是用一个客户端在与服务器进行连接,当多个客户端进行连接的时候会连接不上处于等待状态,说明以前我们的服务器只能同时处理一个请求,故需要修改

    服务器:

    单发:初始化--等待客户端连接--处理--关闭这次连接,再次等待下一次连接,它只能处理一个客户端的请求。

    并发

    初始化--等待连接--在这里处理它不会是主进程进行处理,而是交给子进程或线程进行处理,主进程又快速得等待下一次连接了。

    可以同时处理多个客户请求了,我们一般都会去创建线程来处理。

    我么可以利用线程池,在它里面已经创建好了一定数量的线程,如果要用直接从里面去获取,用完之后直接回收回来,而不需要每次有一个请求就去创建然后用完之后就删除这些附加的操作,

    线程池使用实例

    上面是有3个线程的线程池供10个任务来使用

    编译的时候一定要带上-lpthread

    首先是怎么创建线程池,然后怎么使用线程池

    创建线程池

    使用函数pthread_create (&(pool->threadid[i]), NULL, thread_routine, NULL)来创建线程。

    往线程池中添加任务

    销毁线程池

    下面利用上面的线程池代码来优化之前的server.c程序

    一个线程要去完成一项任务,那么首先找到我们的任务在哪里

    。。。。。。看代码

    server.c

    client.c

  • 相关阅读:
    python基础4
    python的基础数据类型和编码
    python的if语句和while循环
    java特殊运算符
    深入理解java集合
    python常用模块
    python函数的参数问题
    集合关系之间的运算
    集合
    可变类型与不可变类型
  • 原文地址:https://www.cnblogs.com/gary-guo/p/6033212.html
Copyright © 2020-2023  润新知