Java多线程编程之Thread和Runnable的区别
来源:互联网 发布:java cache类 编辑:程序博客网 时间:2024/05/21 22:06
Thread 和Runnable的最大区别就在于共享数据。每当你new一个Thread的时候,虚拟机会给你new出来的Thread分配一块单独的内存。Thread和Thread对象之间的数据不共享。如下:
Example1:
class Thread1 extends Thread{
private int temp = 0;
public void run(){
操作temp变量;
输出temp变量作为记录
}
}
分别开三个线程或者更多观察来观察会发现,这三个线程都是从0开始累加的,这就说明temp变量是不被共享的。
new Thread().start();
new Thread().start();
new Thread().start();
Example2:
class Thread2 implements Runnable{
private int temp = 0;
public void run(){
操作temp
输出temp变量作为记录
}
}
执行example1相同的操作
Thread2 t2 = new Thread2();
new Thread(t2).start();
new Thread(t2).start();
new Thread(t2).start();
通过观察程序输出你会发现,这三个线程执行的时候,输出的内容就是从0开始依次累加的。
即由于temp变量被共享,所以,多个线程会对其进行同时操作。
这里需要注意的一点就是,由于Thread2对象被多个线程共享,所以,在同时开始进行多线程操作的时候很容易造成线程异常,
为了保证线程安全,建议在使用共享资源的地方添加同步锁来保证线程执行安全。
- Java多线程编程之Thread和Runnable的区别
- 【Java并发编程】Runnable和Thread实现多线程的区别
- 【Java并发编程】之六:Runnable和Thread实现多线程的区别(含代码)
- 【Java并发编程】之六:Runnable和Thread实现多线程的区别(含代码)
- 【Java并发编程】之六:Runnable和Thread实现多线程的区别(含代码)
- 【Java并发编程】之六:Runnable和Thread实现多线程的区别(含代码)
- 【Java并发编程】之六:Runnable和Thread实现多线程的区别(含代码)(r)
- 【Java并发编程】之六:Runnable和Thread实现多线程的区别(含代码)
- Java 并发编程之Runnable和Thread实现多线程的区别
- 【Java并发编程】之六:Runnable和Thread实现多线程的区别(含代码)
- 【Java并发编程】之六:Runnable和Thread实现多线程的区别(含代码)
- java 多线程 Thread和Runnable的区别
- Java多线程Thread和Runnable的区别
- Java多线程编程之Runnable、Thread简介
- java多线程之Thread与runnable的区别
- java并发编程(一)--Runnable和Thread实现多线程的区别
- Java并发编程(6):Runnable和Thread实现多线程的区别(含代码)
- java多线程 Runnable和Thread区别
- centOS7安装java以及连接外网问题(Ping不通)
- Linux C 基础1
- 士兵杀敌(三)
- JSON 之 SuperObject(3): 访问
- 文章标题
- Java多线程编程之Thread和Runnable的区别
- nginx 禁止对.svn 目录访问
- ES6新特性
- 句子引发的血案-第四天
- Flex
- 多线程实现生产者消费者
- eclipse 中新建的Dynamic Web Project 中无web.xml&&web.xml中Servlet的配置问题
- NS-3教程(2):NS-3简单介绍
- What is the difference between wc -1 < mydata.dat and wc -1 < mydata.dat ?