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
相关文档:
/**
* 平衡二叉搜索(排序)树
*
* 平衡二叉搜索树双称为AVL树,它也是一棵二叉搜索树,是对二叉搜索树的一种改进,或都是具有下列性质的二叉树:它
* 的左子树和右子树都是平衡二叉树,且左子树和右子树的深度之差的绝对值不超过1。
*
* 平衡因子(Balance Factor,BF)定义为 ......
参数说明
fileName: 表示想解压的文件名 如:c:\\aaa\a.zip
unZipDir: 表示想解压到的路径 如:c:\\ccc
public static void unZip1(String fileName, String unZipDir) {
try {
Fil ......
一些企业在招聘程序员的时候,总会特意提出一个要求,即要求具有良好的编码规范。确实现在程序开发人员已经不在是单枪匹马的单干,而是讲究团体作战。此时就要求团队内的乘员都可能够恪守代码的编写规范,这对于乘员之间共享代码、排错等作业都具有非常现实的意义。这在Java语言中当然也不例外。笔者借这次机会, ......
作为Java程序员来说,最痛苦的事情莫过于可以选择的范围太广,可以读的书太多,往往容易无所适从。根据我的经验,按照学习的先后顺序,推荐给大家,特别是那些想不断提高自己技术水平的Java程序员们。
一、Java编程入门类
对于没有Java编程经验的程序员要入门,随便读什么入门书籍都一样,这个阶段需要你 ......
仅仅是一个微小的问题而已:
1.可以设置一个setcp.bat的文件,内容如下
set classpath=.;D:\StudyWorkSpace\lib\sqljdbc.jar;D:\StudyWorkSpace\lib\jfreechart-1.0.10.jar;D:\StudyWorkSpace\jfreechart\jcommon-1.0.13.jar;
每次编译Java文件的时候都要先运行此文件,可以在环境变量里 ......