上篇,我们提到了内存创建和释放带给长时间运行的服务器性能的损害问题。
当然还可能增加了CPU的相当的开销。
那么如何解决这个问题呢。
在这里只做一些讨论,具体实现,是你自己的事情。
到目前为止,我们能够做的都是管理一个内存池。
一开始,我们先分配好一批内存,把这批内存标注为空闲。
在客户端连接入来的时候,从空闲链表里面取第一个结构指针,填充内存。
Delete(0);删除空闲链表索引,是删除,不是释放,这个要记住。
然后使用一个正在使用链表来管理已经被调用的内存,使用ADD操作。
那么跟客户端断开连接后,将该释放的或者需要置Nil的对象处理之后。
从正在使用的链表删除该指针索引,然后把内存“归还”给空闲链表。
其实这个操作完全就是指针管理,效率如何,这个还要问????
实际内存分配好后,释放的时候只是标识释放而已,并没有返回给操作系统,不会带来内存碎片的问题了。而且CPU占用率肯定低很多。
也许大家说,一开始分配多少合适,看你自己的需要而定。
如果不够怎么办,不够就再分配了。
其实每一个服务器都有额定的连接数目限制。所以你可以设置一个合适你自己的数目,超过该数目,直接忽略就行,或者怎么做,你自己可以定。
如果一台服务器,我最多允许5000个连接,那么就设置为5000。超过后,发送信息给客户端,让它连接另外的服务器也行。
一般情况下,是不是这样操作???
总之,服务器编程,你必须管理内存池,这个是肯定的。除非你的服务器三头两天就重启一次。
没有内存池概念你就不要进服务器编程的范围。
至于具体做法,各人不同,都是按照自己的喜好来做,能够实现,没有内存泄露就行了。
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Browser-use 详细介绍&使用文档
· 软件产品开发中常见的10个问题及处理方法
· Vite CVE-2025-30208 安全漏洞