TCP多线程服务端-客户端模板(Linux下)

简介: TCP多线程服务端-客户端模板(Linux下)

服务器模板

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <string.h>
#include <unistd.h>
#include <time.h>
#include <pthread.h>
#include <malloc.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <signal.h>
#define PORT 9999   // 端口
void *client_thread(void *arg);
//多线程 并发服务器
int main(int argc, char const *argv[])
{
    int ret;
    int sockfd;  //套接字描述符
    int connfd;
    char buf[1024];
    int fp;
    sockfd = socket(AF_INET, SOCK_STREAM, 0); //创建通信套接字ipv4协议 tcp通信
    if(sockfd==-1){
        printf("socket failed\n");
        exit(-1);
    }
    //定义addr存入本机地址信息
    struct sockaddr_in addr;
    addr.sin_family =  AF_INET   ;  //协议
    addr.sin_port =  htons(PORT) ;  //端口
    addr.sin_addr.s_addr = inet_addr("0") ; //ip  0代表本机
    //绑定地址信息(sockfd + addr)
    ret = bind(sockfd, (struct sockaddr *)&addr, sizeof(addr)); 
    if(ret==-1){
        printf("bind failed\n");
        exit(-1);
    }
    listen(sockfd,255);  //建立监听队列,并监听状态
    while(1){
        printf("wait...\n");
        connfd =  accept(sockfd, NULL, NULL); //建立连接
        printf("connect a client\n");
        // 创建子线程
        pthread_t pid;
        pthread_create(&pid, NULL, client_thread, (void *)&connfd);
        pthread_detach(pid);
    }
    close(sockfd);
    return 0;
}
// 线程函数
void *client_thread(void *arg)
{
    int connfd = *(int *)arg;
    char buf[256];  // 接收缓冲区,大小根据你的需求定
    while(1) {
      // 你的程序逻辑
        // 接收函数: ret = read(connfd, buf, sizeof(buf));   // 返回值为实际接收的字节数,ret <= 0 表示客户端断开连接
        // 发送函数: ret = write(connfd, buf, sizeof(buf));  // 返回值为实际发送的字节数
    }
}

客户端模板

#include <stdio.h>
#include <stdlib.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <string.h>
#include <sys/socket.h>
#include <time.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
#define HOST "192.168.1.108"  // 服务器地址
#define PORT 9999  // 服务器端口
//搭建tcp客服端
int main(int argc, char const *argv[])
{
  int ret,ret1,ret2;
  int sockfd; //套接字描述符
  srand(time(NULL));
  sockfd = socket(AF_INET ,SOCK_STREAM, 0); //创建通信套接字(TCP)
  if(sockfd == -1)
  {
    printf("socket failed\n");
    exit(-1);
  }
  //定义addr存入本机地址信息
  struct sockaddr_in addr;
    addr.sin_family = AF_INET; //协议
    addr.sin_port = htons(PORT);    //端口
    addr.sin_addr.s_addr= inet_addr(HOST); //服务器地址
    ret = connect(sockfd, (struct sockaddr *)&addr, sizeof(addr));  //连接tcp客服端
    if(ret == -1)
    {
      printf("connect failed1\n");
      return 0;
    }
    printf("connect success!\n");
    while(1)
    {
      // 你的程序逻辑
        // 接收函数: ret = read(connfd, buf, sizeof(buf));   // 返回值为实际接收的字节数
        // 发送函数: ret = write(connfd, buf, sizeof(buf));  // 返回值为实际发送的字节数
    }
    close(sockfd); //关闭通信套接字(TCP)
}
xgrang
+关注
目录
打赏
0
0
0
0
1
分享
相关文章
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
在计算机系统的底层架构中,操作系统肩负着资源管理与任务调度的重任。当我们启动各类应用程序时,其背后复杂的运作机制便悄然展开。程序,作为静态的指令集合,如何在系统中实现动态执行?本文带你一探究竟!
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
C语言 网络编程(十四)并发的TCP服务端-以线程完成功能
这段代码实现了一个基于TCP协议的多线程服务器和客户端程序,服务器端通过为每个客户端创建独立的线程来处理并发请求,解决了粘包问题并支持不定长数据传输。服务器监听在IP地址`172.17.140.183`的`8080`端口上,接收客户端发来的数据,并将接收到的消息添加“-回传”后返回给客户端。客户端则可以循环输入并发送数据,同时接收服务器回传的信息。当输入“exit”时,客户端会结束与服务器的通信并关闭连接。
C语言 网络编程(九)并发的UDP服务端 以线程完成功能
这是一个基于UDP协议的客户端和服务端程序,其中服务端采用多线程并发处理客户端请求。客户端通过UDP向服务端发送登录请求,并根据登录结果与服务端的新子线程进行后续交互。服务端在主线程中接收客户端请求并创建新线程处理登录验证及后续通信,子线程创建新的套接字并与客户端进行数据交换。该程序展示了如何利用线程和UDP实现简单的并发服务器架构。
|
9月前
|
揭秘网络通信的魔法:Win32多线程技术如何让服务器化身超级英雄,同时与成千上万客户端对话!
【8月更文挑战第16天】在网络编程中,客户/服务器模型让客户端向服务器发送请求并接收响应。Win32 API支持在Windows上构建此类应用。首先要初始化网络环境并通过`socket`函数创建套接字。服务器需绑定地址和端口,使用`bind`和`listen`函数准备接收连接。对每个客户端调用`accept`函数并在新线程中处理。客户端则通过`connect`建立连接,双方可通过`send`和`recv`交换数据。多线程提升服务器处理能力,确保高效响应。
85 6
|
9月前
|
Java使用FileInputStream&&FileOutputStream模拟客户端向服务器端上传文件(单线程)
Java使用FileInputStream&&FileOutputStream模拟客户端向服务器端上传文件(单线程)
126 1
Linux下svn服务端的安装与配置
Linux下svn服务端的安装与配置
113 0
【Linux】多线程——线程概念|进程VS线程|线程控制(下)
【Linux】多线程——线程概念|进程VS线程|线程控制(下)
120 0
|
10月前
|
【Linux】多线程——线程概念|进程VS线程|线程控制(上)
【Linux】多线程——线程概念|进程VS线程|线程控制(上)
114 0
Redis14----Redis的java客户端-jedis的连接池,jedis本身是线程不安全的,并且频繁的创建和销毁连接会有性能损耗,最好用jedis连接池代替jedis,配置端口,密码
Redis14----Redis的java客户端-jedis的连接池,jedis本身是线程不安全的,并且频繁的创建和销毁连接会有性能损耗,最好用jedis连接池代替jedis,配置端口,密码
|
3月前
|
Linux编程: 在业务线程中注册和处理Linux信号
本文详细介绍了如何在Linux中通过在业务线程中注册和处理信号。我们讨论了信号的基本概念,并通过完整的代码示例展示了在业务线程中注册和处理信号的方法。通过正确地使用信号处理机制,可以提高程序的健壮性和响应能力。希望本文能帮助您更好地理解和应用Linux信号处理,提高开发效率和代码质量。
69 17
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等