操作系统生产者消费者问题实验报告
更新时间:2024-02-28 00:58:01 阅读量: 综合文库 文档下载
实验名称:
一、生产者-消费者问题的多线程解决方案 二、设计一个执行矩阵乘法的多线程程序
日期:2015-10-22 班级:13级计科 学号: 姓名:
一、 实验目的
1.掌握线程的同步与互斥
2.掌握生产者消费者的实现问题 3.掌握多线程的编程方法
4.掌握矩阵乘法的基本计算原理以及实现
实验报告二
二、 实验内容
1.生产者-消费者问题的多线程解决方案
2.设计一个执行矩阵乘法的多线程程序
三、 项目要求与分析
1.请查阅资料,掌握线程创建的相关知识以及矩阵乘法的相关知识,了解java语言
程序编写的相关知识 2.理解线程的实验步骤 在本次试验中,以“生产者-消费者”模型为依据,提供了一个多线程的“生产者-消费者”实例,编写java代码调试运行结果,得出相应的结论。 理解矩阵乘法的实验步骤
四、 具体实现
1. 生产者-消费者实例
(1) 创建一个缓冲信息发送接收通道接口,并创建邮箱盒子类实现,主要代码如下:
//通道接口
public interface Channel {
public abstract void send(Object item); public abstract Object receive(); }
//实现接口
public class MessageQueue implements Channel {
private Vector queue; public MessageQueue() {
queue=new Vector(); }
public void send(Object item) {
queue.addElement(item); }
public Object receive() {
if(queue.size()==0) return null; else
return queue.remove(0); } }
(2) 创建一个工厂多线程类(启动生产者和消费者),并且添加main函数进行测试,主
要代码如下:
//工厂类与主方法
public class Factory {
public Factory() {
Channel mailBox=new MessageQueue();
Thread producerThread=new Thread(new Producer(mailBox)); Thread consumerThread=new Thread(new Consumer(mailBox)); producerThread.start(); consumerThread.start(); }
public static void main(String[] args) {
Factory server=new Factory(); } (3) 创建一个线程睡眠类,用于测试,主要代码如下:
public class SleepUtilities {
public static void nap() {
nap(NAP_TIME); }
public static void nap(int duration) {
int sleeptime = (int)(NAP_TIME * Math.random()); try
{ Thread.sleep(sleeptime*1000); } catch (InterruptedException e) {} }
private static final int NAP_TIME = 5; (4) 创建生产者类实现Runnable,主要代码如下:
public class Producer implements Runnable {
private Channel mbox;
public Producer(Channel mbox) {
this.mbox=mbox; }
public void run() {
Date message; while(true) {
SleepUtilities.nap(); message=new Date();
System.out.println(\+message); mbox.send(message); } } }
(5) 创建消费者类实现Runnable,主要代码如下:
public class Consumer implements Runnable {
private Channel mbox;
public Consumer(Channel mbox) {
this.mbox=mbox; }
public void run() {
Date message;
while(true) {
SleepUtilities.nap();
message=(Date)mbox.receive();
if(message!=null)
System.out.println(\+message); } }
} (6) 调试程序,运行结果:
2. 矩阵乘法实例
(1) 初始化矩阵(便于观察,这里使用随机数生成矩阵),主要初始化代码如下
matrix1 = new int[m][k];
matrix2 = new int[k][n]; matrix3 = new int[m][n];
//随机初始化矩阵a,b fillRandom(matrix1);
fillRandom(matrix2);
static void fillRandom(int[][] x)
{
for (int i=0; i for(int j=0; j //每个元素设置为0到99的随机自然数 x[i][j] = (int) (Math.random() * 100); } } } (2) 打印输出矩阵函数,主要代码如下: static void printMatrix(int[][] x) { for (int i=0; i for(int j=0; j System.out.print(x[i][j]+\); } System.out.println(\); } System.out.println(\); } (3) 创建多线程类,并实现Runnable接口同步对矩阵进行分行计算,主要代码如下: //创建线程,数量 <= 4 for(int i=0; i<4; i++) { if(index < m) { Thread t = new Thread(new MyThread()); t.start(); }else { break; } synchronized static int getTask() { if(index < m) { return index++; } return -1; } } class MyThread implements Runnable { int task; //@Override public void run() { MultiThreadMatrix.threadCount++; while( (task = MultiThreadMatrix.getTask()) != -1 ) { System.out.println(\进程: \+Thread.currentThread().getName()+\开始计算第 \+(task+1)+\行\); for(int i=0; i for(int j=0; j MultiThreadMatrix.matrix3[task][i] += MultiThreadMatrix.matrix1[task][j] * MultiThreadMatrix.matrix2[j][i]; } } } MultiThreadMatrix.threadCount--; } (4) 通过不断改变矩阵大小,线程数目,,调试程序,运行结果: 五、 所遇问题与解决方法 1. 在生产者-消费者多线程试验中,刚开始没有考虑到使用线程睡眠,运行结果速度之快, 没法观看数据变化,后面定义了睡眠控制,使得问题得以解决 2. 在多线程矩阵开发实验中,刚开始定义矩阵太小,测试结果不太明显,后面通过把矩阵 改大,并且线程数目不断变化使得结果明显。 六、 实验总结 深刻了解了生产者消费者多线程,进一步理解了“生产者-消费者”模型。同时也 掌握了一些java编程语言相关知识。多线程矩阵实验中,发现矩阵小时,线程越少,运行时间越长;而矩阵过大时,线程数量与运行时间成反比。
正在阅读:
操作系统生产者消费者问题实验报告02-28
应用写作试题203-08
OHSAS18002 职业安全卫生管理体系实施指南04-20
汽车营销学讲义-第1章-汽车市场营销概述08-05
包装印刷企业市场营销策略现状及改进 - 以A企业为例的分析-毕业论文10-16
给老师画像作文600字06-24
语文教学中的导入语01-25
2019年暑假的一件趣事作文06-14
纸介电容器项目可行性研究报告10-25
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 生产者
- 操作系统
- 消费者
- 实验
- 报告
- 问题
- 新北师大版一年级数学上册教材分析报告
- 苏教版二上生字表
- 高中物理必修2知识点总结
- 北师大版语文五年级下册表格式教案
- 2013--2014新人教版八年级数学上期末测试题带详细讲解(超经典)
- 中考数学创新题集锦(含答案)
- 高中物理解题模型详解
- 高一物理必修一复习提纲
- 新目标八年级英语上册复习提纲(全套)
- 使用ping命令自测网络故障
- 国际经济学习题与答案2 2011.1.8
- 分析新课程背景下数学教学的几个“转变”
- 投标文件
- COMPASS使用手册,兰德马克说明书
- 手把手教你电视上网 网络电视功能攻略
- (小学教育)2019二年级语文下册识字3贝的故事当堂达标题新人教
- windows汇总
- 高级英语课文译文(上,下册)(自考)
- 六年级上学期小学语文考点复习测试期末真题模拟试卷(16套试卷)
- 汽轮发电机组施工组织设计