转发地址:http://blog.csdn.net/cowcga/article/details/6198382

关于TIdTCPClient的几种方法 收藏 其实Indy比较简单,但是可以提供的方法太多了。我找了很久,才搞明白。

比方说这个读取缓冲区的数据,就有很多种方法。相对于TTcpClient的几种方法来说,TIdTCPClient确实提供了多种选择,不仔细研究真的容易糊涂(其实我比较喜欢用CurrentReadBuffer):

1、ReadFromStack 原型:function ReadFromStack(const ARaiseExceptionIfDisconnected: boolean; const ATimeout: integer; const AUseBuffer: boolean; ADestStream: TIdBuffer): integer; virtual; 用于判断缓冲区里是否还有数据可读,返回值:Integer - Number of bytes read.

2、CurrentReadBuffer 原型:function CurrentReadBuffer: string; 用于读取Socket数据到缓冲区,注意返回为String类型,如果直接显示该String的数据,对于/0之后的数据可能看不到,因此要读取所有的数据,还必须利用CurrentReadBufferSize()判断该String的长度。 返回值:String - Contents of the Indy buffer.

3、GetResponse 原型:function GetResponse(const AAllowedResponses: Array of SmallInt): SmallInt; virtual; 对于简单的命令应答可以使用这个方法获取应答消息,返回值:SmallInt - The numeric response number.

4、ReadBuffer 原型:procedure ReadBuffer(var ABuffer; const AByteCount: Longint); 读取指定数目的字节到缓冲区ABuffer,注意它会调用 ReadFromStack 以检查缓冲区里的数据是否少于AByteCount

5、ReadInteger 原型:function ReadInteger(const AConvert: boolean): Integer; 从缓冲区中读取整型数据,它会调用ReadBuffer

6、ReadLn 原型:function ReadLn(const ATerminator: string; const ATimeout: integer): string; virtual; 读取移行记录,带有一个TimeOut属性,以防止在读不到新行时死循环。返回值:String - Line read from the buffer. 注意行分隔符可能是以下几种: #0 - Default Line Feed (#10) LF - Line Feed (#10) CR - Carriage Return (#13) EOL - End-of-line (Carriage Return Line Feed)

7、ReadLnWait: 原型:function ReadLnWait: string; 很像ReadLn,但它会一直傻傻的等待

8、ReadSmallInt 原型:function ReadSmallInt(const AConvert: boolean): SmallInt;

9、ReadStream 原型:procedure ReadStream(AStream: TStream; AByteCount: LongInt; const AReadUntilDisconnect: boolean);

10、ReadString 原型:function ReadString(const ABytes: integer): string; 与CurrentReadBuffer的不同在于它读取指定长度的字符串 IdTCPClient和IdTCPServer主要属性 2008-10-13 12:40 IdTCPClient属性 1 : IOHandler 如果有相应的输入/输出操作,那么IOHandler相对应的组件或 接口将提供一个虚拟/抽象的输入/输出接口给相应的网络连接 2 : Intercept 如果有一个网络连接正在使用,那么Intercept 提供的组件或接 口将可以拦截相应的网络数据流中的数据 3 : BoundIP 指定使用IdTCPClient组件的计算机系统的IP地址,也就是说,其 中是空白那么什么样的计算机都可以使用,但如果指定的IP地址为239.126.12.2,那么 就只有IP地址为239.126.12.2的计算机可以使用它. 4 : BoundPor 网络端口的概念,指定使用IdTCPClient组件的计算机系统网络 端口,也就是说,如果BoundPort中指定了以整数为端口的网络端口,那么通讯时就只能 使用这个商品进行通讯 5 : Host 如果不是使用BoundIP中的地址起先通讯,那么Host就是诣将 要通讯的计算机系统的名称或它的IP地址,可以是计算机名也可以是IP地址. 6 : Port 与BoundPort的概念是基本一样的,只是它与HOst相配合来决 定IdTCPClient组件要与哪一个计算机系统中的什么样的网络通讯端口进行通讯 方法 IdTCPClient 主要使 用Write,WriteBuffer,WriteCardinal,WriteFile,WriteHeader,WriteInteger,WriteL n,WriteRFCReply,WriteRFCStrings,WriteSmallInt,WriteStream,WriteStrings. 通过它们 IdTCPClient 可以发送非常多的类型的数据到相应的服务端,而这些都是非 常的简单 如: Write的函数说明是: procedure Write(Const Aout : String) ; Virtual; 它的目的很简单,就是发送一个字符串到相应的服务端.其中Aout就是被发送的字符串. 而 WriteLn的函数说明是: procedure WriteLn(Const Aout : String = ''); Virtual; 它的目的就是在Write的基础上,在被发送的字符串后加入相应的回车控件符. 注意 : 虽然IdTCPClient可以直接使用,它不可以被单独的使用,它必须与相应 的IdTCPServer组件相配合才能发挥特定的作用,当然,如果相应的网络系统中具有这 样的TCP服务器应用,那么IdTCPClient也可以直接与它们进行通讯. IdTCPServer 属性 1 : Bindings 包括了相应的服务端所允许的所有的Socket(套接字)的相关信 息,比如它们的IP地址和端口号 2 : ListenQueue 是规定在服务端失效之前最多可以允许的监听网络连接的纯种 数目.默认情况下它的值是15,但这个值可以根据自己的需要和系统的最大承受能力来 进行改变 3 : MaxConnects 它表示的内容就是服务端可以承载的最大的网络连接数目,如果 它的值是0,那么就表明它没有最大的限制值,可以使用任意数目的连接. 4 : MaxConnectionReply 与MaxConnects相配合,当连接数目大 于MaxConnects的数目时,它将返回一个错误的信息,而这个信息是由TIdRFCReply 类所定义的 5 : ThreadMgr 就是使用相应的 ThreadMgr 组件来对于网络连接线程进行管 理.

