您好,欢迎访问三七文档
当前位置:首页 > 电子/通信 > 综合/其它 > 专业课程设计I报告-B09040208
专业课程设计I报告(2011/2012学年第二学期)题目1:进程的同步与互斥题目2:计算机图形动画专业计算机科学与技术学生姓名黄金花班级学号B09040208指导教师黄海平指导单位计算机学院日期2012.4.16-4.26指导教师成绩评定表学生姓名班级学号专业计算机科学与技术评分内容评分标准优秀良好中等差平时成绩认真对待课程设计,遵守实验室规定,上机不迟到早退,不做和设计无关的事√设计成果设计的科学、合理性功能丰富、符合题目要求界面友好、外观漂亮、大方程序功能执行的正确性程序算法执行的效能设计报告设计报告正确合理、反映系统设计流程文档内容详实程度文档格式规范、排版美观验收答辩简练、准确阐述设计内容,能准确有条理回答各种问题,系统演示顺利。评分等级指导教师简短评语该同学出勤率(满勤、较高、一般,较低),学习态度(端正、较端正、一般、较差),演示程序(未)达到了(基本要求、提高要求1或/和2),撰写报告格式(规范、一般)、表述(清晰、一般、不清楚),圆满(较好、基本)完成了课题任务。(可选:尚存在……缺陷。)指导教师签名日期2012-4-30备注评分等级有五种:优秀、良好、中等、及格、不及格教师对学生的项目评分——进程的同步与互斥一、课题内容和要求1、课题内容题目:教师对学生的项目评分——进程的同步与互斥内容:在一个班上有S个学生。每个学生都要做一个项目,每一个项目由K个老师一起评分。总共有M个老师。每个老师最多给N个项目评分。其中,S*K=M*N。在项目结束后,老师们提供T分钟用来检查学生们的项目。检查每一个学生的项目需要用时D分钟。其中,TD。每一个学生的项目由K个老师共同来检查。在T分钟的时间段内,学生可以在任何时间进入教室(random),除了在最后的D分钟内。所有的老师一直保持工作状态直到他检查完N个项目或者是T分钟过去后。T分钟过去后,所有的老师和同学都必须离开教室。另外,在T分钟结束前的D分钟内(即在最后的D分钟内),如果有任何老师或者是学生都处在没有任务的状态下,都必须离开教室,因为已经没有时间让他完成任务了(因为一个项目检查的时间是整整D分钟)。具体过程:当一个学生进入教室后,他立即开始找K个没有任务的老师(一次找一个老师,假如没有空闲的老师,则等到有老师为止),找齐K个老师之后给老师检查,然后离开教室。刚开始每一个老师都是处于空闲状态直到他被学生找到,被学生找到后只能等待,直到学生找齐K个老师(在等待学生找其他老师的时间里,他是不能接受其他同学检查作业的请求的),当学生找齐K个老师后,老师们执行完检查任务,然后重新变成空闲状态。每个老师在总共检查了N个学生的作业后,离开教室。2.课程要求用一个程序来模拟上面描述的作业检查过程。每一个学生和每一个老师应该用不同的线程来完成。可以选用C、C++和Java作为开发语言,但是考虑到专业课程设计I的实验大纲,请尽可能使用Java语言。提高要求:(1)考虑到跨平台的特性,请尽量使用posix线程标准(采用该标准有额外的加分);(2)实现良好的图形用户界面;(3)在程序演示过程中能清晰的展示多个学生线程和多个老师线程的同步和互斥流程。二、需求和思路分析该课题主要考察操作系统中PV操作知识点,涉及到多进程管理和死锁的相关知识。1.为了实现老师与学生能协调进行下去,可以采用多线程,这里可以使用三种线程:总线程,老师线程,学生线程。(1).总线程:主线程作为主类,实现对老师线程和学生线程的调用产生老师线程,并激活;产生随机数来定义每个学生进入的时间;产生学生线程;并按上面产生的时间激活;时间结束,程序结束;(2).老师线程:(0)老师进入教室;(1)在教室中空闲;(2)直到被一个学生选择后等待(所有K个老师聚集);(3)等待结束项目检查开始;(4)做D分钟的项目检查;(5)N次检查完毕或者T分钟时间到,离开教室。否则回到(1)(3).学生线程:(0)进入教室(1)选择一个进入的时间(random()%(T-D))minutes;(2)进入教室;(3)选择K个空闲的老师,若找不齐,则等待;(4)找齐后,做D分钟的检查;(5)检查完毕离开教室。2.在此题目要求中涉及PV操作的有学生选择老师阶段,在学生选择老师时刻,可能出现学生甲,学生乙同时发现有K个老师,于是每个人占有了一部分但又不够,且不放开资源,造成死锁的现象,对于这一问题可以设定,只要有一个学生在选择老师时,其他的学生都不可以选,一个人选完了,另外一个人才可以再选,这样就避免了死锁的发生;还有一个同步和互斥的问题,教室每次只可以进去或出来一个人,即学生、老师不可以同时进入教室,离开教室。这可以通过相关修饰符来解决;以上两个问题皆可以用修饰符synchronized来解决。如果线程进入,则得到对象锁,那么别的线程在该类所有对象上的任何操作都不能进行。3.注意事项(1)在剩余时间小于D时,一个已创建的学生线程只能执行第(5)步,不能再创建新的学生线程;(2)在剩余时间小于D时,一个老师进程只能在执行(3)—(4)步或者直接执行第(5)步;(3)对于所有合理的S,M,K,N,T,D数值(这些数必须都是正整数并且满足条件:S*K=M*NandTD),你的程序都能够运行成功;(4)你的程序对所有的时间安排策略都必须运行成功。例如不管线程的相对速度,例如要把握好sleep的毫秒数;(5)在每一个线程的生命周期内,每一步都要有一个合理的说明信息,来表明这个线程中包括哪个老师,哪个学生,进行到什么程度了;(6)要特别注意防范死锁问题的发生。三、概要设计1.主类通过人机对话获得所需要的学生人数S,老师人数M,学生需要接受检查的老师数K,老师最多检查学生数N,学生接受检查所需时间D,总时间T。创建获取时间函数,进入,离开公共函数,供学生线程和老师线程使用,调用随机函数产生学生线程产生的时间,接着产生老师线程,等老师线程全部产生,一旦学生线程产生时间一到立即产生学生线程,等待时间T到,结束所有未结束的学生和老师线程,退出程序。流程图如下:2、老师线程在教师线程中,老师进入和离开教室时利用修饰符synchronized来解决同步与互斥的问题;在进入的函数声明为:publicstaticsynchronizedvoidcomein(),离开的函数声明为publicstaticsynchronizedvoidcomein(),在synchronized的修饰下,每次只能有一个线程调用comein和leave函数,且这两个函数是在主类中声明的,故老师与老师,学生与学生,老师与同学都不会同时进入或离开。教师线程中,老师先进来并告知用户老师已经进入,刚开始时,进来一个staticintbusy[];//0表示闲1表示忙staticintcount[];//老师已经检查的个数staticintTnum;//教室中空闲老师的个数staticintS=1,M=2,K=1,N=2,D=1,T=2,p;staticlongstart;staticObjectoo=newObject();//用于锁staticintr[];publicstaticintgettime();publicstaticsynchronizedvoidcomein();publicstaticsynchronizedvoidleave();教师,教室中的空闲教师就增加一个,老师进来后,程序先判断该教室检查的学生数够N没,时间已经不够了。若两者有一个满足则老师要离开教室并告知用户,教室中空闲的教室少一个,且要把改离开的教室的状态设为忙,因为学生并不知道老师的编号,通过随机数找老师时,仍可能找到该老师,故只能通过设“忙”使该老师不可用才行。告知用户老师离开时,通过对比老师离开的原因,输出不同的信息;如果不满足条件,则通过while语句让老师处在等待之中;等待学生请老师来检查;流程图如下:2、学生进程在学生线程中,进入之前先判断现在进去时间够不够检查,如果不够,学生则不进入,离开,输出离开信息。如果够,学生。进入,并向用户打印进入信息。学生进入后就开始看有没有K个空闲的老师,且时间够不够,如果时间够,但老师不足,则通过while语句一直等待;如果等待中时间不够了(不管空闲老师足够了没有),则直接离开,输出离开信息;如果在有效时间内等到了K个老师则开始选择老师;一个学生选择老师时,不允许他人选择,且一开始就将空闲教师数减K,老师编号是通过随机数产生的,随机产生一个老师,看他忙不忙,如果忙则再随机找,如果不忙,则将老师编号存起来,将老师的状态改为忙;找到K个空闲老师后,通过sleep函数来表示检查D这么长的时间。检查完毕后,输出检查完毕信息,学生释放老师,将选择的老师的状态改为空闲,老师空闲数加依次增加,每个老师的检查次数增加1,(此时判断时间够不够,老师是否已近检查了N个人,如果不够或已经检查够N个人,则让老师离开,状态改为忙空闲老师相应减少。若不是,则继续等待;)学生离开,输出离开信息;流程图:四、详细设计源程序代码如下:/**Tochangethistemplate,chooseTools|Templates*andopenthetemplateintheeditor.*/package教师对学生项目评分;importjava.util.*;importjava.util.Scanner;publicclassjob{staticintbusy[];//老师忙,0表示闲,1表示忙staticintcount[];//老师已经检查的个数staticintTnum;//教室中空闲老师的个数staticintS=1,M=2,K=1,N=2,D,T,p;staticlongstart;staticintr[];publicstaticintgettime(){doubleduration;longfinish=System.currentTimeMillis();duration=(double)(finish-start);return(int)duration;}publicstaticvoidmain(Stringargs[]){do{if(S*KM*N||S0||K0||M0||N0)System.out.println(Wronginput!!!);System.out.println(请输入学生个数S:);Scannerinput=newScanner(System.in);S=input.nextInt();System.out.println(请输入老师个数M:);M=input.nextInt();System.out.println(请输入检查每个项目需要的老师数K:);K=input.nextInt();System.out.println(请输入每个老师可以检查的项目数N:);N=input.nextInt();System.out.println(请输入总时间T:);T=input.nextInt();System.out.println(请输入检查每个项目所需时间D:);D=input.nextInt();}while(S*KM*N||S0||K0||M0||N0);busy=newint[M];count=newint[M];Tnum=0;r=newint[S];for(inti=0;iM;i++){busy[i]=0;count[i]=0;}Teachertea[]=newTeacher[M];for(intk=0;kM;k++){tea[k]=newTeacher(k);}Studentstu[]=newStudent[S];for(intk=0;kS;k++){stu[k]=newStudent(k);}System.out.println(time:);for(inti=0;iS;i++)//产生随机时间,保存于r数组中{r[i]=(int)((double)Math.random()*T);System.out.pr
本文标题:专业课程设计I报告-B09040208
链接地址:https://www.777doc.com/doc-4777877 .html