synchronized 线程同步

synchronized  通常用来形容一次方法的调用,调用一旦开始,调用者必须等到方法调用返回后,才能继续执行后续的操作。

1.demo

package demo1;
public class MyThread extends Thread {
    private  int count = 5;
    @Override
    public  void run() {
        count--;
        System.err.println("∽"+currentThread().getName()+"count:"+this.count);
    }
    public  static void main(String[] args){
        MyThread  myThread = new MyThread();
        Thread t1 = new Thread(myThread,"myThread-1");
        Thread t2 = new Thread(myThread,"myThread-2");
        Thread t3 = new Thread(myThread,"myThread-3");
        Thread t4 = new Thread(myThread,"myThread-4");
        Thread t5 = new Thread(myThread,"myThread-5");
        t1.start();
        t2.start();
        t3.start();
        t4.start();
        t5.start();

    }
}结果输出:

        ∽myThread-1count:2
        ∽myThread-4count:1
        ∽myThread-2count:2
        ∽myThread-3count:2
        ∽myThread-5count:0

 

描述:5个线程都会去对这个 count  变量进行操作,但是出现了重复的数据,说明没有进行同步、共享。

2.demo:使用 synchronized 关键字

package demo1;

public class MyThread extends Thread {

    private  int count = 5;
    @Override
    public synchronized void run() {
        count--;
        System.err.println("∽"+currentThread().getName()+"count:"+this.count);
    }
    public  static void main(String[] args){
        MyThread  myThread = new MyThread();
        Thread t1 = new Thread(myThread,"myThread-1");
        Thread t2 = new Thread(myThread,"myThread-2");
        Thread t3 = new Thread(myThread,"myThread-3");
        Thread t4 = new Thread(myThread,"myThread-4");
        Thread t5 = new Thread(myThread,"myThread-5");
        t1.start();
        t2.start();
        t3.start();
        t4.start();
        t5.start();

    }
}

结果输出:

      ∽myThread-1count:4
      ∽myThread-3count:3
      ∽myThread-2count:2
      ∽myThread-4count:1
      ∽myThread-5count:0

 

描述:输出的结果没有重复的,说明同步生效了。

  1.当多个线程都去访问 MyThread 的run 方法的时候,都会以队列的的方式去进行访问处理(CPU的分配)。

  2.一个线程要执行 synchronized 方法修饰的代码块:都会去尝试去获取锁(object的锁),如果拿到锁,则执行 synchronized 代码的内容;

   如果拿不到,则会不断的去尝试获取这把锁,一直到拿到为止 (多个线程去尝试获取这把锁,就行形成竞争、排队的问题)。

时间: 2024-08-04 03:52:43

synchronized 线程同步的相关文章

synchronized 线程同步-类级别锁定

1.demo 说明:代码中通过 printNum 方法传入参数判断 a.b 分别对 num 这个参数的值进行了修改. package demo1; import sun.applet.Main; public class MyThread2 extends Thread { private int num = 0; public synchronized void printNum(String str) { try { if (str.equals("a")) { num = 100

线程同步关键字synchronized的作用

线程和进程的区别:  线程:是进程内部中的单一顺序控制流,一个进程拥有多个线程,多个线程共享一个进程的内存空间.   进程:是指一种"自包容"的运行程序,由操作系统直接管理.直接运行.有直接的地址空间,每个进程以开始都会消化内存. 线程同步:当二个或二个以上的进程同时访问一个资源时,为了保护资源的数据安全,只允许同一时间一个进程的访问,别的进程需要等待该进程放弃这个资源使用权时才能继续访问. 用一个列子来说明线程同步到底是怎么回事. package com.project.thread

【java并发】(2) Java线程同步:synchronized锁住的是代码还是对象

在Java中,synchronized关键字是用来控制线程同步的,就是在多线程的环境下,控制synchronized代码段不被多个线程同时执行.synchronized既可以加在一段代码上,也可以加在方法上. 关键是,不要认为给方法或者代码段加上synchronized就万事大吉,看下面一段代码: class Sync { public synchronized void test() { System.out.println("test开始.."); try { Thread.sle

java线程同步: synchronized详解(转)

Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码. 一.当两个并发线程访问同一个对象object中的这个synchronized(this)同步代码块时,一个时间内只能有一个线程得到执行(如果多个线程调用同一个线程,只能有一个线程得到执行).另一个线程必须等待当前线程执行完这个代码块以后才能执行该代码块. 二.然而,当一个线程访问object的一个synchronized(this)同步代码块时,另一个线程仍然可以访问该object中

Java多线程:线程同步与关键字synchronized

一.同步的特性1. 不必同步类中所有的方法, 类可以同时拥有同步和非同步方法.2. 如果线程拥有同步和非同步方法, 则非同步方法可以被多个线程自由访问而不受锁的限制. 参见实验1:http://blog.csdn.net/huang_xw/article/details/73185613. 如果两个线程要执行一个类中的同步方法, 并且两个线程使用相同的实例来调用方法, 那么一次只能有一个线程能够执行方法, 另一个需要等待, 直到锁被释放. 参见实验2:http://blog.csdn.net/h

Java线程(二):线程同步synchronized和volatile

上篇通过一个简单的例子说明了线程安全与不安全,在例子中不安全的情况下输出的结果恰好是逐个递增的(其实是巧合,多运行几次,会产生不同的输出结果),为什么会产生这样的结果呢,因为建立的Count对象是线程共享的,一个线程改变了其成员变量num值,下一个线程正巧读到了修改后的num,所以会递增输出. 要说明线程同步问题首先要说明Java线程的两个特性,可见性和有序性.多个线程之间是不能直接传递数据交互的,它们之间的交互只能通过共享变量来实现.拿上篇博文中的例子来说明,在多个线程之间共享了Count类的

java的线程同步机制synchronized关键字的理解

线程同步:               由于同一进程的多个线程共享同一片存储空间,在带来方便的同时,也带来了访问冲突这个严重的问题.Java语言提供了专门机制以解决这种冲突,有效避免了同一个数据对象被多个线程同时访问. 需要明确的几个问题: 1)synchronized关键字可以作为函数的修饰符,也可作为函数内的语句,也就是平时说的同步方法和同步语句块.如果 再细的分类,synchronized可作用于instance变量.object reference(对象引用).static函数和clas

JAVA并发编程3_线程同步之synchronized关键字

在上一篇博客里讲解了JAVA的线程的内存模型,见:JAVA并发编程2_线程安全&内存模型,接着上一篇提到的问题解决多线程共享资源的情况下的线程安全问题. 不安全线程分析 public class Test implements Runnable { private int i = 0; private int getNext() { return i++; } @Override public void run() { // synchronized while (true) { synchro

【java7并发编程实战】—–线程同步基础:synchronized

在我们的实际应用当中可能经常会遇到这样一个场景:多个线程读或者.写相同的数据,访问相同的文件等等.对于这种情况如果我们不加以控制,是非常容易导致错误的.在java中,为了解决这个问题,引入临界区概念.所谓临界区是指一个访问共用资源的程序片段,而这些共用资源又无法同时被多个线程访问. 在java中为了实现临界区提供了同步机制.当一个线程试图访问一个临界区时,他将使用一种同步机制来查看是不是已经有其他线程进入临界区.如果没有则他就可以进入临界区,否则他就会被同步机制挂起,指定进入的线程离开这个临界区