「每日一问」并发编程的特性是什么?

    技术2022-07-10  193

    原子性

    原子性(Atomicity)是指:在一次或者多次操作时,要么所有操作都被执行,要么所有操作都不执行。

    在Java内存模型中,只保证了基本读取和赋值的原子性操作。如果想保证多个操作的原子性,需要使用synchronized关键字或者Lock相关的工具类。如果想要使int、long等类型的自增操作具有原子性,可以用java.util.concurrent.atomic包下的工具类,如:AtomicInteger、AtomicLong等。另外需要注意的是,volatile关键字不具有保证原子性的语义。

    可见性

    可见性(Visibility)是指:当一个线程对共享变量进行修改后,另外一个线程可以立即看到该变量修改后的最新值。

    可以使用volatile、synchronized关键字和Lock相关的工具类保证可见性。

    有序性

    有序性(Ordering)是指:程序执行的顺序按照代码的先后顺序执行。

    除了Happens-Before原则提供的天然有序性,我们还可以使用volatile、synchronized关键字和Lock相关的工具类保证有序性。

    参考答案

    原子性、可见性、有序性

    文章持续更新,微信搜索「 万猫学社 」第一时间阅读。 关注后回复「 电子书 」,免费获取12本Java必读技术书籍。

    万猫学社 认证博客专家 资深Java开发 更多文章持续更新中,微信公众号搜索「 万猫学社 」第一时间阅读。关注后回复「 电子书 」,即可免费获取12本Java必读技术书籍。
    Processed: 0.015, SQL: 9