人物背景: 老徐,男,本名徐福贵,从事Java相关研发工作多年,职场老油条,摸鱼小能手,虽然岁数不大但长的比较着急,人称老徐.据说之前炒某币败光了所有家产,甚至现在还有欠债. 阿珍,女,本名陈家珍,刚刚入职不久的实习生,虽然是职场菜鸟但聪明好学.据说是学校的四大校花之一,追求她的人从旺角排到了铜锣湾,不过至今还单身. 阿珍探出头看了看老徐的屏幕,全部都是绿色的曲线图,好奇地问:"老徐,你看的这是什么?"老徐看的太入神,转过头才发现阿珍,尬尴地笑了笑说:"我就是看看最近的行情.…
人物背景: 老徐,男,本名徐福贵,从事Java相关研发工作多年,职场老油条,摸鱼小能手,虽然岁数不大但长的比较着急,人称老徐.据说之前炒某币败光了所有家产,甚至现在还有欠债. 阿珍,女,本名陈家珍,刚刚入职不久的实习生,虽然是职场菜鸟但聪明好学.据说是学校的四大校花之一,追求她的人从旺角排到了铜锣湾,不过至今还单身. 老徐问道:"阿珍,你知道ArrayList和LinkedList的区别吗?" 阿珍微微一笑,说:"这也太小儿科了,ArrayList是基于数组实现,Linked…
人物背景: 老徐,男,本名徐福贵,从事Java相关研发工作多年,职场老油条,摸鱼小能手,虽然岁数不大但长的比较着急,人称老徐.据说之前炒某币败光了所有家产,甚至现在还有欠债. 阿珍,女,本名陈家珍,刚刚入职不久的实习生,虽然是职场菜鸟但聪明好学.据说是学校的四大校花之一,追求她的人从旺角排到了铜锣湾,不过至今还单身. 微信公众号:万猫学社 微信扫描二维码 关注后回复「电子书」 获取12本Java必读技术书籍 阿珍吃完饭刚刚回来,看到老徐正在吃方便面,说:"老徐,不至于吧.你为了还债,中午就吃这个…
老徐FrankXuLei 受邀为花旗银行上海研发中心讲授<微软WCF服务分布式开发与SOA架构设计课程> 受邀为花旗银行上海研发中心讲授<微软WCF服务分布式开发与SOA架构设计课程>研发中心2000多工程师,隶属于花旗集团.非常愉快也交流具体开发问题.偶遇前同事Ross@微软中国 @微软中国MSDN @微软中国TechNet @微软中国MVP项目组 @51CTO技术社区 @新青年IT学习网 微软WCF Web服务 Web API学习群 339444457 微软ASP.NET MV…
http://www.cnblogs.com/dolphin0520/p/3949310.html java 1.5以前创建线程的2种方式,一种是直接继承Thread,另外一种就是实现Runnable接口.这2种方式都有一个缺陷就是:在执行完任务之后无法获取执行结果. 如果需要获取执行结果,就必须通过共享变量或者使用线程通信的方式来达到效果,这样使用起来就比较麻烦. 而自从Java 1.5开始,就提供了Callable和Future,通过它们可以在任务执行完毕之后得到任务执行结果. 今天我们就来…
我们先来分别看一下这两个接口 Runnable: // // Source code recreated from a .class file by IntelliJ IDEA // (powered by Fernflower decompiler) // package java.lang; @FunctionalInterface public interface Runnable { void run(); } 只有一个方法run(),表示执行任务的逻辑. Callable: // //…
Runnable和Callable之间的区别 1.Runnable任务执行后没有返回值:Callable任务执行后可以获得返回值 2.Runnable的方法是run(),没有返回值:Callable的方法是call(),有返回值 3.Runnable的run()方法不能抛异常,有异常的话只能在run方法里面解决:Callable的call()方法可以抛异常 4.Runnable可以直接传递给Thread对象执行:Callable不可以,Callable执行可以放在FutureTask中,然后把f…
Runnable和Callable 的区别 01.Runnable接口中只有一个run()没有返回值 没有声明异常   Callable接口中只有一个call()有返回值 有声明异常 02.Callable中的call()返回值我们一般使用Future接口来接收 03.涉及了Future思想:排队以后可以暂时离队,等到该线程可以操作时会有方法提醒,然后将继续执行本操作.…
突然发现和启动一个线程有关的有三函数,run(), call(), start(),有点小乱,所以特别梳理一下 首先说一下start(),这个是最好说的,感觉start()和run()这俩名字是真的有点容易混 其实,start()是我们用extends Thread方式写一个线程才会遇到的问题,其中的逻辑就是,start()会调用run()方法,就run()方法自己而言,其实就是一个同步的方法,所以如果在main中直接调用一个线程的run方法,会看到多个线程会顺序执行. 只有用start方法开始…
1.runnable 与 callable区别 2.避免callable执行完任务,获取返回结果时,阻塞其他子线程 下面固定线程池,设置4个,表明同时只有4个线程在执行任务,当某个线程执行完一个任务,才会把另一个任务加进来继续执行(注释的是调度线程池) {下图有10个任务要执行,但线程池里只有4个线程来执行任务} 下面这种写法,可以给执行任务的线程传参(即自己重写的TaskCallabel,传i了) 接上图,用Future接收实现callable接口的线程的返回值,会阻塞主线程 下面自己实现的T…
在再度温习Java5的并发编程的知识点时发现,首要的就是把Runnable.Callable.Executor.Future等的关系搞明白,遂有了下述小测试程序,通过这个例子上述三者的关系就一目了然了. 在java5以后,一个可以调度执行的线程单元可以有三种方式定义: Thread.Runnable.Callable,其中Runnable实现的是void run()方法,Callable实现的是 V call()方法,并且可以返回执行结果,其中Runnable可以提交给Thread来包装下,直接…
一:Runnable.Callable.FutureTask简介 (1)Runnable:其中的run()方法没有返回值. ①.Runnable对象可以直接扔给Thread创建线程实例,并且创建的线程实例与Runnable绑定,线程实例调用start()方法时,Runnable任务就开始真正在线程中执行. ②.Runnable对象也可以直接扔给线程池对象的execute方法和submit方法,让线程池为其绑定池中的线程来执行. ③.Runnable对象也可以进一步封装成FutureTask对象之…
这一系列的文章暂不涉及Java多线程开发中的底层原理以及JMM.JVM部分的解析(将另文总结),主要关注实际编码中Java并发编程的核心知识点和应知应会部分. 说在前面,Java并发编程的实质,是线程对象调用start方法启动多线程,而线程对象则必须是Thread类或其子类实现.Runnable和Callable的作用类似于Comparable.Serializable,是用于被并发的类实现的接口,从而使得Thread类可以在初始化时传入这个被并发的类.此是大前提.本文从多线程实现和启动出发,对…
本文转载自:http://blog.csdn.net/bboyfeiyu/article/details/24851847 Runnable 其中Runnable应该是我们最熟悉的接口,它只有一个run()函数,用于将耗时操作写在其中,该函数没有返回值.然后使用某个线程去执行该runnable即可实现多线程,Thread类在调用start()函数后就是执行的是Runnable的run()函数.Runnable的声明如下 : public interface Runnable { /** * Wh…
并发性(concurrency)和并行性(parallel)是两个概念,并行是指在同一时刻,有多条指令在多个处理器上同时执行:并发指在同一时刻只能有一条指令执行,但多个进程指令被快速轮换执行,使得宏观上具有多个进程同时执行的效果. 多线程编程优点: 进程之间不能共享内存,但线程之间共享内存非常容易. 系统创建线程所分配的资源相对创建进程而言,代价非常小. Java中实现线程的方式目前有三种: 一:继承Thread类创建线程类 package com.clzhang.sample.thread;…
Runnable: Runnable的代码非常简单,他是一个接口,且接口中只有一个方法,run(),创建一个类实现他,把一些费时操作写在其中,然后使用某个线程去执行该Runnable实现类即可实现多线程. Callable: Callable的代码也非常简单,不同的是他是一个泛型接口,call()函数返回的类型就是创建Callable传进来的V类型,Callable与Runnable的功能大致相同,项目中有些任务是需要异步(提交到线程池中)去执行,而主线程往往需要知道异步执行产生的结果,这时我们…
类图: 先看各自的源码: public interface Runnable { public abstract void run(); } public class Thread implements Runnable { /* What will be run. */ private Runnable target; } Thread与Runnable其实是一个装饰器模式. public interface Callable<V> { V call() throws Exception;…
Runnable 任务,没有返回值 Callable 任务,又返回值 Runnable与Callable 相同点: 1. 都是接口: 2. 用来编写多线程程序: 3. 都需要调用Thread.start()启动线程 不同点: 1. 实现Callable接口的任务线程能返回执行结果:而实现Runnable接口的任务线程不能返回结果 2. Callable接口的call()方法允许抛出异常:而Runnable接口的run()方法的异常只能在内部消化,不能继续上抛…
一.Runnable Runnable非常简单,只需要实现一个run方法即可,没有参数,也没有返回值.可以以new Thread的方式去运行,当然更好的方式在放到excutorPool中去运行. 二.Callabe和Future Callable也用来实现异步调用,但是可以返回参数,并可以抛出异常. Future可以认为是对java异步执行机制的另一种包装. public interface Future<V> { boolean cancel(boolean mayInterruptIfRu…
Java从发布的第一个版本开始就可以很方便地编写多线程的应用程序,并在设计中引入异步处理.Thread类.Runnable接口和Java内存管理模型使得多线程编程简单直接.但正如之前提到过的,Thread类和Runnable接口都不允许声明检查型异常,也不能定义返回值.没有返回值这点稍微有点麻烦.   不能声明抛出检查型异常则更麻烦一些.public void run()方法契约意味着你必须捕获并处理检查型异常.即使你小心地保存了异常信息(译者注:在捕获异常时)以便稍后检查,但也不能保证这个类(…
Java 提供了三种创建线程的方法 1.继承Thread接口 public class Thread2Thread { public static void main(String[] args) { new MyThread1().start(); new Thread(new MyThread1(), "线程2").start(); } } /** * 通过继承Thread类 */ class MyThread1 extends Thread { /** * 重写run方法 */…
一.多线程 线程是指进程中的一个执行流程,一个进程中可以有多个线程.如java.exe进程中可以运行很多线程.进程是运行中的程序,是内存等资源的集合,线程是属于某个进程的,进程中的多个线程共享进程中的内存.线程之间的并发执行是线程轮流占用资源执行的结果,给人一种“同时”执行的感觉.在Java中多线程的编程有很多方法来实现,这里从Thread类.Runnable与Callable接口以及线程池等几个方式来探讨. 二.Thread类 以下是Thread类的部分源代码: public class Th…
Runnable 与 Callable的区别: (1)Callable规定的方法是call(),Runnable规定的方法是run(). (2)Callable的任务执行后可返回值,而Runnable的任务是不能返回值的 (3)call方法可以抛出异常,run方法不可以 (4)运行Callable任务可以拿到一个Future对象,Future 表示异步计算的结果.(PS: 特别注意,executorService.submit(Runnable task) 也会返回future, 但是没有fut…
说说Runnable与Callable   Callable接口:   Runnable接口: 相同点: 两者都是接口:(废话) 两者都可用来编写多线程程序: 两者都需要调用Thread.start()启动线程: 不同点: 两者最大的不同点是:实现Callable接口的任务线程能返回执行结果:而实现Runnable接口的任务线程不能返回结果: Callable接口的call()方法允许抛出异常:而Runnable接口的run()方法的异常只能在内部消化,不能继续上抛: 注意点: Callable…
一.Callable与Future类图 1.类图 许多任务实际上都是存在延迟的计算,对于这些任务,Callable是一种更好的抽象:它会返回一个值,并可能抛出一个异常.Callable接口: V call() throws Exception; 可以看到,这是一个泛型接口,call()函数返回的类型就是传递进来的V类型. Runnable和Callable描述的都是抽象的计算任务.这些任务通常是有生命周期的.Executor执行的任务有4个生命周期阶段:创建.提交.开始和完成.由于有些任务可能要…
方式一:继承Thread类实现多线程: 1. 在Java中负责实现线程功能的类是java.lang.Thread 类. 2. 可以通过创建 Thread的实例来创建新的线程. 3. 每个线程都是通过某个特定的Thread对象所对应的方法run( )来完成其操作的,方法run( )称为线程体. 4. 通过调用Thread类的start()方法来启动一个线程(只是将线程由新生态转为就绪态,而不是运行态). 代码示例: public class TestThread extends Thread {/…
说一下 runnable 和 callable 有什么区别?(未完成)…
Runnable是个借口,使用简单: 1. 实现该接口并重写run方法 2. 利用该类的对象创建线程 3. 线程启动时就会自动调用该对象的run方法     通常在开发中结合ExecutorService使用,将任务的提交与任务的执行解耦开,同时也能更好地利用Executor提供的各种特性 Runnable接口: public interface Runnable { public abstract void run(); } 缺点: 1.Runnable接口不能抛出异常,只能内部消化: 2.R…
Java中存在Runnable.Callable.Future.FutureTask这几个与线程相关的类或者接口,在Java中也是比较重要的几个概念,我们通过下面的简单示例来了解一下它们的作用于区别. Runnable 其中Runnable应该是我们最熟悉的接口,它只有一个run()函数,用于将耗时操作写在其中,该函数没有返回值.然后使用某个线程去执行该runnable即可实现多线程,Thread类在调用start()函数后就是执行的是Runnable的run()函数.Runnable的声明如下…
多线程一直是初学者最抵触的东西,如果你想进阶的话,那必须闯过这道难关,特别是多线程中Thread.Runnable.Callable.Future.FutureTask这几个类往往是初学者容易搞混的.这里先总结这几个类特点和区别,让大家带着模糊印象来学习这篇文章 Thread.Runnable.Callable:都是线程 Thread特点:提供了线程等待.线程睡眠.线程礼让等操作 Runnable和Callable特点:都是接口,并提供对应的实现方法 Runnable.Callable区别:Ru…