- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
大作业一 Linux信号量机制 姓名 学号: 班级: 日期 1 需求说明 目标: 本次实验的目标是在Linux环境下实现一个多线程对临界资源的互斥操作,利用信号量实现对临界资源的保护,支持Linux下文件输入输出,提高对Linux环境下多进程、多线程、信号量机制和文件操作等知识的理解。 2 设计说明 有进程A、B、C,分别调用过程get、copy、put对缓冲区S和T进行操作。其中get负责从文件F_in中把数据块读入并输出缓冲区S,copy负责从S中提取数据块并复制到缓冲区T中,put负责从缓冲区T中取出信息存入到本地文件F_out中。实现get、copy、put的操作过程。 2.1 结构设计 三个信号量实现线程互斥 sem_tread_sem; // read sem_twrite_sem; // write sem_tcopy_sem; // copy 2.2 功能设计 实现了同步多线程运行,文件读入,缓冲区COPY,文件写入三个线程同时运行,完成LINUX下文件的输入输出。 文件读入:用linux下open(),read(),lseek()函数实现 文件写出:用linux下open(),write()实现 缓冲区建立 malloc()函数 信号量建立sem_init(),sem_wait(),sem_post() 互斥量建立pthread_create(),pthread_mutex_lock(),pthread_mutex_unlock() 3 测试和使用说明 3.1 使用说明 使用./signalmove启动程序,启动参数必须包括,写入文件名,写出的文件名,和缓冲区大小,否则会报错退出。 缓冲区大小必须为数字,否则退出。 3.2 测试说明 4 程序清单 [cpp] view plaincopy OBJS=main.o copy.o get.o put.o file.o signalmove:$(OBJS) signalmove.h gcc $(OBJS) -o signalmove -lpthread main.o:main.c signalmove.h gcc -c main.c -lpthread copy.o:copy.c signalmove.h gcc -c copy.c get.o:get.c signalmove.h gcc -c get.c put.o:put.c signalmove.h gcc -c put.c file.o:file.c signalmove.h gcc -c file.c /* * signalmove.h * * Created on: May 14, 2012 * Author: dell */ #ifndef SIGNALMOVE_H_ #define SIGNALMOVE_H_ #include stdio.h #include stdlib.h #include unistd.h #include pthread.h #include semaphore.h #include signal.h #include fcntl.h #include string.h #include ctype.h //file works void file_in(); void file_out(); //copy from s to t void copy(); //put and get void put(); void get(); sem_t read_sem; // read sem_t write_sem; // write sem_t copy_sem; // copy pthread_mutex_t read_mutex; // pthread mutex for read pthread_mutex_t write_mutex; // pthread mutex for write char *data_s; //read buffer char *data_t; //write buffer int len; //buffer length char *filename_out; //name_out char *filename_in; //name_in int result; int result_copy; #endif /* SIGNAL
文档评论(0)