2012年2月11日

CentOS下整合Eclipse和Thrift的方法

    首先下载thrift.0.7.0(thrift需要很多支持,如boost,详细见http://wiki.apache.org/thrift/ThriftRequirements,安装先请先确定已经具备这些条件,特别是boost)

    解压

    # tar -zxvf thrift-0.7.0.tar.gz

    最好自己看thrift-0.7.0文件夹下的README文件里的Installation说明

    一般是

    #./configure --with-boost=/usr/local

    ... ...

    #make

    ... ...

    #make install

    安装好后在终端输入thrift验证一下,如果有反应,说明安装成功

    安装Eclipse,并安装CDT插件,安装教程可以百度或者Google一下(我的CentOS在安装系统的时候就默认安装了Eclipse)

    安装完CDT插件后就可以在Eclipse下编写C/C++项目了。

    在Eclipse下New一下C++ Project,Project type为Empty Project,Toolchains为Linux GCC,编辑项目名称,点Finish

   

    右键项目名称->Propertise->C/C++General->Includes.

    选择GNU C++,点击右边Add..按钮,Directory输入/usr/local/include/thrift,或点File System选择thrift的include文件夹

    还是在当前页面,选择第三个Tab:Libraries,点击右边Add..按钮,在File处填上thrift(可继续点Add按钮,在File处填上pthread添加多线程库),然后确定

 

    测试:

    编写.thrift,将生成的文件copy到ecplise c++项目下,ctrl+B构建,右键运行。

    可能会提示error while loading shared libraries: libthrift.so.0: cannot open shared object file: No such file or directory

    解决方法:

    eclipse的项目属性-->C/C++ Build-->Settings-->Tool settings-->GCC C++ Linker-->Miscellaneous的Other options (-Xlinker [option])添加 -R/usr/local/lib

   

posted @ 2012-02-11 15:36 落叶歸根 阅读(144) 评论(0) 编辑

2011年12月15日

socket的select函数

思路:

  1. 初始化一个socket
  2. 建立一个socket列表用于管理socket
  3. 将初步连接的socket放入列表中
  4. 用select判断列表中未处理的socket

Win API版本

1.

USHORT nPort = 4567;    // 此服务器监听的端口号

// 创建监听套节字
SOCKET sListen = ::socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
sockaddr_in sin;
sin.sin_family = AF_INET;
sin.sin_port = htons(nPort);
sin.sin_addr.S_un.S_addr = INADDR_ANY;
// 绑定套节字到本地机器
if(::bind(sListen, (sockaddr*)&sin, sizeof(sin)) == SOCKET_ERROR)
{
printf(" Failed bind() \n");
return -1;
}
// 进入监听模式
::listen(sListen, 5);

2.

// select模型处理过程
// 1)初始化一个套节字集合fdSocket,添加监听套节字句柄到这个集合
fd_set fdSocket; // 所有可用套节字集合
FD_ZERO(&fdSocket);
FD_SET(sListen, &fdSocket);

3.

while(TRUE)
{
// 2)将fdSocket集合的一个拷贝fdRead传递给select函数,
// 当有事件发生时,select函数移除fdRead集合中没有未决I/O操作的套节字句柄,然后返回。
fd_set fdRead = fdSocket;
int nRet = ::select(0, &fdRead, NULL, NULL, NULL);
if(nRet > 0)
{
// 3)通过将原来fdSocket集合与select处理过的fdRead集合比较,
// 确定都有哪些套节字有未决I/O,并进一步处理这些I/O。
for(int i=0; i<(int)fdSocket.fd_count; i++)
{
if(fdSocket.fd_array[i] == sListen) // (1)监听套节字接收到新连接
{
if(fdSocket.fd_count < FD_SETSIZE)
{
sockaddr_in addrRemote;
int nAddrLen = sizeof(addrRemote);
SOCKET sNew = ::accept(sListen, (SOCKADDR*)&addrRemote, &nAddrLen);

FD_SET(sNew, &fdSocket);
printf("接收到连接(%s)\n", ::inet_ntoa(addrRemote.sin_addr));
}
else
{
printf(" Too much connections! \n");
continue;
}
}
else
{
char szText[256];
int nRecv = ::recv(fdSocket.fd_array[i], szText, strlen(szText), 0);
if(nRecv > 0) // (2)可读
{
szText[nRecv] = '\0';
printf("接收到数据:%s \n", szText);
}
else // (3)连接关闭、重启或者中断
{
::closesocket(fdSocket.fd_array[i]);
printf("关闭\n");
FD_CLR(fdSocket.fd_array[i], &fdSocket);
}
}
}
}
else
{
printf(" Failed select() \n");
break;
}
}

本文系转载而来学习之用.

windows头文件WinSock2.h中对FD_SETSIZE的定义是

#ifndef FD_SETSIZE
#define FD_SETSIZE 64
#endif /* FD_SETSIZE */

如果是偏大点的服务程序,64个socket肯定是太小了,如果想手动地增加FD_SETSIZE的大小,可以在导入WinSock2.h的前一行加入 #define FD_SETSIZE 1024,网上貌似说这个数字不能大于1024.

 


posted @ 2011-12-15 16:47 落叶歸根 阅读(37) 评论(0) 编辑