2017-2018-1 20155229 实验三 实时系统

2017-2018-1 20155229 实验三 实时系统

实验目的

  • 了解实时系统的信息、特点等内容。
  • 学习客户端和服务器之间的工作原理,并编写代码实现。

实验步骤

实验三-并发程序-1

  • 学习使用Linux命令wc(1)
  • 基于Linux Socket程序设计实现wc(1)服务器(端口号是你学号的后6位)和客户端
  • 客户端传一个文本文件给服务器
  • 服务器返加文本文件中的单词数

wc命令的功能:

统计指定文件中的字节数、字数、行数,并将统计结果显示输出。该命令统计指定文件中的字节数、字数、行数。如果没有给出文件名,则从标准输入读取。wc同时也给出所指定文件的总统计数。

wc命令的参数
  • -c 统计字节数。
  • -l 统计行数。
  • -m 统计字符数。这个标志不能与-c 标志一起使用。
  • -w统计字数。一个字被定义为由空白、跳格或换行字符分隔的字符串。
  • -L 打印最长行的长度。


386 1525 12288 test.txt
行数 单词数 字节数 文件名

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()函数创建新线程。

#include <pthread.h>
int 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命令查询命令也很顺手。

posted @ 2017-11-18 12:16  Fer_佳  阅读(214)  评论(0编辑  收藏  举报