首页 > 其他 > 详细

Java多线程初学者指南(9):为什么要进行数据同步

时间:2014-02-08 00:47:52      阅读:369      评论:0      收藏:0      [点我收藏+]

Java中的变量分为两类:局部变量和类变量。局部变量是指在方法内定义的变量,如在run方法中定义的变量。对于这些变量来说,并不存在线程之间共享的问题。因此,它们不需要进行数据同步。类变量是在类中定义的变量,作用域是整个类。这类变量可以被多个线程共享。因此,我们需要对这类变量进行数据同步。

数据同步就是指在同一时间,只能由一个线程来访问被同步的类变量,当前线程访问完这些变量后,其他线程才能继续访问。这里说的访问是指有写操作的访问,如果所有访问类变量的线程都是读操作,一般是不需要数据同步的。

那么如果不对共享的类变量进行数据同步,会发生什么情况呢?让我们先看看下面的代码会发生什么样的事情:

bubuko.com,布布扣
 1 package com.fly.data;
 2 
 3 public class MyThread4 extends Thread {
 4     
 5      public static int n = 0;
 6 
 7         public void run()
 8         {
 9             int m = n;
10             yield();
11             m++;
12             n = m;
13         }
14         public static void main(String[] args) throws Exception
15         {
16             MyThread4 myThread = new MyThread4 ();
17             Thread threads[] = new Thread[100];
18             for (int i = 0; i < threads.length; i++)
19                 threads[i] = new Thread(myThread);
20             for (int i = 0; i < threads.length; i++)
21                 threads[i].start();
22             for (int i = 0; i < threads.length; i++)
23                 threads[i].join();
24             System.out.println("n = " + MyThread4.n);
25         }
26 
27 }
bubuko.com,布布扣

 在执行上面代码的可能结果如下:

     n = 89

看到这个结果,可能很多读者会感到奇怪。这个程序明明是启动了100个线程,然后每个线程将静态变量n1。最后使用join方法使这100个线程都运行完后,再输出这个n值。按正常来讲,结果应该是n = 100。可偏偏结果小于100

Java多线程初学者指南(9):为什么要进行数据同步

原文:http://www.cnblogs.com/dragonflyyi/p/3539917.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!