【技术干货】Java小知识


    Java作为大数据技术的必备基础编程语言,是想要转行学习大数据的小伙伴必须要熟练掌握的一项技术。今天科妹就为大家带来了Java里的小知识点讲解。
    
    1.类加载子系统的作用:根据给定的全限定名类名(如java.lang.Object)来装载class文件的内容到运行时数据区中的方法区
    2.双亲委派机制:当一个类收到了类加载请求时,不会自己先去加载这个类,而是将其委派给父类,由父类去加载,如果此时父类不能加载,反馈给子类,由子类去完成类的加载。
    3.类加载过程:加载、链接(验证准备解析)、初始化
    加载阶段,虚拟机需要完成以下3件事情:
    1)通过一个类的全限定名来获取定义此类的二进制字节流(并没有指明要从一个Class文件中获取,可以从其他渠道,譬如:网络、动态生成、数据库等)。
    2)将这个字节流所代表的静态存储结构转化为方法区的运行时数据结构。
    3)在内存中生成一个代表这个类的java.lang.Class对象,作为方法区这个类的各种数据的访问入口。
    验证阶段大致会完成4个阶段的检验动作:
    1)文件格式验证
    2)元数据验证
    3)字节码验证
    4)符号引用验证
    准备阶段是正式为类变量分配内存并设置类变量初始值的阶段,这些变量所使用的内存都将在方法区中进行分配。
    解析阶段是虚拟机将常量池内的符号引用替换为直接引用的过程。
    在初始化阶段,则根据程序猿通过程序制定的主观计划去初始化类变量和其他资源,或者说:初始化阶段是执行类构造器()方法的过程。
    
    栈的内存要远远小于堆内存
    -Xss选项设置栈内存的大小。
    -Xms选项可以设置堆的开始时的大小,-Xmx选项可以设置堆的最大值。
    
    在Java中,每一个对象都拥有一个锁标记(锁),也称为监视器,多线程同时访问某个对象时,线程只有获取了该对象的锁才能访问。
    Lock和synchronized有以下几点不同
    1)Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现;
    2)采用synchronized不需要用户去手动释放锁,当synchronized方法或者synchronized代码块执行完后,系统会自动让线程释放对锁的占用;synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock时需要在finally块中释放锁;
    3)响应中断Lock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断;
    4)Lock可以是否获取锁,synchronized不行。
    5)Lock可以提高多个线程进行读操作的效率。
    6) 公平锁Lock可以设置为公平锁,synchronized就是非公平锁
    单独调用interrupt()方法不能中断正在运行过程中的线程,只能中断阻塞过程中的线程。
    当通过lockInterruptibly()方法获取某个锁时,如果不能获取到,只有进行等待的情况下,是可以响应中断的(线程B调用threadB.interrupt()方法能够中断线程B的等待过程)。
    而用synchronized修饰的话,当一个线程处于等待某个锁的状态,是无法被中断的,只有一直等待下去。
    Java作为大数据技术的重要基础语言,大家一定要牢牢掌握住它的知识点,为自己的将来打好基础。
    更多大数据相关资讯,欢迎关注成都科多大数据微信公众号。