c++builder中的Tserversocket,Tclientsocket最简单的两种开发.

王朝c/c++·作者佚名  2006-01-10
窄屏简体版  字體: |||超大  

如果用Tserversocket,Tclientsocket控件来开发网络程序的时候,往往会想到是选择异步好,还是同步好,也就是非阻塞和阻塞的选择,而我们大部分有时候往往都没怎么考虑清楚,特别是对刚接触过的人来说.

首先要弄清出,异步和同步的差别,异步通讯是所有的客户请求都在一个线程中来处理,多个客户同时同步连接的话,则采取排队的方式(这就是C++ Builder中ServerSocket的非阻塞模式)。而对于同步程通讯,每当有一个客户连接时,服务器就会开辟一个线程与之通讯(这就是C++ Builder中ServerSocket的阻塞模式--多线程).同步通讯产生的机制在于,当执行一个函数,比如说在客户端执行一个connect,如果网络很忙的话,客户端可能会等很长的时间.而有一点要注意的是bcb的vcl的子线程根本就不处理消息的。所以如果你异步在线程里使用Tserversocket或者Tclientsocket,非阻塞模式不能选择,需要使用阻塞方式。

当如果你的服务端人数不多的话,处理的数据比较小的话,可以用非阻塞方式.而当你采用服务端和客户端是需要文件传输的话,那么服务端一般采用多线程的阻塞模式.

非阻塞模式下的写法一般是直接在

void __fastcall ServerSocket1ClientConnect(TObject *Sender,

TCustomWinSocket *Socket);

void __fastcall ServerSocket1Accept(TObject *Sender,

TCustomWinSocket *Socket);

void __fastcall ServerSocket1ClientDisconnect(TObject *Sender,

TCustomWinSocket *Socket);

void __fastcall ServerSocket1ClientError(TObject *Sender,

TCustomWinSocket *Socket, TErrorEvent ErrorEvent,

int &ErrorCode);

void __fastcall ServerSocket1ClientRead(TObject *Sender,

TCustomWinSocket *Socket);

这些里面直接写代码就可以了,比较简单.

在用阻塞方式时候,你可以建立一个线程来处理你的每个socket连接.

class SrvThread : public Thread

{

private:

TClientSocket* ClientSocket;

protected:

void __fastcall Execute();

public:

__fastcall SrvThread(TServerClientWinSocket*);

};

每当有一个客户连接时,在OnGetThread事件中开辟一线程:

void __fastcall TForm::ServerSocket1GetThread(TObject *Sender,

TServerClientWinSocket *ClientSocket,

TServerClientThread *&SocketThread)

{

SocketThread=new SrvThread(ClientSocket);

}

在SrvThread线程类中来处理数据:

void __fastcall SrvThread::Execute()

{

//Add your codes here ....................

}

关于阻塞方式还是非阻塞方式有很多种情况,例如还有非阻塞的select模型,还有重叠io.完成端口模型.同步的可以选择配线程词的阻塞模式.micro一般推荐在windows情况下使用非阻塞模式来编写网络程序....

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航