Java 并发学习
一、创建任务
任务可以理解为一段独立执行的代码,它完成一定的功能。
在Java 5及以上版本中不仅可以利用 Runnable接口,还可以利用Callable接口。
两种任务的区别:Runnable 的run()方法完成的任务是没有返回值的 - void
而Callable 的call()方法完成的任务是有返回值的 - 返回值 有接口的泛型<V> 来制定
二、执行任务
通过java.util.concurrent.ExecutorService接口对象来执行任务,
这个接口对象由工具类java.util.concurrent.Executors的静态方法来创建。
相关类及接口说明:
Executors 提供建立线程池或线程工厂的方法.
ExecutorService 提供了管理终止的方法,以及可为跟踪一个或多个异步任务执行状况而生成 Future 的方法。
Executor 可以简单理解为一个线程的执行者,是Executors 的上一级接口。
Callable 线程要执行而去实现的接口
Future 表示异步计算的结果,对执行的线程的状态检查,可以获得执行结果.
下面以一个例子来说明:
public class CallableDemo {
public static void main(String[] args) {
/**
* Executors.newFixedThreadPool(5)创建一个线程池,
* 这个线程池中维护 5 个线程的执行与销毁工作,并将维护的工作交给 ExecutorService 去处理
*/
ExecutorService service = Executors.newFixedThreadPool(5);
// ExecutorService service = Executors.newCachedThreadPool();
/**
* 记录线程的 任务(这里由实现了Callable接口 的类来执行)的返回接口
*/
List<Future<String>> resultList = new ArrayList<Future<String>>();
/**
* 创建 10个任务
*/
for (int i = 0; i < 10; i++) {
/**
* ExecutorService 的 submit方法 来维护任务(这个任务不是线程,是Callable,但是和线程的工作原理是一样的)的运行状态
*/
Future<String> future = service.submit(new
相关文档:
package Utils.Sort;
/**
*快速排序,要求待排序的数组必须实现Comparable接口
*/
public class QuickSort implements SortStrategy
{
private static final int CUTOFF = 3; //当元素数大于此 ......
一些企业在招聘程序员的时候,总会特意提出一个要求,即要求具有良好的编码规范。确实现在程序开发人员已经不在是单枪匹马的单干,而是讲究团体作战。此时就要求团队内的乘员都可能够恪守代码的编写规范,这对于乘员之间共享代码、排错等作业都具有非常现实的意义。这在Java语言中当然也不例外。笔者借这次机会, ......
原贴地址http://www.javaeye.com/topic/257191
今天下午研究了半天hashcode()和equals()方法,终于有了一点点的明白,写下来与大家分享(zhaoxudong
2008.10.23晚21.36)。
1. 首先equals()和hashcode()这两个方法都是从object类中继承过来的。
equals()方法在object类中定义如下:
public boolean equals( ......
最近我遇到很多java开发的新人,包括很自认为不是新人的人根本就不会自己搭建一个完整的开发环境,因此想写此文,希对他们有所帮助,解除他们的一些开发困惑,更好的了解java.
一、windows下开发环境的搭建
1、从http://java.sun.com/上下载windows平台的JDK,并安装。假设安装目录为:C:\jdk6.0
2、设定相关环境量(以wi ......
http://public0821.javaeye.com/blog/423941
C++调用JAVA主要用到了SUN公司的JNI技术, JNI是Java Native Interface的 缩写。从Java 1.1开始,Java Native Interface (JNI)标准成为java平台的一部分,它允许Java代码和其他语言写的代码进行交互。相关资料见http://java.sun.com/j2se/1.5.0/docs/guide/jni/spec/jniTOC.htm ......