2018-2019-1 20165334《信息安全系统设计基础》实验三 并发程序
实验三-并发程序-1
任务详情
- 学习使用Linux命令wc(1)
- 基于Linux Socket程序设计实现wc(1)服务器(端口号是你学号的后6位)和客户端
- 客户端传一个文本文件给服务器
- 服务器返加文本文件中的单词数
- 上方提交代码
- 附件提交测试截图,至少要测试附件中的两个文件
学习使用Linux命令wc(1)
基于Linux Socket程序设计实现wc(1)服务器(端口号是你学号的后6位)和客户端
实验三-并发程序-2
任务详情
使用多线程实现wc服务器并使用同步互斥机制保证计数正确
上方提交代码
下方提交测试
对比单线程版本的性能,并分析原因
对比单线程版本的性能,并分析原因
- 从吞吐量上来说,多线程远远大于单线程,从性能上来说,多线程也是远远优于单线程
- 线程本身由于创建和切换的开销,采用多线程不会提高程序的执行速度,反而会降低速度,但是对于频繁IO操作的程序,多线程可以有效的并发。
对于包含不同任务的程序,可以考虑每个任务使用一个线程。这样的程序在设计上相对于单线程做所有事的程序来说,更为清晰明了,比如生产、消费者问题。 - 在实际的开发中对于性能优化的问题需要考虑到具体的场景来考虑是否使用多线程技术。
代码链接
实验中遇到的问题
- 由于pthread库不是Linux系统默认的库,连接时需要使用库libpthread.a,所以在使用pthread_create创建线程时,在编译中要加-lpthread参数:
- gcc -o pthread -lpthread pthread.c