码迷,mamicode.com
首页 > 其他好文 > 详细

当synchronized关键字和this关键字

时间:2017-05-14 21:57:30      阅读:173      评论:0      收藏:0      [点我收藏+]

标签:cep   错误   结果   同步   时代   except   current   通过   cat   

package cn.itcast_01_mythread.thread.testThread;


public class MyThreadWithImpliment_Synch_method implements Runnable {
    int x;

    public MyThreadWithImpliment_Synch_method(int x) {
        this.x = x;
    }

    
    public synchronized void queryCurrentTime(){        
        for (int i = 0; i < 10; i++) {
            String name = Thread.currentThread().getName();
            System.out.println("to "+name + " current is " + i);
            /*try {
                //Thread.sleep(100);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }*/
        }
        
    }
    
    @Override
    public void run() {
        String name = Thread.currentThread().getName();
        System.out.println("线程" + name + "的run方法被调用……");
        this.queryCurrentTime();
//queryCurrentTime();
    }

    public static void main(String[] args) {
        Thread thread1 = new Thread(new MyThreadWithImpliment_Synch_method(1), "thread-1");
        Thread thread2 = new Thread(new MyThreadWithImpliment_Synch_method(2), "thread-2");
         thread1.start();
         thread2.start();
        // 注意调用run和调用start的区别,直接调用run,则都运行在main线程中
//        thread1.run();
//        thread2.run();
    }
}

this.queryCurrentTime();//执行的结果,结果与预期的一样

线程thread-2的run方法被调用……
to thread-2 current is 0
to thread-2 current is 1
to thread-2 current is 2
to thread-2 current is 3
to thread-2 current is 4
to thread-2 current is 5
to thread-2 current is 6
to thread-2 current is 7
to thread-2 current is 8
to thread-2 current is 9
线程thread-1的run方法被调用……
to thread-1 current is 0
to thread-1 current is 1
to thread-1 current is 2
to thread-1 current is 3
to thread-1 current is 4
to thread-1 current is 5
to thread-1 current is 6
to thread-1 current is 7
to thread-1 current is 8
to thread-1 current is 9

queryCurrentTime();//执行的结果 与预期的不一样!!,好像就没有实现锁的功能

线程thread-1的run方法被调用……
线程thread-2的run方法被调用……
to thread-1 current is 0
to thread-2 current is 0
to thread-1 current is 1
to thread-2 current is 1
to thread-1 current is 2
to thread-2 current is 2
to thread-1 current is 3
to thread-2 current is 3
to thread-1 current is 4
to thread-2 current is 4
to thread-1 current is 5
to thread-2 current is 5
to thread-1 current is 6
to thread-2 current is 6
to thread-1 current is 7
to thread-2 current is 7
to thread-1 current is 8
to thread-2 current is 8
to thread-1 current is 9
to thread-2 current is 9

看疯狂java上说的,对于synchronized修饰的实例方法(非static方法)而言,无须显示指定同步监视器,同步方法监视器是this也就是调用该方法的对象。

所以我的理解是对于synchronized是站在对象的级别的,不是站在方法的级别的,如果直接在同一个类不通过this关键字调这个方法那么同步锁就没有加上同时代码不会报任何错误

ps:用的是jdk1.8

当synchronized关键字和this关键字

标签:cep   错误   结果   同步   时代   except   current   通过   cat   

原文地址:http://www.cnblogs.com/rocky-AGE-24/p/6853660.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!