由于代码的注释已经很详尽了,所以这里不再作过多说明.仅仅贴出代码和结果图.

值得注意的是必须先启动server程序再启动client.

Server:

 #include <WINSOCK2.H>    //套接字库
#include <stdio.h> #define PORT 6000 //服务器端口
#define MSGSIZE 1024 //收发缓冲区的大小 #pragma comment(lib, "ws2_32.lib") //链接静态库 DWORD WINAPI FunThread(LPVOID); //创建一个线程,专门用来接收数据 SOCKET sClient; //连接所用套节字
SOCKET sListen; //监听套接字
SOCKADDR_IN client; //保存客户的地址信息
int iaddrSize = sizeof(SOCKADDR_IN); int main()
{ WSADATA wsaData; //WSADATA结构体中主要包含了系统所支持的Winsock版本信息
SOCKADDR_IN local; //定义本地套接字地址
char s_Message[MSGSIZE]; //收发缓冲区 WSAStartup(0x0202, &wsaData); //初始化套接字库 sListen = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);//创建服务器监听套节字。TCP协议 local.sin_family = AF_INET; //AF_INET指明使用TCP/IP协议族
local.sin_port = htons(PORT);//指明连接服务器的端口号
local.sin_addr.s_addr = htonl(INADDR_ANY);//自动获取本机地址 bind(sListen, (struct sockaddr *)&local, sizeof(SOCKADDR_IN));//地址绑定到套接字 listen(sListen, );//开始监听 sClient = accept(sListen, (struct sockaddr *)&client, &iaddrSize);//建立连接,返回用于连接的套接字
printf("Accepte client:%s:%d\n", inet_ntoa(client.sin_addr), ntohs(client.sin_port));//输出客户端的IP地址和端口 HANDLE hThread=CreateThread(NULL,,FunThread,,,);//运行至此创建专门的接收线程用于接收客户端发送
//的数据,在监听主线程上创建一个新的数据接收线程
CloseHandle(hThread);//关闭线程句柄 //用于从服务器端向客户端发送数据
while (TRUE)
{
printf("Server Send:");
//从键盘输入
gets(s_Message);
//发送数据
send(sClient, s_Message, strlen(s_Message), );
}
return ;
} //当接收数据时调用此线程函数
DWORD WINAPI FunThread(LPVOID)
{
char c_Message[MSGSIZE]; //接收数据缓冲区
int ret; //接收字节的个数
while (TRUE)
{
ret = recv(sClient, c_Message, MSGSIZE, );//接收数据到缓冲区 //判断是否成功接收,如果未成功接收则重启监听,将原缓冲区的数据归零
if(ret==SOCKET_ERROR)
{
printf("\nclient is closed!"); sClient = accept(sListen, (struct sockaddr *)&client, &iaddrSize);//重新开始监听
printf("\nAccepte new client:%s:%d", inet_ntoa(client.sin_addr), ntohs(client.sin_port));
memset(c_Message,,);//将原来的client message归零
continue;
}
c_Message[ret] = '\0';
printf("\nReceived: %s\n", c_Message);
}
return ;
}<strong>
</strong>

Client:

 #include <WINSOCK2.H> //套接字库
#include <stdio.h> #define SERVER_ADDRESS "127.0.0.1" //服务器端IP地址,由于服务也在本地机器上所以用环回地址127.0.0.1 #define PORT 6000 //客户端绑定端口
#define MSGSIZE 1024 //客户端接收数据缓冲区大小
#pragma comment(lib, "ws2_32.lib") DWORD WINAPI FunThread(LPVOID); //对于客户端接收数据的线程函数 SOCKET sClient; //客户端套接字
SOCKADDR_IN server; //服务器端套接字 int main()
{
WSADATA wsaData;
char c_Message[MSGSIZE]; //数据缓冲区 WSAStartup(0x0202, &wsaData); //初始化套接字库 sClient = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); //创建客户端套接字 memset(&server, , sizeof(SOCKADDR_IN)); //先将保存地址的server置为全0
server.sin_family = PF_INET; //声明地址格式是TCP/IP地址格式
server.sin_port = htons(PORT); //指明连接服务器的端口号
server.sin_addr.s_addr = inet_addr(SERVER_ADDRESS); //指明连接服务器的IP地址 connect(sClient, (struct sockaddr *)&server, sizeof(SOCKADDR_IN)); //连到刚才指明的服务器上 HANDLE hThread=CreateThread(NULL,,FunThread,,,);;//客户端开辟接收数据线程
CloseHandle(hThread); //客户端向服务器发送数据
while (TRUE)
{
printf("Client Send:");
gets(c_Message); send(sClient, c_Message, strlen(c_Message), );
if(!strcmp(c_Message,"exit"))//client自身退出
exit();
} // 释放连接和进行结束工作
closesocket(sClient);
WSACleanup();
return ;
} //接收线程函数
DWORD WINAPI FunThread(LPVOID)
{
char s_Message[MSGSIZE];//定义接收缓冲区
int ret;
while (TRUE)
{
ret = recv(sClient, s_Message, MSGSIZE, );//接收服务器端的数据 //判断是否接收
if(ret==SOCKET_ERROR)
{
printf("\nServer is closed!\n");
exit();
}
s_Message[ret] = '\0';
//显示接收数据
printf("\nReceived: %s\n", s_Message); //如果服务器端发送exit则client退出
if(!strcmp(s_Message,"exit"))//server让client退出
exit();
}
return ;
}<strong>
</strong>

