转自:http://www.cnblogs.com/skywang12345/p/3544116.html概要本章介绍线程池中的Callable和Future。Callable 和 Future 简介示例和源码分析(基于JDK1.7.0_40)转载请注明出处:http://www.cnblogs.com/skywang12345/p/3544116.html Callable 和 Future 简介 Callable 和 Future 是比较有趣的一对组合。当我们需要获取线程的执行结果时,就需要用到它们。Callable用于产生结果,Future用于获取结果。1. CallableCallable 是一个...
任务说明:生产者(Productor)将产品交给店员(Clerk),而消费者(Customer)从店员处取走产品,店员一次只能持有固定数量的产品(比如:20),如果生产者试图生产更多的产品,店员会叫生产者停一下,如果店中有空位放产品了再通知生产者继续生产;如果店中没有产品了,店员会告诉消费者等一下,如果店中有产品了再通知消费者来取走产品。使用Runnable接口完成该任务,代码如下:package testThread;/*共享数据*/
class Clerk{int produc...
本文记录使用ScheduledExecutorService的 scheduleAtFixedRate 方法执行周期性任务的过程。 一,正常任务执行负责执行任务的线程类如下:(一个计算阶乘的任务,计算5以上的阶乘,就会抛出异常) 1publicclass FactorialCalc implements Runnable {2 3private Integer number;4 5public FactorialCalc(Integer number) {6this.number = number;7 }8 9publicvoid run() {
1011int result = 1;
1213if (number == 0) {
14 ...
线程Yield: yield()方法的作用是放弃当前的CPU资源,将它让给其他的任务去占用CPU执行时间,但放弃的时间不确定,有可能刚刚放弃,马上又获得CPU时间片。publicclass YieldThread extends Thread{@Overridepublicvoid run() {long beginTime = System.currentTimeMillis();int count = 0;for (int i = 0; i< 50000000; i++){//Thread.yield();count = count + (i + 1);}long endTime = System.currentTimeMillis();System.out.pri...
多线程的运行出现了安全问题原因: 当多条语句在操作同一个线程数据的时候,一个线程对多条语句只执行了一部分,还没执行完 另一个线程参与进来执行,导致共享数据的错误 解决办法: 对多条操作共享数据的语句,只能让一个线程都执行完。在执行过程中,其它线程不可以参与执行。 JAVA对于多线程安全问题,提供了专业的解决方式就是同步代码块synchronized(对象){ 需要被同步的代码} 1class Ticket implements Runnable...
第一种 继承Thread类自定义类,继承Thread类,并重写run()方法.class MyThread1 extends Thread {@Overridepublic void run() {System.out.println("第一种方式Thread " + Thread.currentThread().getName());}
}
public class Test {public static void main(String[] args) throws Exception {//第一种方式MyThread1 thread1 = new MyThread1();thread1.start();MyThread1 thread1 = new MyThread1();thread1.start();MyThread1 th...
国内首部Java多线程设计模式原创作品《Java多线程编程实战指南(设计模式篇)》已由电子工业出版社出版。本书从理论到实战,用生活化的实例和通俗易懂的语言全面介绍Java多线程编程的"三十六计"——多线程设计模式。当当、亚马逊、京东、互动出版网、淘宝等各大书店有售。【样章】http://viscent.iteye.com/category/328291【前言】随着现代CPU的生产工艺从提升CPU主频频率转向多核化,即在一块芯片上集成多个CPU内核(Core),以往...
介绍:在程序中,我们是不能随便中断一个线程的,因为这是极其不安全的操作,我们无法知道这个线程正运行在什么状态,它可能持有某把锁,强行中断可能导致锁不能释放的问题;或者线程可能在操作数据库,强行中断导致数据不一致混乱的问题。正因此,JAVA里将Thread的stop方法设置为过时,以禁止大家使用。一个线程什么时候可以退出呢?当然只有线程自己才能知道。所以我们这里要说的Thread的interrrupt方法,本质不是用来中断一个线...
在java中可有两种方式实现多线程,一种是继承Thread类,一种是实现Runnable接口;Thread类是在java.lang包中定义的。一个类只要继承了Thread类同时覆写了本类中的run()方法就可以实现多线程操作了,但是一个类只能继承一个父类,这是此方法的局限,下面看例子:[java] view plaincopypackage org.thread.demo; class MyThread extends Thread{ private String name; public MyThread(String name) { super(); this.name = nam...
这几天主要是狂看源程序,在弥补了一些以前知识空白的同时,也学会了不少新的知识(比如 NIO),或者称为新技术吧。
线程池就是其中之一,一提到线程,我们会想到以前《操作系统》的生产者与消费者,信号量,同步控制等等。
一提到池,我们会想到数据库连接池,但是线程池又如何呢?
建议:在阅读本文前,先理一理同步的知识,特别是syncronized同步关键字的用法。
关于我对同步的认识,要缘于大三年的一本书,书名好像是 Java 实战...
1.什么是线程 说到线程就是说进程,因为线程不能独立进程而存在. 进程是代码在数据集合上的一次运行活动 , 是系统进行资源分配和调度的基本单位 , 线程则是进程的一个执行路径, 一个进程中至少有一个线程,进程中的多个线程共享进程的资源。 在这里我们要知道,真正执行任务的或占用CPU运行的是线程,所以说线程是CPU分配的基本单位. 我们通常写的java main函数就是一个线程,也程为主线程. 1.1线程创建...
代码1:package cn.itcast.heima2;import java.util.Calendar;
import java.util.Timer;
import java.util.TimerTask;publicclass TraditionalTimerTest {publicstaticvoid main(String[] args) {new Timer().schedule(new TimerTask() {@Overridepublicvoid run() {System.out.println("OUTER:boom!");}},10000,3000);while(true){System.out.println(Calendar.getInstance().get(Calendar.SECOND));try {Thread.sleep(1000);} ca...
Java多线程基础:进程和线程之由来 在前面,已经介绍了Java的基础知识,现在我们来讨论一点稍微难一点的问题:Java并发编程。当然,Java并发编程涉及到很多方面的内容,不是一朝一夕就能够融会贯通使用的,需要在实践中不断积累。由于并发肯定涉及到多线程,因此在进入并发编程主题之前,我们先来了解一下进程和线程的由来,这对后面对并发编程的理解将会有很大的帮助。 下面是本文的目录大纲: 一.操作系统中为什么会出现...
线程池(用完的线程归还到线程池中省去创建删除线程操作)public class Xianchengchi {public static void main(String[] args) throws InterruptedException,ExecutionException {//线程池对象=线程池工厂创建两个线程的线程池ExecutorService es=Executors.newFixedThreadPool(2);//两个线程MyRunnable mr=new MyRunnable(); //任务对象//MyCallable c = new MyCallable();CallSum cs = new CallSum(100); //任务 有参构造 //Thr...
线程池可以解决两个不同问题:由于减少了每个任务调用的开销,它们通常可以在执行大量异步任务时提供增强的性能,并且还可以提供绑定和管理资源(包括执行任务集时使用的线程)的方法。每个 ThreadPoolExecutor 还维护着一些基本的统计数据,如完成的任务数。 Java常用的线程池有四种。Executors.newCachedThreadPool()(无界线程池,可以进行自动线程回收)、Executors.newFixedThreadPool(int)(固定大小线程池)、Executors...