240 发简信
IP属地:河南
  • Java并发编程-线程池

    1.简介 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间。那么有没有一种办...

  • 120
    Java并发编程基础-并发容器ConcurrentHashMap

    1.简介 HashMap是Java程序员使用频率最高的用于映射(键值对)处理的数据类型。但HashMap不是线程安全的,即在多线程并发操作HashMap时可能会发生意向不到的...

  • 120
    Java并发编程-Java中的锁

    主要内容有:Lock接口队列同步器重入锁读写锁LockSupport工具Condition接口 1.Lock接口 锁是用来控制多个线程访问共享资源的方式。一般来说,一个锁能够...

  • 120
    Java并发编程基础线程

    (一)线程简介 线程是操作系统调度的最小单元,每个线程都拥有自己的计算器、堆栈和局部变量等属性,并且能够访问共享的内存变量。为什么要使用多线程可以参考Java多线程及线程池简...

  • 120
    Java并发机制的底层实现

    Java代码编译后会变成Java字节码,字节码被类加载器加载到JVM里,JVM执行字节码,最终需要转化为汇编指令在CPU上执行,Java中所使用的并发机制依赖于JVM的实现和...

  • 120
    深入理解JVM学习笔记-线程安全与锁优化

    线程安全 如果一个对象可以安全的被多个线程同时使用,那他就是线程安全的。当多线程访问一个对象时,如果不同考虑这些线程在运行时环境下的调度和交替执行,也不需要进行额外的同步,或...

  • 深入理解JVM学习笔记-Java内存模型与线程

    硬件效率与一致性:让计算机并发执行若干任务与更充分利用计算机处理器的效能之间的因果关系看起来顺利成章,实际上它们之间的关系并没有想象中的那么简单,由于计算机的存储设备与处理器...

  • 120
    深入理解JVM学习笔记-运行期优化

    Java程序最初是通过解释器进行解释执行的,当虚拟机发现某个方法或者代码块运行特别频繁时,就会把这些代码认定为热点代码,为了提高热点代码的执行效率,运行时虚拟机将会把热点代码...

  • 深入理解JVM学习笔记-编译期优化

    java编译期是一个不确定的操作过程,可能是以下三种场景:1.前段编译:将.java转变为.class文件的过程,如Javac。2.即时编译(just in time):虚拟...

  • 深入理解JVM学习笔记-类加载机制

    类加载机制:虚拟机把描述类的数据从Class文件加载到内存,并对数据进行校验、转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这就叫虚拟机的类加载机制。 类加载...

  • 120
    深入理解JVM学习笔记-类文件结构

    代码编译结果从本地机器码转变为字节码时存储格式发现的一小步,确实编程语言发现的一大步。 1.无关性的基石 计算机只认识0和1,我们编写的程序需要经编译器翻译成由0和1构成的二...

  • 120
    深入理解JVM学习笔记-垃圾收集器与内存分配策略

    垃圾回收需要完成三件事 (1)那些内存需要回收。(2)什么时候回收。(3)如何回收。上篇文章深入理解JVM学习笔记-Java内存区域与内存溢出异常中介绍了Java内存运行时区...

  • 120
    深入理解JVM学习笔记-Java内存区域与内存溢出异常

    运行时数据区域 Java虚拟机在执行java程序的过程中会将它所管理的内存划分为若干不同的数据区域,这些区域有各自用途,以及创建和销毁时间,有的区域随着虚拟机进程的启动而存在...

  • Retrofit源码解析

    Retrofit简介 Retrofit是一个基于OKHttp的RESTful网络请求框架。简单来说,Retrofit就是一个网络请求框架的封装。网络请求工作本质上是由OkHt...

  • Java多线程及线程池简介

    本文主要有以下三部分内容:第一部分:多线程有什么用?第二部分:线程池有什么用?第三部分:线程池相关好文章 多线程有什么用? (1)发挥多核CPU的优势:笔记本、台式机乃至商用...