原创 编程语言 详解gc(垃圾回收)机制五:GC标记-压缩算法 GC标记-压缩算法gc标记-压缩算法是 详解gc(垃圾回收)机制三:GC复制算法 和 详解gc(垃圾回收)机制四:GC标记-清除算法 结合的产物可以看到,从此章开始,gc算法从一个独立的,变成了多个组合方式的,大多数有着垃圾回收的语言,都是使用了多个gc算法组合进行的gc步骤1:遍历所有的活动对象,并且标记2:设定s 2022-11-28 浏览(1) 评论(0) 阅读全文
原创 编程语言 详解gc(垃圾回收)机制四:GC标记-清除算法 标记-清除算法GC标记-压缩算法由标记阶段和清除阶段构成我们在详解gc(垃圾回收)机制(一) 简单说明了 标记-清除算法gc步骤:1:暂停程序业务逻辑,对所有对象进行标记分类2:找出程序可达对象和不可达对象3:删除不可达对象标记清除算法就是如此简单明了,不会出现循环引用的问题,但是标记清除算法需要暂停程序,会造成程序卡顿同时每次标记都需要扫描整个堆内存空间步骤一:遍历根引用 2022-11-28 浏览(1) 评论(0) 阅读全文
原创 编程语言 详解gc(垃圾回收)机制三:GC复制算法 在前2篇中,我们大致了解了语言的gc,以及gc的基本概念详解gc(垃圾回收)机制(一) 详解gc(垃圾回收)机制二:认识GC基本概念 gc算法大致分为以下几种:1:标记-清除2:引用计数法3:GC复制4:GC标记-压缩5:保守GC6:分代垃圾回收7:增量式垃圾回收8:RC Immix在第一篇文章,有讲到 标记-清除,引用计数,以及go的特色 三色标记法.GC复制算法GC复制简单来说,就 2022-11-23 浏览(1) 评论(0) 阅读全文
原创 编程语言 详解gc(垃圾回收)机制二:认识GC基本概念 对象"对象"这个词,在面对对象编程中,它指的是"具有属性和行为的事物",而在GC的世界中,对象表示的是:"通过应用程序利用的数据的集合"对象配置在内存空间里,GC根据情况将配置好的对象进行移动或者销毁,因此,对象是GC的基本单位.一般来说,对象由 头(header) 和域(field)构成头保存对象本身信息的部位称为 "头&qu 2022-10-26 浏览(1) 评论(0) 阅读全文
原创 编程语言 详解gc(垃圾回收)机制(一) 虚拟内存进程在运行时,所操作的内存就是虚拟内存,每个进程之间的虚拟内存互相独立,通过 MMU 内存管理技术再映射到物理内存中,同时,虚拟内存空间块分为:栈内存栈内存在函数中定义的一些基本类型的变量和对象的引用变量都在函数的栈内存中分配。在调用栈结束后将会自动回收#include<stdio.h>#include<stdlib.h>void test() 2022-08-24 浏览(1) 评论(0) 阅读全文
原创 编程语言 int转字符串实现方法 抖音的分享链接一般为: https://v.douyin.com/JGoSFt2/那么后面那串 JGoSFt2 是什么呢?其实后面那串为分享id转字符串,原始数据可能为 :1091566355946 ,通过特定算法转换为了更短的字符串实现代码为:<?phpnamespace EasySwoole\Utility;c 2021-02-25 浏览(1) 评论(0) 阅读全文
转载 redis Redis数据淘汰算法 众所周知,Redis的所有数据都存储在内存中,但是内存是一种有限的资源,所以为了防止Redis无限制的使用内存,在启动Redis时可以通过配置项 maxmemory 来指定其最大能使用的内存容量。例如可以通过以下配置来设置Redis最大能使用 1G 内存:maxmemory 1G当Redis使用的内存超过配置的 maxmemory 时,便会触发数据 2020-12-05 浏览(1) 评论(0) 阅读全文
转载 php 唯一ID生成原理与PHP实现-雪花算法 snowflake算法虽然PHP提供了一个生成唯一ID的函数uniqid(),但这个函数真的可以生成唯一ID吗?我们来看看uniqid()的具体实现:PHP_FUNCTION(uniqid){ ... gettimeofday((struct timeval *) &t 2020-12-05 浏览(1) 评论(0) 阅读全文
原创 编程语言 最长公共子串- LCS 算法 最长子字符串算法#!/usr/bin/python# coding:utf-8def action (str1,str2): pass #转为utf-8编码,一个中文字长度占用1 str1 = 2020-10-24 浏览(1) 评论(0) 阅读全文