微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

谈谈对java的理解

1、java一次编译,到处执行----跨平台

2、gc

3、jre和jdk 区别:

    jre(java runtime environment)java运行环境,包含jvm的client,类库(rt.jar:常用的集合、io、math、lang等都在rt.jar包内)

    jdk(java development kit)Java开发工具,包含jre(含jvm的client和server)及编译器(javac)、诊断工具(jconsole.exe等)

4、java基础类库:(java开头)

    java.lang(exception/string/stringbuffer/Integer等封装类/math/annotion)

    java.util(concurrent/regex正则表达式/collection/日期date calendar)

参考 https://blog.csdn.net/basycia/article/details/50769838

5、java常用第三方类库:(javax开头)

    javax.swing、javax.naming

6、cas原理

java.util.concurrent包下的类都使用的是cas原理实现并发,例如 automicInteger、concurrentHashMap

主存A,线程缓存数据B,更新值C,只有当B=A时,才会将    C赋值给A。

7、并发特性,可用syn、lock方式实现

原子性

有序性:jvm执行java代码时在保证不影响运行结果情况下会进行指令重排,有序性是避免指令重排。

内存可见

8、volatile关键字

可保证内存可见:线程A修改后立即将数据写入主内存。

有序性:修饰的关键字不被指令重排。保证在执行关键字相关操作时,之前的代码已经执行,之后的代码还未执行,但不能保证关键字之前和之后代码的顺序性。

不能保证原子性。

volatile一个典型的应用场景是 单例模式

class Singleton{
    private volatile static Singleton instance = null;
 
    private Singleton() {
 
    }
 
    public static Singleton getInstance() {
        if(instance==null) {
            synchronized (Singleton.class) {
                if(instance==null)
                    instance = new Singleton();
            }
        }
        return instance;
    }
}

为什么单例模式需要使用volatile修饰?

主要在于instance = new Singleton()这句,这并非是一个原子操作,事实上在 JVM 中这句话大概做了下面 3 件事情:

1.给 instance 分配内存

2.调用 Singleton 的构造函数来初始化成员变量

3.将instance对象指向分配的内存空间(执行完这步 instance 就为非 null 了)。

但是在 JVM 的即时编译器中存在指令重排序的优化。也就是说上面的第二步和第三步的顺序是不能保证的,最终的执行顺序可能是 1-2-3 也可能是 1-3-2。如果是后者,则在 3 执行完毕、2 未执行之前,被线程二抢占了,这时 instance 已经是非 null 了(但却没有初始化),所以线程二会直接返回 instance,然后使用,然后顺理成章地报错。

参考: 

你真的了解volatile关键字吗?

深入浅出CAS

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