摘要: JVM堆相关知识 为什么先说JVM堆? JVM的堆是Java对象的活动空间,程序中的类的对象从中分配空间,其存储着正在运行着的应用程序用到的所有对象。这些对象的建立方式就是那些new一类的操作,当对象无用后,是GC来负责这个无用的对象(地球人都知道)。 JVM堆 (1) 新域:存储所有新成生的对象 阅读全文
posted @ 2018-03-02 17:54 stanljj 阅读(271) 评论(0) 推荐(0) 编辑
摘要: Netty是一个高性能、异步事件驱动的NIO框架,基于JAVA NIO提供的API实现 ChannelEvent 先说这个ChannelEvent,因为Netty是基于事件驱动的,就是我们上文提到的,发生什么事,就通知"有关部门"。所以,不难理解,我们自己的业务代码中,一定有跟这些事件相关的处理。在 阅读全文
posted @ 2018-03-02 17:53 stanljj 阅读(158) 评论(0) 推荐(0) 编辑
摘要: 首先说Java编程语言,它是一门高级编程语言,具体由谁何时创建的,读者可以到网上查找相关资料,这里就不再赘述。那么,谈到Java就不得不谈谈JVM、JRE和JDK三者间的区别和联系。 JVM:英文全称Java Virtual Machine,字面意思“Java虚拟机”,简单来说就是一个软件。一个什么 阅读全文
posted @ 2018-03-02 17:50 stanljj 阅读(531) 评论(0) 推荐(0) 编辑
摘要: 著名的CAP理论指出,一个分布式系统不可能同时满足C(一致性)、A(可用性)和P(分区容错性)。由于分区容错性在是分布式系统中必须要保证的,因此我们只能在A和C之间进行权衡。在此Zookeeper保证的是CP, 而Eureka则是AP。 4.1 Zookeeper保证CP 当向注册中心查询服务列表时 阅读全文
posted @ 2018-03-02 17:49 stanljj 阅读(249) 评论(0) 推荐(0) 编辑
摘要: 在分布式网络系统中,缓存更是无处不在:(1)对静态页面的缓存;(2)服务端对某些请求数据的缓存(包括本地缓存和分布式缓存);(3)客户端对服务器端数据的缓存,例如我们的头像等信息; 使用缓存带来的问题: 缓存何时写入? 缓存如何失效? 缓存和DB的一致性如何保证? 多级缓存有什么最佳实践? 如何避免 阅读全文
posted @ 2018-03-02 17:49 stanljj 阅读(156) 评论(0) 推荐(0) 编辑
摘要: Java虚拟机把描述类的数据从Class文件加载到内存,并对数据进行校验、转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这就是虚拟机的加载机制。 类从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期包括了:加载(Loading)、验证(Verification)、准备(P 阅读全文
posted @ 2018-03-02 17:48 stanljj 阅读(154) 评论(0) 推荐(0) 编辑
摘要: 在数据结构中,堆和栈可以说是两种最基础的数据结构,而Java中的栈内存空间和堆内存空间有什么异同,以及和数据结构中的堆栈有何关系? 一、Java 堆存储空间 堆内存(堆存储空间)会在Java运行时分配给对象(Object)或者JRE的类。只要我们创建了一个对象,那么在堆中肯定会分配一块存储空间给这个 阅读全文
posted @ 2018-03-02 17:46 stanljj 阅读(212) 评论(0) 推荐(0) 编辑
摘要: ThreadLocal是用来维护线程中的变量不被其他线程干扰而出现的一个结构,内部包含一个ThreadLocalMap类,该类为Thread类的一个局部变量,该Map存储的key为ThreadLocal对象自身,value为我们要存储的对象,这样一来,在不同线程中,持有的其实都是当前线程的变量副本, 阅读全文
posted @ 2018-03-02 17:44 stanljj 阅读(139) 评论(0) 推荐(0) 编辑
摘要: HashMap基于hashing原理,我们通过put()和get()方法储存和获取对象。当我们将键值对传递给put()方法时,它调用键对象的hashCode()方法来计算hashcode,让后找到bucket位置来储存值对象。当获取对象时,通过键对象的equals()方法找到正确的键值对,然后返回值 阅读全文
posted @ 2018-03-02 17:34 stanljj 阅读(341) 评论(0) 推荐(0) 编辑
摘要: Redis 存储的五种 字符串类型:string 一个String类型的value最大可以存储512M String是最常用的一种数据类型,普通的key/value存储. 散列类型: hash 键值对个数最多为2^32-1个,也就是4294967295个。 类似于表记录的存储 页面视图所需数据的存储 阅读全文
posted @ 2018-03-02 17:23 stanljj 阅读(151) 评论(0) 推荐(0) 编辑