2017-2018-1 20155229 实验三 实时系统
实验目的
- 了解实时系统的信息、特点等内容。
- 学习客户端和服务器之间的工作原理,并编写代码实现。
实验步骤
实验三-并发程序-1
- 学习使用Linux命令wc(1)
- 基于Linux Socket程序设计实现wc(1)服务器(端口号是你学号的后6位)和客户端
- 客户端传一个文本文件给服务器
- 服务器返加文本文件中的单词数
wc命令的功能:
统计指定文件中的字节数、字数、行数,并将统计结果显示输出。该命令统计指定文件中的字节数、字数、行数。如果没有给出文件名,则从标准输入读取。wc同时也给出所指定文件的总统计数。
wc命令的参数
- -c 统计字节数。
- -l 统计行数。
- -m 统计字符数。这个标志不能与-c 标志一起使用。
- -w统计字数。一个字被定义为由空白、跳格或换行字符分隔的字符串。
- -L 打印最长行的长度。
wc命令只打印统计数字不打印文件名
cat *.txt |wc
用来统计当前目录下的文件数
ls -l | wc -l
步骤
①对服务器和客户端的代码分别进行编译:
gcc -o server seerver.c
gcc -o client client.c
②(一个终端中)运行服务器 (注意端口号)
sudo ./server 155229
③(另一个终端)运行客户端,根据提示接收文件
./client
④查看文件是否传送成功
实验三-并发程序-2
- 使用多线程实现wc服务器并使用同步互斥机制保证计数正确
- 对比单线程版本的性能,并分析原因
多线程
每个线程独立地完成相关的功能,任何一个线程执行成功与否对另外两个线程都没有影响
多线程的优点:
- 第一,将原来在一个大流程中实现的功能放到了多个小流程中,程序更加的简洁和易于阅读。
- 第二,将不同的功能放到不同的线程中,提高了程序的执行效率。
- 第三,“多线程”使得程序的模块化更强,有利于追踪程序执行过程和排查问题。
pthread并非Linux系统的默认库,而要在Linux中将其作为一个库来使用,就需要加上“-lpthread”或“-pthread”以显式链接该库。
通过 pthread_create()函数创建新线程。
#includeint pthread_create(pthread_t *restrict tidp, const pthread_attr_t *restrict attr, void *(*start_rtn)(void *), void *restrict arg);
pthread_join
等待一个进程
实验三-并发程序-3(未完成)
- 交叉编译多线程版本服务器并部署到实验箱中
- PC机作客户端测试wc服务器
实验中的问题及解决过程
无
学到的知识
通过本次实验,对单线程和多线程有了进一步的了解和学习,对pthread也有了进一步的使用。通过编程也更深入学习了服务器与客户端。使用man命令查询命令也很顺手。