Android(java)同步方法synchronized
synchronized 是java语言keyword。当它用来修饰一个方法或者一个代码块的时候,可以保证在同一时刻最多仅仅有一个线程运行该段代码。
synchronized keyword,它包含两种使用方法:synchronized 方法和 synchronized 块。
本文直接以代码的形式来展示 synchronized keyword的使用:
【1】synchronized Demo1:
- package com.andyidea.demo;
- /**
- * 当两个并发线程訪问同一个对象object中的这个synchronized(this)同步代码块时,
- * 一个时间内仅仅能有一个线程得到运行。还有一个线程必须等待当前线程运行完这个代码
- * 块以后才干运行该代码块。
- * @author Andy.Chen
- *
- */
- public class Thread01 implements Runnable {
- @Override
- public void run() {
- synchronized (this) {
- for(int i=0;i<3;i++){
- System.out.println(Thread.currentThread().getName()+" synchronized loop "+i);
- }
- }
- }
- public static void main(String[] args) {
- Thread01 t01 = new Thread01();
- System.out.println("synchronized keyword使用 \n"
- +"--------------------------");
- Thread ta = new Thread(t01,"A");
- Thread tb = new Thread(t01,"B");
- ta.start();
- tb.start();
- }
- }
执行结果例如以下:
- synchronized keyword使用
- --------------------------
- B synchronized loop 0
- B synchronized loop 1
- B synchronized loop 2
- A synchronized loop 0
- A synchronized loop 1
- A synchronized loop 2
【2】synchronized Demo2:
- package com.andyidea.demo;
- /**
- * 当一个线程訪问object的一个synchronized(this)同步代码块时,
- * 还有一个线程仍然能够訪问该object中的非synchronized(this)同步代码块。
- * @author Andy.Chen
- *
- */
- public class Thread02 {
- public void method01(){
- synchronized (this) {
- int i=0;
- while(i++ < 3){
- System.out.println(Thread.currentThread().getName() +":"+ i);
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- }
- public void method02(){
- //第1种方式:当一个线程訪问object的一个synchronized(this)同步代码块时。
- //还有一个线程仍然能够訪问该object中的非synchronized(this)同步代码块。
- // int j=0;
- // while(j++ < 3){
- // System.out.println(Thread.currentThread().getName() +":"+ j);
- // try {
- // Thread.sleep(1000);
- // } catch (InterruptedException e) {
- // e.printStackTrace();
- // }
- // }
- //第2种方式:当一个线程訪问object的一个synchronized(this)同步代码块时,
- //其他线程对object中全部其他synchronized(this)同步代码块的訪问将被堵塞。
- synchronized (this) {
- int j=0;
- while(j++ < 3){
- System.out.println(Thread.currentThread().getName() +":"+ j);
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- }
- /**
- * 当一个线程訪问object的一个synchronized(this)同步代码块时,
- * 它就获得了这个object的对象锁。
- * 结果,其他线程对该object对象全部同步代码部分的訪问都被临时堵塞。
- */
- public synchronized void method3(){
- int k=0;
- while(k++ < 3){
- System.out.println(Thread.currentThread().getName() +":"+ k);
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- public static void main(String[] args) {
- final Thread02 t02 = new Thread02();
- System.out.println("synchronized keyword使用 \n"
- +"--------------------------");
- Thread t02A = new Thread(new Runnable() {
- @Override
- public void run() {
- t02.method01();
- }
- },"A");
- Thread t02B = new Thread(new Runnable() {
- @Override
- public void run() {
- t02.method02();
- }
- },"B");
- Thread t02C = new Thread(new Runnable() {
- @Override
- public void run() {
- t02.method3();
- }
- },"C");
- t02A.start();
- t02B.start();
- t02C.start();
- }
- }
执行结果例如以下:
- synchronized keyword使用
- --------------------------
- B:1
- B:2
- B:3
- C:1
- C:2
- C:3
- A:1
- A:2
- A:3
【3】synchronized Demo3:
- package com.andyidea.demo;
- /**
- * synchronized对象锁
- * @author Andy.Chen
- *
- */
- public class Thread03 {
- class InnerObject{
- /**
- * 内部类方法1
- */
- private void innerMethod01(){
- int i=0;
- while(i++ < 3){
- System.out.println(Thread.currentThread().getName() +":"+ i);
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- /**
- * 内部类方法2
- */
- private void innerMethod02(){
- int j=0;
- while(j++ < 3){
- System.out.println(Thread.currentThread().getName() +":"+ j);
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- }
- /**
- * 外部类方法1
- * @param innerObj
- */
- private void outerMethod01(InnerObject innerObj){
- synchronized (innerObj) {
- innerObj.innerMethod01();
- }
- }
- /**
- * 外部类方法2
- * @param innerObj
- */
- private void outerMethod02(InnerObject innerObj){
- innerObj.innerMethod02();
- }
- public static void main(String[] args) {
- final Thread03 t03 = new Thread03();
- final InnerObject innerObj = t03.new InnerObject();
- System.out.println("synchronized keyword使用 \n"
- +"--------------------------");
- Thread t03A = new Thread(new Runnable() {
- @Override
- public void run() {
- t03.outerMethod01(innerObj);
- }
- },"A");
- Thread t03B = new Thread(new Runnable() {
- @Override
- public void run() {
- t03.outerMethod02(innerObj);
- }
- },"B");
- t03A.start();
- t03B.start();
- }
- }
执行结果例如以下:
- synchronized keyword使用
- --------------------------
- A:1
- B:1
- B:2
- A:2
- B:3
- A:3
总结:
1. synchronized 方法控制对类成员变量的訪问:每一个类实例相应一把锁,每一个 synchronized 方法都必须获得调用该方法的类实例的锁方能运行。否则所属线程堵塞,方法一旦运行。就独占该锁。直到从该方法返回时才将锁释放。此后被堵塞的线程方能获得该锁。又一次进入可运行状态。
这样的机制确保了同一时刻对于每一个类实例,其全部声明为 synchronized 的成员函数中至多仅仅有一个处于可运行状态(由于至多仅仅有一个可以获得该类实例相应的锁),从而有效避免了类成员变量的訪问冲突(仅仅要全部可能訪问类成员变量的方法均被声明为
synchronized)。
2. synchronized 块是这样一个代码块,当中的代码必须获得对象 syncObject (如前所述,能够是类实例或类)的锁方能运行。
因为能够针对随意代码块。且可随意指定上锁的对象。故灵活性较高。
对synchronized(this)的一些理解
一、当两个并发线程訪问同一个对象object中的这个synchronized(this)同步代码块时。一个时间内仅仅能有一个线程得到运行。
还有一个线程必须等待当前线程运行完这个代码块以后才干运行该代码块。
二、然而。当一个线程訪问object的一个synchronized(this)同步代码块时。还有一个线程仍然能够訪问该object中的非synchronized(this)同步代码块。
三、尤其关键的是。当一个线程訪问object的一个synchronized(this)同步代码块时,其他线程对object中全部其他synchronized(this)同步代码块的訪问将被堵塞。
四、当一个线程訪问object的一个synchronized(this)同步代码块时。它就获得了这个object的对象锁。
结果,其他线程对该object对象全部同步代码部分的訪问都被临时堵塞。
Android(java)同步方法synchronized的更多相关文章
- Java多线程同步方法Synchronized和volatile
11 同步方法 synchronized – 同时解决了有序性.可见性问题 volatile – 结果可见性问题 12 同步- synchronized synchronized可以在任意对象上加 ...
- Java同步方法:synchronized到底锁住了谁?
目录 前言 同步方法 类的成员方法 类的静态方法 同步代码块 总结 其他同步方法 参考资料 前言 相信不少同学在上完Java课后,对于线程同步部分的实战,都会感到不知其然. 比如上课做实验的时候,按着 ...
- Java 多线程 —— synchronized关键字
java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...
- Java的synchronized关键字:同步机制总结
JAVA中synchronized关键字能够作为函数的修饰符,也可作为函数内的语句,也就是平时说的同步方法和同步语句块.搞清楚synchronized锁定的是哪个对象,就能帮助我们设计更安全的多线程程 ...
- JAVA多线程synchronized详解
Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码. 当两个并发线程访问同一个对象object中的这个synchronized(this)同 ...
- java中synchronized的用法详解
记下来,很重要. Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码. 一.当两个并发线程访问同一个对象object中的这个synchron ...
- JAVA关键词synchronized的作用
记下来,很重要. Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码. 一.当两个并发线程访问同一个对象object中的这个synchron ...
- java中synchronized的使用方法与具体解释
Java语言的keyword.当它用来修饰一个方法或者一个代码块的时候,可以保证在同一时刻最多仅仅有一个线程运行该段代码. 一.当两个并发线程訪问同一个对象object中的这个synchronized ...
- Java 中 synchronized的用法详解(四种用法)
Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码.本文给大家介绍java中 synchronized的用法,对本文感兴趣的朋友一起看看吧 ...
- java中 synchronized 的使用,确保异步执行某一段代码。
最近看了个有关访问网络url和下载的例子,里面有几个synchronized的地方,系统学习下,以下内容很重要,记下来. Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一 ...
随机推荐
- Linux修改终端显示前缀及环境变量
Linux终端前面默认显示一长串,如: [work@aaa.baidu.com dir]$ 这是由PS1环境变量决定的: [work@aaa.baidu.com dir]$ echo $PS1 [\u ...
- go语言之进阶篇单向channel的应用 (生产者,消费者模型)
1.单向channel的应用 示例: package main import ( "fmt" ) //此通道只能写,不能读 func producer(out chan<- ...
- iOS开发文件夹--Copy items if needed
蓝色文件夹 蓝色文件夹(folder)一般作为资源文件夹使用,与黄色文件夹的主要区别是不参与编译,所以说如果你在这些文件夹下编写的逻辑代码是不参与编译的,其他文件也不能直接引用它们,若引用其中文件需要 ...
- [leetcode]Pascal's Triangle II @ Python
原题地址:https://oj.leetcode.com/problems/pascals-triangle-ii/ 题意: Given an index k, return the kth row ...
- 用css3实现风车效果
前面讲过css3可以替代很多js实现的效果,其实很多时候纯css3甚至可以替代图片,直接用css3就可以画出一些简单的图片.虽然css3画出来的图片效果可能不如直接用图片的好,实现起来也比较复杂,最麻 ...
- redis调优 -- 内存碎片
最近查看了一下redis运行状况,发现公司测试服务器的redis内存不太够用,但是实际占用内存的数据量其实不大,以前也没有这种情况,之前在cache层新增了一个防刷积分任务的逻辑才会这样,搜索一下原因 ...
- String 转化Calendar
SimpleDateFormat sdf = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" ); Date dateExecute = s ...
- Centos安装gcc及g++
Centos支持yum安装,安装软件一般格式为yum install .......,注意安装时要先成为root用户. 按照这个思路,我想安装过程如下: 安装gcc:yum install gcc 安 ...
- 阿里云centos配置nginx和nodejs
今天新买了阿里云,想把网站跑起来,于是记录跑起来的过程 1.购买域名 2.购买解析 3.购买ecs主机 4.ssh登录主机 5.安装vsftpd 6.配置ftp用户.文件夹.权限 7.安装nginx/ ...
- mysql设置允许外网访问
1.设置mysql服务允许外网访问 修改mysql的配置文件,有的是my.ini,有的是my.cnf[linux],找到bind-address变量,这个值默认是127.0.0.1,设置为0.0.0. ...