[Indy]用Indy做很卡 ?

cdisk 2008-04-04 12:36:01
我做了一个C/S程序 但是客户端会一卡一卡的 .. 不知道你们的会不会 ? 或者有什么解决办法吗 ?
...全文
115 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
cdisk 2008-04-05
  • 打赏
  • 举报
回复
我放弃用indy做客户端了....
getit911 2008-04-05
  • 打赏
  • 举报
回复
放到线程里就不卡了,Indy是阻塞式的,收到数据才会执行下条语句,不需要额外的监听功能。
ideation_shang 2008-04-05
  • 打赏
  • 举报
回复
C\S and Indy,你做的什么程序?什么网络环境?
dl110 2008-04-05
  • 打赏
  • 举报
回复
用起来挺简单的.
dl110 2008-04-05
  • 打赏
  • 举报
回复
在Form的uses中引用winsock就可以了.
具体使用查看相关联机帮助.这是个API.
cdisk 2008-04-05
  • 打赏
  • 举报
回复
单一的两点相连.. 我想弄服务器那种 ..winsock不知道在哪弄阿 .我想弄个可以发广播的 .
就是多个用户连到一台机器上 ..
cdisk 2008-04-04
  • 打赏
  • 举报
回复
请问多线程要怎么做呢? 还有 idtcpclient当有数据进来时没有触发阿 。??
dl110 2008-04-04
  • 打赏
  • 举报
回复
idtcpclient好像没有监听功能,估计需使用winsock来做.
喝口水 2008-04-04
  • 打赏
  • 举报
回复
你做成多线程的,就一点都不卡了
使用TIdAntiFreeze对抗“冻结”   Indy使用一个特殊的组件TIdAntiFreeze来透明地解决客户程序用户界面“冻结”的问题。TIdAntiFreeze在Indy内部定时中断对栈的调用,并在中断期间调用Application.ProcessMessages方法处理消息,而外部的Indy调用继续保存阻塞状态,就好像TIdAntiFreeze对象不存在一样。你只要在程序中的任意地方添加一个TIdAntiFreeze对象,就能在客户程序中利用到阻塞式Socket的所有优点而避开它的一些显著缺点。   Indy使用了线程技术   阻塞式Socekt通常都采用线程技术,Indy也是如此。从最底层开始,Indy的设计都是线程化的。因此用Indy创建服务器和客户程序跟在Unix下十分相似,并且Delphi的快速开发环境和Indy对WinSock的良好封装使得应用程序创建更加容易。   Indy服务器模型   一个典型的Unix服务器有一个或多个监听进程,它们不停地监听进入的客户连接请求。对于每一个需要服务的客户,都fork一个新进程来处理该客户的所有事务。这样一个进程只处理一个客户连接,编程就变得十分容易。   Indy服务器工作原理同Unix服务器十分类似,只是Windows不像Unix那样支持fork,而是支持线程,因此Indy服务器为每一个客户连接分配一个线程。   图1显示了Indy服务器的工作原理。Indy服务器组件创建一个同应用程序主线程分离的监听线程来监听客户连接请求,对于接受的每一个客户,都创建一个新的线程来为该客户提供服务,所有与这一客户相关的事务都由该线程来处理。   使用组件TIdThreadMgrPool,Indy还支持线程池。   线程与Indy客户程序   Indy客户端组件并未使用线程。但是在一些高级的客户程序中,程序员可以在自定义的线程中使用Indy客户端组件,以使用户界面更加友好。

1,594

社区成员

发帖
与我相关
我的任务
社区描述
Delphi 网络通信/分布式开发
社区管理员
  • 网络通信/分布式开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