线程

原创 2015年11月18日 19:17:03
上吴老师的课总是会取得意外的收获,往往是听课不能给我带来的,这已经在我的影响中完全的赞同的。学了很久的Java的线程,因为难度太大导致了我放弃了继续往下学习,转着去学底层,这已经两周了,平时却没有放弃了线程理解。今天忽然的明白了,线程的顿悟了真正的是功夫在诗外啊,对吴老师教我的方法真正的是感谢啊。
    对于整个学习,只想告诉看到这里的人,注意基础和全局性的东西的学习,局部的东西考试可能会有用,但是完全的理解还是要懂得全局的东西。

1.继承Thread类创建线程类

(1)定义Thread类的子类,并重写该类的run方法,该run方法的方法体就代表了线程要完成的任务。因此把run()方法称为执行体。

(2)创建Thread子类的实例,即创建了线程对象。

(3)调用线程对象的start()方法来启动该线程。 
package com.thread;

public class FirstThreadTest extends Thread{
int i = 0;
//重写run方法,run方法的方法体就是现场执行体
public void run()
{
for(;i<100;i++){
System.out.println(getName()+"  "+i);
}
}
public static void main(String[] args)
{
for(int i = 0;i< 100;i++)
{
System.out.println(Thread.currentThread().getName()+"  : "+i);
if(i==20)
{
new FirstThreadTest().run();
new FirstThreadTest().run();
}
}
}

}
、通过Runnable接口创建线程类

(1)定义runnable接口的实现类,并重写该接口的run()方法,该run()方法的方法体同样是该线程的线程执行体。

(2)创建 Runnable实现类的实例,并依此实例作为Thread的target来创建Thread对象,该Thread对象才是真正的线程对象。

(3)调用线程对象的start()方法来启动该线程。

package com.thread;


public class RunnableThreadTest implements Runnable

{


private int i;

public void run()

{

for(i = 0;i <100;i++)

{

System.out.println(Thread.currentThread().getName()+" "+i);

}

}

public static void main(String[] args)

{

for(int i = 0;i < 100;i++)

{

System.out.println(Thread.currentThread().getName()+" "+i);

if(i==20)

{

RunnableThreadTest rtt = new RunnableThreadTest();

new Thread(rtt,"新线程1").start();

new Thread(rtt,"新线程2").start();

}

}


}


}

3、 通过Callable和Future创建线程

(1)创建Callable接口的实现类,并实现call()方法,该call()方法将作为线程执行体,并且有返回值。

(2)创建Callable实现类的实例,使用FutureTask类来包装Callable对象,该FutureTask对象封装了该Callable对象的call()方法的返回值。

(3)使用FutureTask对象作为Thread对象的target创建并启动新线程。

(4)调用FutureTask对象的get()方法来获得子线程执行结束后的返回值

package com.thread;


import java.util.concurrent.Callable;

import java.util.concurrent.ExecutionException;

import java.util.concurrent.FutureTask;


public class CallableThreadTest implements Callable<Integer>

{


public static void main(String[] args)

{

CallableThreadTest ctt = new CallableThreadTest();

FutureTask<Integer> ft = new FutureTask<>(ctt);

for(int i = 0;i < 100;i++)

{

System.out.println(Thread.currentThread().getName()+" 的循环变量i的值"+i);

if(i==20)

{

new Thread(ft,"有返回值的线程").start();

}

}

try

{

System.out.println("子线程的返回值:"+ft.get());

} catch (InterruptedException e)

{

e.printStackTrace();

} catch (ExecutionException e)

{

e.printStackTrace();

}


}


@Override

public Integer call() throws Exception

{

int i = 0;

for(;i<100;i++)

{

System.out.println(Thread.currentThread().getName()+" "+i);

}

return i;

}


}

二、创建线程的三种方式的对比

采用实现Runnable、Callable接口的方式创见多线程时,优势是:

线程类只是实现了Runnable接口或Callable接口,还可以继承其他类。

在这种方式下,多个线程可以共享同一个target对象,所以非常适合多个相同线程来处理同一份资源的情况,从而可以将CPU、代码和数据分开,形成清晰的模型,较好地体现了面向对象的思想。

劣势是:

编程稍微复杂,如果要访问当前线程,则必须使用Thread.currentThread()方法。

使用继承Thread类的方式创建多线程时优势是:

编写简单,如果需要访问当前线程,则无需使用Thread.currentThread()方法,直接使用this即可获得当前线程。

劣势是:

线程类已经继承了Thread类,所以不能再继承其他父类。

总结一句话,《疯狂Java教程》是一本很好的教材,一千多页的书以前不敢想自己会去看,结果现在发现快看完了。
God Bless China! 

相关文章推荐

java线程.rar

  • 2017年07月26日 10:17
  • 232KB
  • 下载

java多线程之线程生命周期和状态控制

java线程的生命周期和状态控制 一、线程的生命周期 线程状态转换图: 1、新建状态 用new关键字和Thread类或其子类建立一个线程对象后,该线程对象就处于新生状态。处于...
  • ajhsdj
  • ajhsdj
  • 2014年12月02日 15:53
  • 486

安卓 线程代码实例

  • 2017年07月28日 12:13
  • 9KB
  • 下载

vmmap 观察jvm内存 监控jvm jvm线程

  • 2017年03月20日 14:44
  • 413KB
  • 下载

Linux线程退出方式总结

在编写多线程代码时,经常面临线程安全退出的问题。 一般情况下,选择检查标志位的方式: 在线程的while循环中,执行完例程后,都对标志位进行检查,如果标志位指示继续执行则再次执行例程,如果标志位设...

windows线程与内核调度

  • 2015年04月28日 19:34
  • 236KB
  • 下载

线程、预处理ppt

  • 2015年06月10日 17:02
  • 883KB
  • 下载

理解ThreadLocal(线程局部变量)

ThreadLocal(线程局部变量)概述 ThreadLocal是什么呢?其实ThreadLocal并非是一个线程的本地实现版本,它并不是一个Thread,而是threadloca...
  • yanwushu
  • yanwushu
  • 2012年05月17日 22:42
  • 13125

移动编程之线程

  • 2014年11月27日 19:24
  • 1005KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:线程
举报原因:
原因补充:

(最多只允许输入30个字)