嗯,我先把源码贴上来,各位一看,就明白了。然后我再详细叙述问题,谢谢了 哈!//////////////////////////////////////////////////////
// select.cpp文件//这个是服务端!功能是发送数据给客户端!
//只有发送数据的功能,用了select模型,但是,有问题的希望高手解答下!谢谢!#include "../common/initsock.h"
#include <stdio.h>CInitSock theSock; // 初始化Winsock库
int main()
{
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); // select模型处理过程
// 1)初始化一个套节字集合fdSocket,添加监听套节字句柄到这个集合
fd_set fdSocket; // 所有可用套节字集合
FD_ZERO(&fdSocket);
FD_SET(sListen, &fdSocket); printf("This is Srv!\n"); while(TRUE)
{
// 2)将fdSocket集合的一个拷贝fdRead传递给select函数,
// 当有事件发生时,select函数移除fdRead集合中没有未决I/O操作的套节字句柄,然后返回。
fd_set fdWrite = fdSocket;
int nRet = ::select(0, NULL, &fdWrite, NULL, NULL);
//为什么上面的select没有返回值呢?运行到这里,就完了
if(nRet > 0)
{
// 3)通过将原来fdSocket集合与select处理过的fdRead集合比较,
// 确定都有哪些套节字有未决I/O,并进一步处理这些I/O。
for(int i=0; i<(int)fdSocket.fd_count; i++)
{
if(FD_ISSET(fdSocket.fd_array[i], &fdWrite))
{
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
{
printf("input:");
char sendBuf[100];
gets(sendBuf);
int nSend = ::send(fdSocket.fd_array[i], sendBuf, sizeof(sendBuf), 0);
if(nSend > 0) // (2)可读
{
printf("发送的数据:%s \n", sendBuf);
}
else // (3)连接关闭、重启或者中断
{
::closesocket(fdSocket.fd_array[i]);
FD_CLR(fdSocket.fd_array[i], &fdSocket);
}
}
}
}
}
}
return 0;
}
这个是服务端程序,TCP的,客户端的话,好像发不上来了,客户端就是最简单的,教材上的哪种TCP的连接的
服务端只发送数据,而客户端是只接收数据!
现在问题出现了,在
int nRet = ::select(0, NULL, &fdWrite, NULL, NULL);
这个语句,开始有问题了,本来应该有返回值的,咋就突然没有了呢?后面的,我都暂时还没有测试的因为无法编译下去了。谢谢了哈!!!
// select.cpp文件//这个是服务端!功能是发送数据给客户端!
//只有发送数据的功能,用了select模型,但是,有问题的希望高手解答下!谢谢!#include "../common/initsock.h"
#include <stdio.h>CInitSock theSock; // 初始化Winsock库
int main()
{
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); // select模型处理过程
// 1)初始化一个套节字集合fdSocket,添加监听套节字句柄到这个集合
fd_set fdSocket; // 所有可用套节字集合
FD_ZERO(&fdSocket);
FD_SET(sListen, &fdSocket); printf("This is Srv!\n"); while(TRUE)
{
// 2)将fdSocket集合的一个拷贝fdRead传递给select函数,
// 当有事件发生时,select函数移除fdRead集合中没有未决I/O操作的套节字句柄,然后返回。
fd_set fdWrite = fdSocket;
int nRet = ::select(0, NULL, &fdWrite, NULL, NULL);
//为什么上面的select没有返回值呢?运行到这里,就完了
if(nRet > 0)
{
// 3)通过将原来fdSocket集合与select处理过的fdRead集合比较,
// 确定都有哪些套节字有未决I/O,并进一步处理这些I/O。
for(int i=0; i<(int)fdSocket.fd_count; i++)
{
if(FD_ISSET(fdSocket.fd_array[i], &fdWrite))
{
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
{
printf("input:");
char sendBuf[100];
gets(sendBuf);
int nSend = ::send(fdSocket.fd_array[i], sendBuf, sizeof(sendBuf), 0);
if(nSend > 0) // (2)可读
{
printf("发送的数据:%s \n", sendBuf);
}
else // (3)连接关闭、重启或者中断
{
::closesocket(fdSocket.fd_array[i]);
FD_CLR(fdSocket.fd_array[i], &fdSocket);
}
}
}
}
}
}
return 0;
}
这个是服务端程序,TCP的,客户端的话,好像发不上来了,客户端就是最简单的,教材上的哪种TCP的连接的
服务端只发送数据,而客户端是只接收数据!
现在问题出现了,在
int nRet = ::select(0, NULL, &fdWrite, NULL, NULL);
这个语句,开始有问题了,本来应该有返回值的,咋就突然没有了呢?后面的,我都暂时还没有测试的因为无法编译下去了。谢谢了哈!!!
解决方案 »
- 关于OpenGL明暗处理设置法向量的问题
- 改变在CBUTTON按钮上输出设定好颜色的字!
- 图片素材用到控件上是经过分割的么?
- 为何我在VC6下无法用MSComm控件实现通讯?具体内详,请进!
- 如何在系统退出前让程序执行特定的操作?
- !!!急,急,急,在线等待,马上结贴。用ODBC连接数据库,怎么实现select sum(gjip),sum(gjct) from account group by calling_nbr 而且怎
- visual studio.net中文正式版的版本号是多少?
- 错在哪里?
- VS2013 将导入的资源显示到界面
- VC学到什么程度就可以找一份工作了?
- 逻辑坐标和设备坐标的
- vc dao组件写入时间型数据到MDB数据库
#include <stdio.h>CInitSock theSock; // 初始化Winsock库
int main()
{
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); // select模型处理过程
// 1)初始化一个套节字集合fdSocket,添加监听套节字句柄到这个集合
fd_set fdSocket; // 所有可用套节字集合
FD_ZERO(&fdSocket);
FD_SET(sListen, &fdSocket); printf("This is Srv!\n"); while(TRUE)
{
// 2)将fdSocket集合的一个拷贝fdRead传递给select函数,
// 当有事件发生时,select函数移除fdRead集合中没有未决I/O操作的套节字句柄,然后返回。
fd_set fdRead = fdSocket;
int nRet = ::select(0, &fdRead , NULL, NULL, 0);
//为什么上面的select没有返回值呢?运行到这里,就完了
if(nRet > 0)
{
// 3)通过将原来fdSocket集合与select处理过的fdRead集合比较,
// 确定都有哪些套节字有未决I/O,并进一步处理这些I/O。
for(int i=0; i<(int)fdSocket.fd_count; i++)
{
if(FD_ISSET(fdSocket.fd_array[i], &fdRead))
{
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)); printf("input:");
char sendBuf[100];
gets(sendBuf);
int nSend = ::send(fdSocket.fd_array[i], sendBuf, sizeof(sendBuf), 0);
if (nSend > 0)
{
printf("发送的数据:%s \n", sendBuf);
}
else
{
printf(" Too much connections! \n");
continue;
}
}
else
{
printf("input:");
char buf[100];;
int nRecv = ::recv(fdSocket.fd_array[i], buf, sizeof(buf), 0);
if(nSend > 0) // (2)可读
{
printf("发送的数据:%s \n", sendBuf);
}
else // (3)连接关闭、重启或者中断
{
::closesocket(fdSocket.fd_array[i]);
FD_CLR(fdSocket.fd_array[i], &fdSocket);
}
}
}
}
}
}
return 0;
}
FD_SET(sListen, &fdWrite); 或者用FD_SET(sListen, &fdSocket); fd_set fdWrite = fdSocket;
FD_SET(sListen, &fdWrite);
int nRet = ::select(0, NULL, &fdWrite, NULL, NULL);