ImageVerifierCode 换一换
格式:DOCX , 页数:13 ,大小:392.27KB ,
资源ID:3144540      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/3144540.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(实验二多线程应用程序设计.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

实验二多线程应用程序设计.docx

1、实验二多线程应用程序设计成绩信息与通信工程学院实验报告课程名称:嵌入式系统原理与应用实验题目:多线程应用程序设计 指导教师: 班级: 学号: 学生姓名: 一、 实验目的和任务1. 掌握VI编译环境。2. 掌握GCC编译命令。3. 掌握多个文件共同编译方法。4. 掌握GDB调试命令。5. 了解多线程程序设计的基本原理。6. 学习 pthread 库函数的使用。二、 实验设备7. 硬件:PC机8. 软件:LINUX操作系统、虚拟机三、 实验内容及原理1. 在VI编辑器里编写两个文件(其中一个为主程序,实现显示“hello,linux world,I am 1405014XXX XXX”,一个为子程

2、序,实现1n的乘法),为其书写头文件,共同编译为可执行文件,执行,观察运行结果。学习书写MAKEFILE文件,编译,执行,观察结果。利用GCC 编译(加参数-g)为可执行文件,利用GDB调试,学习GDB调试命令。2. 编写多线程程序设计。编译并运行,观察结果。(可参照课件或实验指导书)四、 实验步骤或程序流程1. Gcc编译实验1) 编写实验代码:图3.1实验主程序图3.2实验子程序2) 编写Makefile文件:图3.3 Makefile文件3) Make执行Makefile文件,生成可执行程序并运行:图3.4 执行4) Gdb调试运行:图3.5 gdb调试显示代码图3.6 gdb调试断点运

3、行图3.7 gdb调试逐步运行2. 多线程程序设计:1) 对实验代码进行gcc编译:图3.7gcc编译生成可执行文件2) 运行结果:图3.8程序运行结果五、 实验数据及程序代码1. Gcc编译实验:1) 主程序:#include stdio.h#include my2.hint main() printf(hello.Linux world.I am 1405014232 zzmn); my2();2) 实验子程序:#include my2.h#include stdio.hvoid my2() int i=1;float s=1 int N; printf(Please input n:n)

4、; scanf(%d,&N); for(i,i=n,i+) s*=i; printf(result:); printf(%f,s);3) .h头文件:#ifndef _MY2_H#define _MY2_Hint main();void my2();#endif 4) makefile执行文件:zzmgo: my2.o my1.o gcc -o zzmgo my2.o my1.o my1.o: my1.c my2.h gcc -c my1.c my2.o:my2.c my2.h gcc -c my2.c clean: rm -rf my1.o my2.o zzmgo1. 多线程程序设计:#in

5、clude #include #include #include pthread.h#define BUFFER_SIZE 16/* Circular buffer of integers. */struct prodcons int bufferBUFFER_SIZE; /* the actual data */ pthread_mutex_t lock; /* mutex ensuring exclusive access to buffer */ int readpos, writepos; /* positions for reading and writing */ pthread_

6、cond_t notempty; /* signaled when buffer is not empty */ pthread_cond_t notfull; /* signaled when buffer is not full */;/*-*/* Initialize a buffer */void init(struct prodcons * b) pthread_mutex_init(&b-lock, NULL); pthread_cond_init(&b-notempty, NULL); pthread_cond_init(&b-notfull, NULL); b-readpos

7、= 0; b-writepos = 0;/*-*/* Store an integer in the buffer */void put(struct prodcons * b, int data) pthread_mutex_lock(&b-lock); /* Wait until buffer is not full */ while (b-writepos + 1) % BUFFER_SIZE = b-readpos) printf(wait for not fulln); pthread_cond_wait(&b-notfull, &b-lock); /* Write the data

8、 and advance write pointer */ b-bufferb-writepos = data; b-writepos+; if (b-writepos = BUFFER_SIZE) b-writepos = 0; /* Signal that the buffer is now not empty */ pthread_cond_signal(&b-notempty); pthread_mutex_unlock(&b-lock);/*-*/* Read and remove an integer from the buffer */int get(struct prodcon

9、s * b) int data; pthread_mutex_lock(&b-lock); /* Wait until buffer is not empty */ while (b-writepos = b-readpos) printf(wait for not emptyn); pthread_cond_wait(&b-notempty, &b-lock); /* Read the data and advance read pointer */ data = b-bufferb-readpos; b-readpos+; if (b-readpos = BUFFER_SIZE) b-re

10、adpos = 0; /* Signal that the buffer is now not full */ pthread_cond_signal(&b-notfull); pthread_mutex_unlock(&b-lock); return data;/*-*/#define OVER (-1)struct prodcons buffer;/*-*/void * producer(void * data) int n; for (n = 0; n %dn, n); put(&buffer, n); put(&buffer, OVER); printf(producer stoppe

11、d!n); return NULL;/*-*/void * consumer(void * data) int d; while (1) d = get(&buffer); if (d = OVER ) break; printf( %d-getn, d); printf(consumer stopped!n); return NULL;/*-*/int main(void) pthread_t th_a, th_b; void * retval; init(&buffer); pthread_create(&th_a, NULL, producer, 0); pthread_create(&

12、th_b, NULL, consumer, 0); /* Wait until producer and consumer finish. */ pthread_join(th_a, &retval); pthread_join(th_b, &retval); return 0;六、 实验数据分析及处理1. 实验结构流程图:本实验为著名的生产者消费者问题模型的实现,主程序中分别启动生产者线程和消费者线程。生产者线程不断顺序地将 0 到 1000 的数字写入共享的循环缓冲区,同时消费者线程不断地从共享的循环缓冲区读取数据。流程图如图所示:图6.1 生产者-消费者实验源代码结构流程图2. 主要函数

13、分析:下面我们来看一下,生产者写入缓冲区和消费者从缓冲区读数的具体流程,生产者首先要获得互斥锁,并且判断写指针+1 后是否等于读指针,如果相等则进入等待状态,等候条件变量 notfull;如果不等则向缓冲区中写一个整数,并且设置条件变量为 notempty,最后释放互斥锁。消费者线程与生产者线程类似,这里就不再过多介绍了。流程图如下:图6.2 生产消费流程图3. 主要的多线程API:在本程序的代码中大量的使用了线程函数,如 pthread_cond_signal、pthread_mutex_init、pthread_mutex_lock 等等,这些函数的作用是什么,在哪里定义的,我们将在下面的内容中为其中比较重要的函数做一些详细的说明。1) pthread_create 线程创建函数:in

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1