JAVA学习笔记_demo_多线程_1
2017-08-17 17:01
323 查看
public class Demo { public static boolean stop = false; public static void main(String[] args) throws InterruptedException { //线程1 Thread testThread = new Thread(){ @Override public void run(){ int i=1; while(!stop){ i++; } System.out.println("thread stop i= " +i); } }; //线程2 System.out.println("start!!!"); testThread.start(); Thread.sleep(2000); stop=true; System.out.println("now stop= "+stop); testThread.join(); System.out.println("test........."); } }
输出结果:
结果分析:
执行步骤:1.先执行输出语句,输出 start!!! 2.启动线程1 3.由于可见性问题 线程1一直在死循环 执行 i++这一操作 4.休眠2秒后输出 now stop= true 5.testThread.join(); 此时MainThread在testThread.join()被调用后被阻塞,直到testThread执行完毕才继续执行。 6.testThread一直在执行 i++, 导致System.out.println("thread stop i= " +i); System.out.println("test........."); 这两个语句执行不到
==============================================
相关知识点:
原子性问题,可见性问题,有序性问题。
1.原子性 原子性:即一个操作或者多个操作 要么全部执行并且执行的过程不会被任何因素打断,要么就都不执行。一个很经典的例子就是银行账户转账问题。 2.可见性 可见性是指当多个线程访问同一个变量时,一个线程修改了这个变量的值,其他线程能够立即看得到修改的值。 3.有序性 有序性:即程序执行的顺序按照代码的先后顺序执行。
指令重排序,一般来说,处理器为了提高程序运行效率,可能会对输入代码进行优化,它不保证程序中各个语句的执行先后顺序同代码中的顺序一致,但是它会保证程序最终执行结果和代码顺序执行的结果是一致的。(处理器在进行重排序时是会考虑指令之间的数据依赖性的)
多线程情况下:
//线程1: context = loadContext(); //语句1 inited = true; //语句2 //线程2: while(!inited ){ sleep() } doSomethingwithconfig(context);
由于语句1和语句2没有数据依赖性,因此可能会被重排序。假如发生了重排序,在线程1执行过程中先执行语句2,而此是线程2会以为初始化工作已经完成,那么就会跳出while循环,去执行doSomethingwithconfig(context)方法,而此时context并没有被初始化,就会导致程序出错。
从上面可以看出,指令重排序不会影响单个线程的执行,但是会影响到线程并发执行的正确性。
也就是说,要想并发程序正确地执行,必须要保证原子性、可见性以及有序性。只要有一个没有被保证,就有可能会导致程序运行不正确。
======================================
synchronized
所有加上synchronized 和 块语句,在多线程访问的时候,同一时刻只能有一个线程能够用synchronized 修饰的方法 或者 代码块。
volatile :保证可见性和禁止指令重排序
用volatile修饰的变量,线程在每次使用变量的时候,都会读取变量修改后的最新的值。volatile很容易被误用,用来进行原子性操作。
Thread.Join() 方法
MSDN:Blocks the calling thread until a thread terminates 当a thread调用Join方法的时候,MainThread 就被停止执行,直到a thread线程执行完毕。
参考:http://blog.csdn.net/libing13820393394/article/details/48582999
http://www.cnblogs.com/SkySoot/archive/2012/06/27/2566004.html
相关文章推荐
- 【Java学习笔记】58:多线程Socket通信的demo
- Java学习笔记 --- 多线程共享资源Demo
- Java 多线程编程 学习笔记
- 静态学习笔记StaticDemo.java
- GUI学习笔记MyMenuDemo.java
- 静态内部类学习笔记InnerClassDemo2.java
- JAVA多线程学习笔记
- Java学习笔记(五、多线程)
- C\C++ 程序员从零开始学习Android - 个人学习笔记(十) - java基础 - 多线程(待续)
- 学习java多线程的笔记3-使用BlockingQueue阻塞队列来模拟两个线程之间的通信
- 多态Object类equals方法学习笔记ObjectDemo.java
- 学习java多线程的笔记4--传智播客_张孝祥_空中网挑选实习生的面试题(来源于视频)
- java学习笔记(九)----多线程
- 黑马程序员java学习笔记之四(java多线程总结)
- 多态Object类toString方法学习笔记ObjectDemo.java
- java多线程学习笔记2
- GUI学习笔记MyWindowDemo.java
- 匿名内部类学习笔记InnerClassDemo4.java
- [零散篇]Java学习笔记---Java的Socket网络编程以及多线程
- 异常抛出学习笔记ExceptionDemo2.java