java线程池线程实验报告.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
java线程池线程实验报告

实验名称 Java编程基础(课外部分) 姓 名_汪何媛_______ 学号__100341324_____ 实验日期 2012 年 11 月 1 日 实验报告日期 2012年11月 11 日 成 绩 ___________________ 实验目的 理解并掌握Java中借口的基本概念和具体应用; 熟悉掌握Java中线程的定义和基本操作; 理解线程池的概念,以及常用的线程调度方法。 实验环境 准备SNU的IDK6安装文件; Java程序开发软件一套---MyEclipse6.0 实验实际完成内容及结果分析 1、 请上机调试并运行下面的程序,给出程序的运行结果,并回答以下问题: (1) 本程序执行时共创建了多少线程,每个线程的任务什么,分别是如何 执行的? (2) 根据程序的运行结果说明 Thread.yield();这条语句对线程调度的 影响。 public class myThreadClass extends Thread{ volatile static boolean Stop=false; public static void main(String args[])throws InterruptedException{ myThreadClass thread1=new myThreadClass(); thread1.setPriority(4);//设置优先级 myThreadClass thread2=new myThreadClass();//定义线程 thread2.setPriority(4); thread1.start(); thread2.start();//执行线程 Thread.sleep(5*1000);//调用sleep方法 Stop=true; } public void run(){ System.out.println(Thread.currentThread()+Created); int count=0; for(;Stop!=true;){ count++; Thread.yield(); System.out.println(Thread.currentThread()+Thread terminates.Loop count is+count); } } } 运行结果: 2、 请上机调试并运行本章例题中的线程池程序,给出程序的运行结果,并回答 以下问题: (1) 本例中是如何定义池(pool)的(采用了什么样的数据结构类),池的 作用是什么,对池的操作有哪些,分别是如何实现的。 (2) 本例中线程池中共定义了多少个线程,这些线程是如何调度执行的, 使用了哪些线程调度的方法。 (3)如果将该线程池的任务改为计算给定文件夹下所有文件的摘要信息,应 该如何修改源程序。public class ThreadPoolTester { public static void main(String[] args){ if(args.length!=2){ System.out.println(用法:java ThreadPoolTest numTasks poolSize); System.out.println(numTasks integer:任务的数目); System.out.println(numThreads integer:线程池中的线程数目); return; } int numTasks=Integer.parseInt(args[0]); int poolSize=Integer.parseInt(args[1]); ThreadPool threadPool=new ThreadPool(poolSize); for(int i=0;inumTasks;i++) threadPool.execute(createTask(i)); threadPool.join(); } private static Runnable createTask(final int taskID){ return new Runnable(){ public void run() { System.out.println(Task+taskID+:start); try{ Thread.sleep(500); }catch (InterruptedExceptio

文档评论(0)

shenlan118 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档