indy之道
TIdAntiFreeze工作原理:在内部定时停止堆栈调用、然后调用Application.ProcessMessages。
Indy支持线程pooling。可以用TIdThreadMgrPool组件利用线程pooling
数以百计的线程对于一个忙碌的服务器,可能需要数以百计、千计的线程。人们普遍误解
如此多的线程将立刻使系统当掉。其实不然。
对于多数服务器而言,线程存在期的多数时间用于等待数据。在等待
blocking调用时,线程是不活动的。所以,在一个拥有500个线程的服务器中,可
能只有50个同时活动的线程。在我的系统上,330个线程只耗费1%的CPU时间。
线程与全局Section
当线程需要存取数据时,都必须获取对数据的控制权以保护数据完整性。
对于初学线程编程的人士,这恐怕有些头疼。不过多数服务器并不需要全局数据。
每个线程执行隔离的任务。
Indy之道
Indy与你所熟悉的其它Winsock组件不同。如果你曾经使用过其它组件,
最好是彻底忘记它们是如何工作的。几乎所有其它组件都是non-blocking,以
异步方式调用。你需要对事件进行回应,设置状态机,且常常要进行等待循环。
例如,使用其它组件,当进行连接时,必须等待connect事件发生,或者
循环至被告知已连接。而在Indy中,你简单调用connect,然后等待它返回。
如果连接失败,则引发一个异常。使用Indy非常相似于操作文件。代码可以放
置于一个地方,而无需切割到各种事件代码中。
Indy有何不同
简述
1、使用blocking调用
2、不依赖事件——Indy拥有事件(处于提供信息的考虑),但并非必须。
3、被设计为支持线程——无需进行额外的线程化工作。
Indy天生支持线程。在Windows中用Indy编写服务器或客户端与在Unix平
台上编写服务器或客户端相似,甚至更加简单。
典型的Unix服务器有一个或多个“监听”进程,查找客户端请求。对于每
个客户端,都要创建一个新进程。
Indy以简单的方式工作。Windows能较好地处理线程。Indy服务器为每个
客户端锁定一个线程。
Indy服务器建立一个与主线程分离的监听线程。监听线程等待客户端请
求。对于每个连接的客户端,产生一个新线程为其服务。然后,在线程上下文
中引发适当的事件。
本文来自博客园,作者:{咏南中间件},转载请注明原文链接:https://www.cnblogs.com/hnxxcxg/archive/2008/11/27/2940787.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?