黑马程序员技术交流社区
标题:
线程执行时间固定
[打印本页]
作者:
罗玉宁
时间:
2013-4-8 09:21
标题:
线程执行时间固定
本帖最后由 罗玉宁 于 2013-4-11 12:43 编辑
想一个线程就是执行一秒钟,一秒钟后结束。我是这么想的谁有更好的方法请告诉我。
class TimerTest
{
public static void main(String[] args) throws Exception
{
Test t = new Test();
t.setDaemon(true);
t.start();
Thread.sleep(1000);
}
}
class Test extends Thread
{
public void run()
{
while(true)
{
System.out.println("xxxxx");
}
}
}
复制代码
作者:
刘渝灵
时间:
2013-4-8 10:29
此程序的意思是,创建一个线程并设为 守护线程,这个线程和主线程同时运行,如果运行到主线程,主线程睡眠1秒,醒来后只剩下之前的那个守护线程,程序结束。是这个意思吗? 但是这样控制,时间好像不精确?如果先执行了创建的线程一会才执行主线程,这超出1秒了吧?
作者:
罗玉宁
时间:
2013-4-8 10:49
I know 寻求更好
作者:
我手心里的宝
时间:
2013-4-8 11:05
线程池的概念与Executors类的应用
首先介绍在TCP服务器编程模型的原理,当一个客户端连接到服务器,服务器要起一个线程为之服,当客户端的回话结束时,线程也就结束了,即每一个客户端连接,服务器 就要为之创建一个新的线程,这好比假设每个报名学员都要通过我来亲自接 待,以便给每个学员一种好的感觉,但每个学员报名手续花费半个小时,对于 50名学生,我一个个接待和为之办手续,显然是不实际的,那么我会怎么做呢
?我会先接待每个学员,打完招呼后,再把他分配给一名工作人员去办理手续 ,这样我就接待了每一名学员.
如果访问服务器的客户端很多,那么服务器要不断的创建和销毁线程, 这样将严重影响服务器的性能,如果真的来一名学员,我们就安排一名新的 工作人员为之服务,这也是不可能的,那么公司岂不是要招很多工作人员.
应该是一名工作人员服务完一名学员,空闲下来后,一旦有新的学员要服务,
我们安排该工作人员,为之服务.
线程池的概念于此类似,首先创建一些线程,他们的集合称为线程池,
当服务器接收到一个客户请求后,就从线程池中取出一个空闲的线程为之服
务,服务完成后不关闭该线程,而是将该线程还回到线程池中.
在线程池的编程模式下,任务是交给整个线程池,而不是直接交给某个线
程,线程池拿到任务偶,他就在内部找有空闲的线程,再把任务交给内部某个
空闲的线程,这就是封装.记住,任务是交给整个线程池,但可以同时向一个线程池中提交多个任务.
创建固定大小的线程池:
ExecutorService threadPool = Executors.newFixedThreadPool(3);
threadPool.execute(Runnable runnable);
创建缓存的线程池:
如果线程不够自动创建新的线程满足服务
ExecutorService threadPool = Executors.newCachedThreadPool();
threadPool.execute(Runnable runnable);
创建单一线程池.
线程里面只有一个线程,如果该线程意外死亡,那么系统会自动创建一个新的线程来代替.
ExecutorService threadPool = Executors.newSingleThreadExecutor();
threadPool.execute(Runnable runnable);
//执行完任务后关闭线程池,
threadPool.shutdown();
//不管任务是否完成都关闭线程池
threadPool.shutdownNow();
用线程池启动定时器.
Executors.newScheduledThreadPool(3).schedule(new Runnable(){
@Override
publicvoid run() {
}
}, 20, TimeUnit.SECONDS);
线程池的概念,看看吧,张老师7k面试有讲到,但不详细,在这里,总结分享一下
作者:
何衍其
时间:
2013-4-8 22:50
本帖最后由 何衍其 于 2013-4-8 22:51 编辑
你看如下的示例代码能达到你的要求不
public Object waitCallComplete() throws InterruptedException, ExecutionException, TimeoutException{
// 新建一个线程池
ExecutorService executorService = Executors.newCachedThreadPool();
Callable<Object> callable = new Callable<Object>(){
public Object call() throws Exception {
// 这里可以替换为从数据库中取数据,或其它的计算
Object obj = new Object();
return obj;
}
};
// 执行任务
Future<Object> future = executorService.submit(callable);
// future.get方法将阻塞并等待一秒,如果一秒后没有返回,则抛出异常
Object returnObj = future.get(1, TimeUnit.SECONDS);
return returnObj;
}
复制代码
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2