客户端

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <string.h>
#include<arpa/inet.h>
#include <error.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <pthread.h>
void* recvsocket(void* arg)//接受来着客户端数据的线程
{
int st = *(int*)arg;
char s[];
while ()
{
memset(s, , sizeof(s));
int rc = recv(st, s, sizeof(s), );
if (rc <= )//代表socket被关闭(0)或者出错(-1)
{
break;
}
printf("client receive:%s\n", s);
}
return NULL;
}
void* sendsocket(void* arg)//向服务端socket发送数据的线程
{
int st = *(int*)arg;
char s[];
while ()
{
memset(s, , sizeof(s));
scanf("%s", s);
int sc = send(st, s, strlen(s), );
}
}
//执行 ./ClientLinux.out 127.0.0.1 8080
int main(int arg, char* args[])
{
if (arg < )
{
printf("arg<3\n");
return - ;
}
int port = atoi(args[]);
//第一步:初始化一个socket实例
int st = socket(AF_INET, SOCK_STREAM, ); //第二步:定义一个IP地址结构并设置值
struct sockaddr_in addr;
//内存初始化,将addr变量指向的内存签n个字节用0进行初始化填充
memset(&addr, , sizeof(addr));
//设置采用的协议为TCP/IP协议
addr.sin_family = AF_INET;
//设置端口号
addr.sin_port = htons(port);
//设置IP地址
addr.sin_addr.s_addr = inet_addr(args[]); //第三步:开始连接服务端
if (connect(st, (struct sockaddr*) & addr, sizeof(addr)) == -)
{
printf("connect fail %s\n", strerror(errno));
return EXIT_FAILURE;
} //第四步:初始化要发送的信息并且通过send函数发送数据
pthread_t thrd1, thrd2;//定义一个线程
pthread_create(&thrd1, NULL, recvsocket, &st);
pthread_create(&thrd2, NULL, sendsocket, &st);
pthread_join(thrd1,NULL);
pthread_join(thrd2,NULL); close(st);
getchar();
return EXIT_SUCCESS;
}

