首页
学习
活动
专区
工具
TVP
发布

木木玲

专栏成员
72
文章
86564
阅读量
29
订阅数
《 深入探索 JVM 》文集
嘿,笔者的个人博客已经孵化完成啦?,欢迎大家来逛逛。以后的文章也会在博客进行首发,快来关注我吧,我们继续一起探讨技术一同进步~ 《 深入探索 JVM 》文集 『类加载器』篇 深入浅出“类加载器” 之「
tomas家的小拨浪鼓
2019-12-13
6250
ClassLoader 源码详解
ClassLoader是一个类加载器对象,负责去加载类。ClassLoader是一个抽象对象。给定了一个类的“二进制名称”,一个类加载器需要尝试去定位或者生成一个数据,该数据构成了一个定义的类。一个典型的策略就是转换名字(即,二进制名字)成一个文件名,然后从文件系统读取这个文件名包含的“字节码文件”。 注意,这里有两种方式来通过一个“二进制名称”来加载一个类: ① 定位 也就是说,表示这个类的数据已经存在了,类加载器去定位到这个存储的数据进行加载即可。比如,java.lang.String就是在rt.jar中存储的了,可以直接定位到。 ② 生成 一些在java代码中动态生成的类,而这些类的数据就是在运行期时由类加载器去生成的。比如,动态代理。
tomas家的小拨浪鼓
2019-08-07
7810
深入探索“线程上下文类加载器”
Q: 越基础的类由越上层的加载器进行加载,如果基础类又要调用回用户的代码,那该怎么办? A: 解决方案:使用“线程上下文类加载器”
tomas家的小拨浪鼓
2019-08-06
1.9K1
深入浅出 ClassLoader
“加载”是类加载的时机的第一阶段。 类从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期包括(5个阶段): ① 加载(Loading) ② 连接(Linking)      [1] 验证(Verification)      [2] 准备(Preparation)      [3] 解析(Resolution) ③ 初始化(Initialization) ④ 使用(Using) ⑤ 卸载(Unloading)
tomas家的小拨浪鼓
2019-08-06
8030
大话 ThreadLocal
该类提供了线程本地变量。该变量不同于普通的副本,因为访问这个变量(通过 get 或 set 方法)的每个线程都是自己独立初始化该变量的。 ThreadLocal实例通常是Thread类中典型的静态私有属性,由于关联线程的状态(比如,user ID 或 Transaction ID)
tomas家的小拨浪鼓
2019-06-17
7300
“类加载机制”详解
概述 虚拟机的类加载机制:虚拟机把描述类的数据从Class文件加载到内存,并对数据进行校验、转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型。 类型的加载、连接和初始化过程都是在程序运行期间完成的。 缺点: 令类加载时稍微增加一些性能开销 优点: 为Java应用程序提供高度的灵活性。 Java里天生可以动态扩展的语言特性就是依赖运行期动态加载和动态连接这个特点实现的。 第一,后文中直接对“类”的描述都包括了类和接口的可能性,而对于类和接口需要分开描述的场景会特别指明; 第二,本章所提到
tomas家的小拨浪鼓
2018-06-27
9650
Java程序员必须掌握的网站知识 —— TCP
本文主要通过整理网络上的资料,整理出的关于TCP方面的简单理论知识。作为Java程序员虽然更多的时候我们都是直接调用现成的API,但是对网络知识有个宏观的概念能方便我们更好的编写代码。当然,文中涉及的
tomas家的小拨浪鼓
2018-06-27
1K0
Netty in Action ——— The codec framework
本文是Netty文集中“Netty in action”系列的文章。主要是对Norman Maurer and Marvin Allen Wolfthal 的 《Netty in action》一书简要翻译,同时对重要点加上一些自己补充和扩展。 本章含盖 解码器、编码器、编解码器综述 Netty 的编解码类 Netty提供可以简化各种协议的自定义编解码器创建的组件。 什么是编解码器? 每个网络应用都会定义端之间传输的二进制字节该如何被解析和转换,从发送端到目标程序的数据类型。这个转换逻辑通过编解码器来
tomas家的小拨浪鼓
2018-06-27
7260
Netty 源码解析 ——— NioEventLoop 详解
本文是Netty文集中“Netty 源码解析”系列的文章。主要对Netty的重要流程以及类进行源码解析,以使得我们更好的去使用Netty。Netty是一个非常优秀的网络框架,对其源码解读的过程也是不断学习的过程。 NioEventLoop 通过前面的学习,我们对NioEventLoop做过如下几点简单的概述: ① NioEventLoop是一个基于JDK NIO的异步事件循环类,它负责处理一个Channel的所有事件在这个Channel的生命周期期间。 ② NioEventLoop的整个生命周期只
tomas家的小拨浪鼓
2018-06-27
2.2K1
Netty 那些事儿 ——— 心跳机制
本文是Netty文集中“Netty 那些事儿”系列的文章。主要结合在开发实战中,我们遇到的一些“奇奇怪怪”的问题,以及如何正确且更好的使用Netty框架,并会对Netty中涉及的重要设计理念进行介绍。 什么是心跳机制? 心跳说的是在客户端和服务端在互相建立ESTABLISH状态的时候,如何通过发送一个最简单的包来保持连接的存活,还有监控另一边服务的可用性等。 心跳包的作用 保活 Q:为什么说心跳机制能保持连接的存活,它是集群中或长连接中最为有效避免网络中断的一个重要的保障措施? A:之所以说是“避
tomas家的小拨浪鼓
2018-06-27
2.7K0
Netty 源码解析 ——— Netty 优雅关闭流程
本文是Netty文集中“Netty 源码解析”系列的文章。主要对Netty的重要流程以及类进行源码解析,以使得我们更好的去使用Netty。Netty是一个非常优秀的网络框架,对其源码解读的过程也是不断学习的过程。 Netty的优雅关闭操作 Netty是通过『eventLoopGroup.shutdownGracefully()』操作来实现它的优雅关闭的。 我们先来看下shutdownGracefully方法的doc说明: /** * Signals this executor tha
tomas家的小拨浪鼓
2018-06-27
3.1K0
Netty 源码解析 ——— AdaptiveRecvByteBufAllocator
本文是Netty文集中“Netty 源码解析”系列的文章。主要对Netty的重要流程以及类进行源码解析,以使得我们更好的去使用Netty。Netty是一个非常优秀的网络框架,对其源码解读的过程也是不断学习的过程。 AdaptiveRecvByteBufAllocator主要用于构建一个最优大小的缓冲区来接收数据。比如,在读事件中就会通过该类来获取一个最优大小的的缓冲区来接收对端发送过来的可读取的数据。 关于AdaptiveRecvByteBufAllocator的分析,会通过一层层的Java doc来
tomas家的小拨浪鼓
2018-06-27
1.3K0
Netty 源码解析 ——— 服务端启动流程 (下)
本文是Netty文集中“Netty 源码解析”系列的文章。主要对Netty的重要流程以及类进行源码解析,以使得我们更好的去使用Netty。Netty是一个非常优秀的网络框架,对其源码解读的过程也是不断学习的过程。 本文接Netty 源码解析 ——— 服务端启动流程 (上)继续解析Netty服务器启动流程的剩下步骤 重要类介绍 在讲解源码之前,同样我们先对该篇文字这涉及到的几个Netty中的重要的类进行简单的介绍。 ChannelFuture ChannelFuture是针对于Channel的一个Fut
tomas家的小拨浪鼓
2018-06-27
1.2K0
Netty 源码解析 ——— 服务端启动流程 (上)
本文是Netty文集中“Netty 源码解析”系列的文章。主要对Netty的重要流程以及类进行源码解析,以使得我们更好的去使用Netty。Netty是一个非常优秀的网络框架,对其源码解读的过程也是不断
tomas家的小拨浪鼓
2018-06-27
8900
Netty in Action ——— Netty的组件和设计
本文是Netty文集中“Netty in action”系列的文章。主要是对Norman Maurer and Marvin Allen Wolfthal 的 《Netty in action》一书简要翻译,同时对重要点加上一些自己补充和扩展。 本章涵盖 Netty的技术和结构方面 Channel、EventLoop和ChannelFuture ChannelHandler和ChannelPipeline 引导 Channel,EventLoop,and ChannelFuture 下面我们将
tomas家的小拨浪鼓
2018-06-27
7970
PriorityQueue 源码分析
PriorityQueue 一个无限的优先级队列基于一个优先级堆。优先级队列中的元素根据它们的Comparable自然顺序或通过在队列构造时提供的Comparator来排序。(如果有Comparator就根据Comparator来对元素进行排序,否则根据元素自己的Comparable来进行排序)。一个优先级队列不允许‘null’元素。一个依赖自然排序的优先级队列甚至不允许插入一个不可比较(non-comparable)的对象(如果你插入一个non-comparable对象,则会抛出一个ClassCastEx
tomas家的小拨浪鼓
2018-06-27
1.4K0
设计模式 ——— 中介者模式
意图 用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。 中介者模式的本质:封装交互。 适用性 如果一组对象之间的通信方式比较复杂,导致相互依赖、结构混乱,可以采用中介者模式,把这些对象相互的交互管理起来,各个对象都只需要和中介者交互,从而使得各个对象松散耦合,结构也更清晰易懂。 如果一个对象引用很多的对象,并直接跟这些对象交互,导致难以复用该对象。可以采用中介者模式,把这个对象跟其它对象的交互封装到中介者对象里面,这个对象就
tomas家的小拨浪鼓
2018-06-27
5580
Netty in action ——— 事件循环 和 线程模式
本文是Netty文集中“Netty in action”系列的文章。主要是对Norman Maurer and Marvin Allen Wolfthal 的 《Netty in action》一书简要翻译,同时对重要点加上一些自己补充和扩展。 概要 线程模式概述 事件循环概念和实现 定时任务 实现细节 线程模型概述 一个基于线程池的模式可以描述为: 从池的空闲队列中选择一个线程,并将该线程分配以运行一个提交上来的任务( 任务实现了Runnable接口 )。 当任务完成,线程返回给队列,并可用
tomas家的小拨浪鼓
2018-06-27
8280
堆外内存 之 DirectByteBuffer 详解
堆外内存 堆外内存是相对于堆内内存的一个概念。堆内内存是由JVM所管控的Java进程内存,我们平时在Java中创建的对象都处于堆内内存中,并且它们遵循JVM的内存管理机制,JVM会采用垃圾回收机制统一管理它们的内存。那么堆外内存就是存在于JVM管控之外的一块内存区域,因此它是不受JVM的管控。 在讲解DirectByteBuffer之前,需要先简单了解两个知识点 java引用类型,因为DirectByteBuffer是通过虚引用(Phantom Reference)来实现堆外内存的释放的。 Phant
tomas家的小拨浪鼓
2018-06-27
2.5K0
Java 引用类型简述
强引用 ( Strong Reference ) 强引用是使用最普遍的引用。如果一个对象具有强引用,那垃圾回收器绝不会回收它。当内存空间不足,Java虚拟机宁愿抛出OutOfMemoryError错误,使程序异常终止,也不会靠随意回收具有强引用的对象来解决内存不足的问题。 ps:强引用其实也就是我们平时A a = new A()这个意思。 强引用特性 强引用可以直接访问目标对象。 强引用所指向的对象在任何时候都不会被系统回收。 强引用可能导致内存泄漏。 Final Reference 当前类是否是
tomas家的小拨浪鼓
2018-06-27
7290
点击加载更多
社区活动
【纪录片】中国数据库前世今生
穿越半个世纪,探寻中国数据库50年的发展历程
Python精品学习库
代码在线跑,知识轻松学
博客搬家 | 分享价值百万资源包
自行/邀约他人一键搬运博客,速成社区影响力并领取好礼
技术创作特训营·精选知识专栏
往期视频·千货材料·成员作品 最新动态
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档