运行结果如下:



基于TCP套接字实现的简单Demo的更多相关文章

  1. unix网络编程第四章----基于TCP套接字编程

    为了执行网络I/O操作.进程必须做的第一件事情就是调用Socket函数.指定期待的通信协议 #include<sys/socket.h> int socket(int family,int ...

  2. Python之路(第三十一篇) 网络编程:简单的tcp套接字通信、粘包现象

    一.简单的tcp套接字通信 套接字通信的一般流程 服务端 server = socket() #创建服务器套接字 server.bind() #把地址绑定到套接字,网络地址加端口 server.lis ...

  3. Python网络编程之TCP套接字简单用法示例

    Python网络编程之TCP套接字简单用法示例 本文实例讲述了Python网络编程之TCP套接字简单用法.分享给大家供大家参考,具体如下: 上学期学的计算机网络,因为之前还未学习python,而jav ...

  4. TCP套接字编程模型及实例

    摘要:     本文讲述了TCP套接字编程模块,包括服务器端的创建套接字.绑定.监听.接受.读/写.终止连接,客户端的创建套接字.连接.读/写.终止连接.先给出实例,进而结合代码分析. PS:本文权当 ...

  5. Python网络编程02 /基于TCP、UDP协议的socket简单的通信、字符串转bytes类型

    Python网络编程02 /基于TCP.UDP协议的socket简单的通信.字符串转bytes类型 目录 Python网络编程02 /基于TCP.UDP协议的socket简单的通信.字符串转bytes ...

  6. TCP套接字编程

    一.套接字(socket)函数 图1给出了在一个TCP客户与服务器通信的流程.服务器首先启动,稍后某个客户启动,它试图连接到服务器.假设客户给服务器发送一个请求,服务器处理该请求,并且给客户发回一个相 ...

  7. 【UNIX网络编程(二)】基本TCP套接字编程函数

    基于TCP客户/server程序的套接字函数图例如以下: 运行网络I/O.一个进程必须做的第一件事就是调用socket函数.指定期望的通信协议类型. #include <sys/socket.h ...

  8. 套接字编程相关函数(2:TCP套接字编程相关函数)

    本文摘录自<UNIX网络编程 卷1>. 基本套接字函数 socket函数 为了执行网络I/O,一个进程必须做的第一件事就是调用socket函数,指定期望的通信协议类型.其定义如下: #in ...

  9. LINUX TCP套接字详细配置

    提高服务器的负载能力,是一个永恒的话题.在一台服务器CPU和内存资源额定有限的情况下,最大的压榨服务器的性能,是最终的目的.要提高 Linux系统下的负载能力,可以先启用Apache的Worker模式 ...

随机推荐

  1. .NET中栈和堆的比较 #1

    原文出处:http://www.c-sharpcorner.com/UploadFile/rmcochran/csharp_memory01122006130034PM/csharp_memory.a ...

  2. UESTC_秋实大哥与小朋友 2015 UESTC Training for Data Structures<Problem A>

    A - 秋实大哥与小朋友 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Sub ...

  3. Plus One 解答

    Question Given a non-negative number represented as an array of digits, plus one to the number. The ...

  4. Machine Learning - Lecture 16

    Reinforcement Learning (R.L.) ① MDPs (Markov Decision Processes) ② Value Functions ③ Value Iteration ...

  5. http://home.cnblogs.com/

    说起编辑器,可能大部分人要推荐的是Vim和Emacs,本人用过Vim,功能确实强大,但是不是很习惯,之前一直有朋友推荐SUblime Text 2这款编辑器,然后这段时间就试了一下,就深深地喜欢上这款 ...

  6. A Corrupt Mayor's Performance Art(线段树区间更新+位运算,颜色段种类)

    A Corrupt Mayor's Performance Art Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 100000/100 ...

  7. Visual Studio® 2010 Web Deployment Projects站点编译生成bin同时发表插件

    VS2010环境下: 1.Visual Studio® 2010 Web Deployment Projects下载地址:        http://www.microsoft.com/downlo ...

  8. C# Winform中执行post操作并获取返回的XML类型的数据

    /// <summary> /// 返回指定日期的订单数据 /// </summary> /// <param name="StartDate"> ...

  9. JSON 日期格式带 T 问题

    var iso = new IsoDateTimeConverter(); iso.DateTimeFormat = "yyyy-MM-dd"; object obj = new  ...

  10. hbase性能调优之压缩测试

    文章概述: 1.顺序写 2.顺序读 3.随机写 4.随机读 5.SCAN数据 0 性能测试工具 hbase org.apache.hadoop.hbase.PerformanceEvaluation ...