服务端

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <string.h>
#include<arpa/inet.h>
#include <error.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <pthread.h>
void* recvsocket(void* arg)//接受来着客户端数据的线程
{
int st = *(int*)arg;
char s[];
while ()
{
memset(s, , sizeof(s));
int rc = recv(st, s, sizeof(s), );
if (rc <= )//代表socket被关闭(0)或者出错(-1)
{
printf("sercver recv fail:%d\n", rc);
break;
}
printf("server receive:%s\n", s);
}
return NULL;
}
void* sendsocket(void* arg)//向客户端socket发送数据的线程
{
int st = *(int*)arg;
char s[];
while ()
{
memset(s, , sizeof(s));
scanf("%s", s);
int sc = send(st, s, strlen(s), );
}
}
//执行命令 ./ServerLinux.out 8080
int main(int arg, char* args[])
{
if (arg < )
{
return -;
}
int port = atoi(args[]);
int st = socket(AF_INET, SOCK_STREAM, ); //setsockopt 设置socket的一个属性,让地址可以重用。
int on = ;
if (setsockopt(st, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) == -)
{
printf("setsockopt failed:%s\n", strerror(errno));
return EXIT_FAILURE;
}
struct sockaddr_in addr;
memset(&addr, , sizeof(addr));
addr.sin_family = AF_INET;
addr.sin_port = htons(port);
//INADDR_ANY表示这个服务器上的所有Ip地址。一台服务器可以有多个ip地址。将socket绑定到这个机器的所有ip地址上
addr.sin_addr.s_addr = htonl(INADDR_ANY); //将ip地址与server程序绑定
if (bind(st, (struct sockaddr*) & addr, sizeof(addr)) == -)
{
printf("bind fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//server开始监听。 20代表同时有多少个连接过来(20并发)
if (listen(st, ) == -)
{
printf("listen fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//char s[1024];
int client_st = ;//客户端socket
struct sockaddr_in client_addr;//客户端IP pthread_t thrd1, thrd2;//定义一个线程
while ()
{
memset(&client_addr, , sizeof(client_addr));
socklen_t len = sizeof(client_addr);
//accept会阻塞,直到有客户端连接过来。accept返回客户端的描述符
client_st = accept(st, (struct sockaddr*) & client_addr, &len);
if (client_st == -)
{
printf("accept fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//打印客户端的ip地址
printf("accept ip : %s\n", inet_ntoa(client_addr.sin_addr));
pthread_create(&thrd1, NULL, recvsocket, &client_st);
pthread_create(&thrd2, NULL, sendsocket, &client_st);
}
close(st);
getchar();
}

c++ Socket客户端和服务端示例版本三(多线程版本)的更多相关文章

  1. c++ Socket客户端和服务端示例版本二

    客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...

  2. c++ Socket客户端和服务端示例版本一

    客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...

  3. c#Socket客户端和服务端的信息发送

    这是我制作的界面信息,c# Socket通信的简单使用,刚开始学习,不对的地方请大家指教,目前是可以运行的,之后自己在慢慢添加新的东西.同时了解Tcp协议的三次握手.希望对跟我一样的初学者有所帮助. ...

  4. socket 客户端和服务端通信

    客户端要连接服务器:首先要知道服务器的IP地址.而服务器里有很多的应用程序,每一个应用程序对应一个端口号 所以客户端想要与服务器中的某个应用程序进行通信就必须要知道那个应用程序的所在服务器的IP地址, ...

  5. java Socket通信,客户端与服务端相互发消息

    1.通信过程 网络分为应用层,http.ssh.telnet就是属于这一类,建立在传输层的基础上.其实就是定义了各自的编码解码格式,分层如下: 2.Socket连接 上述通信都要先在传输层有建立连接的 ...

  6. 基于开源SuperSocket实现客户端和服务端通信项目实战

    一.课程介绍 本期带给大家分享的是基于SuperSocket的项目实战,阿笨在实际工作中遇到的真实业务场景,请跟随阿笨的视角去如何实现打通B/S与C/S网络通讯,如果您对本期的<基于开源Supe ...

  7. swoole 客户端和服务端不断通信

    server.php <?php class Chat { const HOST = '0.0.0.0';//ip地址 0.0.0.0代表接受所有ip的访问 const PART = 9501; ...

  8. socket创建TCP服务端和客户端

    看情况选择相对应的套接字*面向连接的传输--tcp协议--可靠的--流式套接字(SOCK_STREAM)*面向无连接的传输--udp协议--不可靠的--数据报套接字(SOCK_DGRAM) 在liun ...

  9. c++ 网络编程(一)TCP/UDP windows/linux 下入门级socket通信 客户端与服务端交互代码

    原文作者:aircraft 原文地址:https://www.cnblogs.com/DOMLX/p/9601511.html c++ 网络编程(一)TCP/UDP  入门级客户端与服务端交互代码 网 ...

随机推荐

  1. [BZOJ4237]稻草人:CDQ分治+单调栈

    分析 按\(y\)排序后CDQ分治,可以发现每个点可以影响的是\(x\)坐标的一段区间,可以使用扫描线+单调栈,在单调栈上二分即可解决,时间复杂度\(O(n \log^2 n)\). 通过归并排序可以 ...

  2. .Net MVC JsonResult在IE下返回值变成下载文件问题

    昨天,有用户反馈公司的系统,一提交表单就变成了下载文件.匆匆忙忙地发现是IE浏览器(360兼容模式,不就是IE内核吗),返回Json格式的字符串变成了下载JSON文件.(代码如下) return Js ...

  3. linux 目录介绍

    /boot: 系统启动相关的文件,如内核.initrd,以及grub(bootloader)/dev: 设备文件 /etc:配置文件/home:用户的家目录,每一个用户的家目录通常默认为/home/U ...

  4. DAY 1模拟赛

    DAY1 杨溢鑫小姐姐出题 好毒瘤啊 T1 低仿机器人 (robo,1s,64M) 题目描述 自从 Dji 推出 robomaster S1 机器人过后,小文就一直缠着爸爸想要一个机器人.没想到爸爸最 ...

  5. Java中判断两个列表是否相等

    CollectionUtils.isEqualCollection(final Collection a, final Collection b) CollectionUtils工具类中有一个查看两个 ...

  6. Intellij IDEA 常见问题

    右击项目时,没有 Java Class,只能创建其他文件 IDEA 还没有将这个项目识别为 Maven 项目时,会出现这种情况.此时右键无法创建类. 解决办法: 手动为 IDEA 指定项目类型:如果编 ...

  7. laravel 配置双模板引擎

    有时候我们可能有这种需求,pc 和 mobile 端显示的页面不一样,这个时候,我们就需要判断设备类型: ****我们用  composer require whichbrowser/parser  ...

  8. web form 防止一个请求重复提交

    /// <summary> /// 防止一个请求重复提交 /// </summary> public void PreventRepeatSubmit() { if (Scri ...

  9. java保留2位或n位小数

    1.直接使用字符串处理 double ds = Double.valueOf(String.format("%.3f", Math.random()).toString()); 这 ...

  10. 【Linux开发】直接渲染管理

    原文地址:https://dri.freedesktop.org/wiki/DRM/ DRM - Direct Rendering Manager DRM是一个内核级的设备驱动,既可以编译到内核中也可 ...