内存的管理
由于Java,Go等等语言都采用了自动内存管理机制。不用显式管理内存,简化了编程,提高了编程的效率,解决了内存泄漏的问题。但是由于对软件需求的提高,高并发,高吞吐,和不规范的编程等等,会导致内存的泄露。
自动内存管理机制
自动内存管理机制主要考虑内存的申请和内存的回收。
- 内存的申请:
1.计算创建对象内存占用空间的大小。
2.在内存连续且空闲的空间,通过对象的大小,标志使用。
3.将引用指向内存中物理地址。 - 内存的回收
1.首先需要找到需要回收的对象,将回收对象的内存空间标志为空闲,期间为了确保对象回收的准确性,需要暂停进程。
2.其次对回收后的内存进行碎片的整理。
内存的回收相对于内存的申请复杂的多。
内存泄漏
在高并发的场景中,大量的请求进入,有请求对象,响应对象,还有期间业务逻辑处理的对象。这些对象在完成响应之后就停留在内存中等待回收。虽然垃圾回收的时机有多种策略。但是只要内存FULL就会回收。
当内存满了回收,这时的内存回收就需要较长时间的进程暂停。导致大量的请求阻塞,当完成内存回收后,又有大量的请求进入,迅速填满内存,导致恶性循环。当创建对象速度大于回收速度时就可能会导致泄漏。