TIdTCPClient 详解的更多相关文章

  1. Linq之旅:Linq入门详解(Linq to Objects)

    示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...

  2. 架构设计:远程调用服务架构设计及zookeeper技术详解(下篇)

    一.下篇开头的废话 终于开写下篇了,这也是我写远程调用框架的第三篇文章,前两篇都被博客园作为[编辑推荐]的文章,很兴奋哦,嘿嘿~~~~,本人是个很臭美的人,一定得要截图为证: 今天是2014年的第一天 ...

  3. EntityFramework Core 1.1 Add、Attach、Update、Remove方法如何高效使用详解

    前言 我比较喜欢安静,大概和我喜欢研究和琢磨技术原因相关吧,刚好到了元旦节,这几天可以好好学习下EF Core,同时在项目当中用到EF Core,借此机会给予比较深入的理解,这里我们只讲解和EF 6. ...

  4. Java 字符串格式化详解

    Java 字符串格式化详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 文中如有纰漏,欢迎大家留言指出. 在 Java 的 String 类中,可以使用 format() 方法 ...

  5. Android Notification 详解(一)——基本操作

    Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...

  6. Android Notification 详解——基本操作

    Android Notification 详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 前几天项目中有用到 Android 通知相关的内容,索性把 Android Notificatio ...

  7. Git初探--笔记整理和Git命令详解

    几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...

  8. Drawable实战解析:Android XML shape 标签使用详解(apk瘦身,减少内存好帮手)

    Android XML shape 标签使用详解   一个android开发者肯定懂得使用 xml 定义一个 Drawable,比如定义一个 rect 或者 circle 作为一个 View 的背景. ...

  9. Node.js npm 详解

    一.npm简介 安装npm请阅读我之前的文章Hello Node中npm安装那一部分,不过只介绍了linux平台,如果是其它平台,有前辈写了更加详细的介绍. npm的全称:Node Package M ...

随机推荐

  1. CSS传统布局之页面布局实例

    传统的页面布局依赖于盒模型+流动模型(flow)+浮动模型(float)+层模型(layer)来实现页面的布局,具体方法是通过盒模型+display属性+float属性+position属性来加以实现 ...

  2. OC工程调用Swift方法

    1.建一个OC工程命名为SwiftOC.如图所示: 2.新建一个swfit文件命名为Test.swift,会弹出提示,选择Create Bridging Header建立桥接文件,系统会建立“工程名- ...

  3. redhat 安装hadoop1.2.1伪分布式

    完整安装过程参考:http://www.cnblogs.com/shishanyuan/p/4147580.html 一.环境准备    1.安装linux.jdk      2.下载hadoop2. ...

  4. shell脚本学习(二)

    4.cat命令 1)  cat -s    摆脱多余的空白行 2)  cat -T    将制表符显示为^I 3)  cat -n    显示行号 4) cat -b    跳过空白行,然后显示行号 ...

  5. QT插件和服务培训

    下载地址:http://files.cnblogs.com/files/senior-engineer/%E6%8F%92%E4%BB%B6%E5%92%8C%E6%9C%8D%E5%8A%A1%E5 ...

  6. RGB888转RGB666

    内存中的数据排列高位在左,低位在右 RGB888->RGB666 高 -------低 B[3]         B[2]          B[1]         B[0]         ...

  7. js-call、apply

    这里主要就是做一些前人的总结,有时候会有自己的看法,首先把定义说一下 1.方法定义 call方法: 语法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]]) 定义 ...

  8. mysql主从数据库

    Mysql主从配置,实现读写分离 大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库 ...

  9. jetty作为内嵌服务器自启动

    为了完成web工程的测试,最近内嵌jetty也要搞起来.第一次搞还是挺焦头烂额的.直接上成果: package com.test.action; import java.io.File; import ...

  10. java synchronized 线程同步机制详解

    Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码. 一.当两个并发线程访问同一个对象object中的这个synchronized(this ...