synchronized方法对非synchronized方法有哪些影响

StringBuilder是线程不安全的类。

StringBuffer是线程安全的,因为它里面的方法加了synchronized。

今天写了一段代码测试了一下:用循环开启10个线程,调用StringBuffer(StringBuilder)的append追加1 到 10 。

结果预期一样:线程不安全的StringBuilder会漏掉一些数字,

public static void main(String[] args) throws InterruptedException {        StringBuffer buffer = new StringBuffer();        StringBuilder builder = new StringBuilder();        // 开启十个线程,分别对buffer 和 builder 操作                for(int i = 0; i < 10; i++) {                        int j = i;                        new Thread(new Runnable() {                            public void run() {                                try {                        Thread.sleep(500); //造成阻塞                    } catch (InterruptedException e) {                        e.printStackTrace();                    }                    builder.append(j);                }            }).start();        }        //等待以上操作完成        Thread.sleep(1000);        // 打印结果        System.out.println("builder:"+builder);    }

线程安全的StringBuffer则追加了全部10个数字:

public static void main(String[] args) throws InterruptedException {    StringBuffer buffer = new StringBuffer();    StringBuilder builder = new StringBuilder();    // 开启十个线程,分别对buffer 和 builder 操作            for(int i = 0; i < 10; i++) {                int j = i;                new Thread(new Runnable() {                    public void run() {                        try {                    Thread.sleep(500); //造成阻塞                } catch (InterruptedException e) {                    e.printStackTrace();                }                buffer.append(j);            }        }).start();    }    //等待以上操作完成    Thread.sleep(1000);    // 打印结果    System.out.println("buffer:"+buffer);}

这时:如果我同时操作builder和buffer,且先调用buffer的append,这时每次操作因为builder和buffer在同一个线程,builder的方法因为buffer阻塞了线程而被变成“同步”的方法,同样append了10个数字

public static void main(String[] args) throws InterruptedException {    StringBuffer buffer = new StringBuffer();    StringBuilder builder = new StringBuilder();    // 开启十个线程,分别对buffer 和 builder 操作            for(int i = 0; i < 10; i++) {                int j = i;                new Thread(new Runnable() {                    public void run() {                        try {                    Thread.sleep(500); //造成阻塞                } catch (InterruptedException e) {                    e.printStackTrace();                }                buffer.append(j);                builder.append(j);            }        }).start();    }    //等待以上操作完成    Thread.sleep(1000);    // 打印结果    System.out.println("buffer:"+buffer);    System.out.println("builder:"+builder);}

以上就是synchronized方法对非synchronized方法有哪些影响的详细内容,更多请关注其它相关文章!

用最少的悔恨面对过去

synchronized方法对非synchronized方法有哪些影响

相关文章:

你感兴趣的文章:

标签云: