架构师训练营作业

用户头像
邵帅
关注
发布于: 2020 年 07 月 29 日

垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供的一种用于在空闲时间不定时回收无任何对象引用的对象占据的内存空间的一种机制。

会在cpu空闲的时候自动进行回收

在堆内存存储满了之后  

主动调用System.gc()后尝试进行回收

补充:System.gc()用于调用垃圾收集器,在调用时,垃圾收集器将运行以回收未使用的内存空间。它将尝试释放被丢弃对象占用的内存。 然而System.gc()调用附带一个免责声明,无法保证对垃圾收集器的调用。  所以System.gc()并不能说是完美主动进了垃圾回收。

引用计数法

简单的来说就是判断对象的引用数量。实现方式:给对象共添加一个引用计数器,每当有引用对他进行引用时,计数器的值就加1,当引用失效,也就是不在执行此对象,它的计数器的值随之减1,若某一个对象的计数器的值为0,那么表示这个对象没有被其他对象引用,也就是意味着是一个失效的垃圾对象,就会被gc进行回收。 但是这种简单的算法在当前的jvm中并没有采用,原因是他并不能解决对象之间循环引用的问题。 假设有A和B两个对象之间互相引用,也就是说A对象中的一个属性是B,B中的一个属性时A,这种情况下由于他们的相互引用,从而垃圾回收机制无法识别。

可达性分析算法(根搜索算法)

通过一系列名为GC Roots的对象作为起点,从这些节点往下搜索,搜索走过的路径称为引用链。当一个对象到GC Roots没有任何引用链相连时(意味着GC Roots到这个对象不可达),证明该对象是不可用的,则应该被回收



秒杀系统的特点在于

流量在秒杀开始的时刻一段时间是流量暴增的,因此业务的扩展性和数据的一致性就很关键

前端部署性能强劲的负载均衡,将系统分解成不同的服务,在秒杀前提前准备将服务扩容,这样就可以确保系统有足够的容量处理,同时由于物品有限,因此可以要确保数据和事务的一致性就尤为关键

用户头像

邵帅

关注

还未添加个人签名 2017.10.29 加入

还未添加个人简介

评论

发布
暂无评论
架构师训练营作业