client_thread.c server_thread.c

client_thread.c
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <netdb.h>
#include <unistd.h>

int main(int argc,char *argv[])
{
    int connect_fd;
    int ret;
    char snd_buf[1024];
    int i;
    int port;
    int len;

    static struct sockaddr_in srv_addr;

    //客户端运行需要给出具体的连接地址和端口
    if(argc!=3)
    {
        printf("Usage: %s server_ip_address port\n",argv[0]);
        return 1;
    }

    //获得输入的端口
    port=atoi(argv[2]);

    //创建套节字用于客户端的连接
    connect_fd=socket(PF_INET,SOCK_STREAM,0);
    if(connect_fd<0)
    {
        perror("cannot create communication socket");
        return 1;
    }

    //填充关于服务器的套节字信息
    memset(&srv_addr,0,sizeof(srv_addr));
    srv_addr.sin_family=AF_INET;
    srv_addr.sin_addr.s_addr=inet_addr(argv[1]);
    srv_addr.sin_port=htons(port);

    //连接指定的服务器
    ret=connect(connect_fd,(struct sockaddr *)&srv_addr,sizeof(srv_addr));
    if(ret==-1)
    {
        perror("cannot connect to the server");
        close(connect_fd);
        return 1;
    }

    memset(snd_buf,0,1024);
    //用户输入信息后,程序将输入的信息通过套接字发送给服务器
    //然后调用read函数从服务器中读取发送来的信息
    //当输入“@”时,程序退出
    while(1)
    {
        write(STDOUT_FILENO,"input message:",14);
        len=read(STDIN_FILENO,snd_buf,1024);
        if(len>0)
            write(connect_fd,snd_buf,len);
        len=read(connect_fd,snd_buf,len);
        if(len>0)
            printf("Message form server: %s\n",snd_buf);
        if(snd_buf[0]==‘@‘)
            break;
    }
    close(connect_fd);
    return 0;
}

server_thread.c
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <errno.h>
#include <unistd.h>
#include <signal.h>
#include <sys/wait.h>
#include <netdb.h>
#include <pthread.h>

//线程执行函数负责读写
void *thr_fn(void *arg)
{
    int size,j;
    char recv_buf[1024];
    int *parg=(int *)arg;
    int new_fd=*parg;
    printf("new_fd=%d\n",new_fd);
    while((size=read(new_fd,recv_buf,1024))>0)
    {
        if(recv_buf[0]==‘@‘)
            break;
        printf("Message from client(%d): %s\n",size,recv_buf);
        for(j=0;j<size;j++)
            recv_buf[j]=toupper(recv_buf[j]);
        write(new_fd,recv_buf,size);
    }
    close(new_fd);
    return 0;
}

int main(int argc,char *argv[])
{
    socklen_t clt_addr_len;
    int listen_fd;
    int com_fd;
    int ret;
    int i;
    static char recv_buf[1024];
    int len;
    int port;
    pthread_t tid;

    struct sockaddr_in clt_addr;
    struct sockaddr_in srv_addr;

    //服务器端运行时要给出端口信息,该端口为监听端口
    if(argc!=2)
    {
        printf("Usage:%s port\n",argv[0]);
        return 1;
    }

    //获得输入的端口
    port=atoi(argv[1]);

    //创建套接字用于服务器的监听
    listen_fd=socket(PF_INET,SOCK_STREAM,0);
    if(listen_fd<0)
    {
        perror("cannot create listening socket");
        return 1;
    }

    //填充关于服务器的套节字信息
    memset(&srv_addr,0,sizeof(srv_addr));
    srv_addr.sin_family=AF_INET;
    srv_addr.sin_addr.s_addr=htonl(INADDR_ANY);
    srv_addr.sin_port=htons(port);

    //将服务器和套节字绑定
    ret=bind(listen_fd,(struct sockaddr *)&srv_addr,sizeof(srv_addr));
    if(ret==-1)
    {
        perror("cannot bind server socket");
        close(listen_fd);
        return 1;
    }

    //监听指定端口,连接5个客户端
    ret=listen(listen_fd,5);
    if(ret==-1)
    {
        perror("cannot listen the client connect request");
        close(listen_fd);
        return 1;
    }
    //对每个连接来的客户端创建一个线程,单独与其进行通信
    //首先调用read函数读取客户端发送来的信息
    //将其转换成大写后发送回客户端
    //当输入“@”时,程序退出
    while(1)
    {
        len=sizeof(clt_addr);
        com_fd=accept(listen_fd,(struct sockaddr *)&clt_addr,&len);
        if(com_fd<0)
        {
            if(errno==EINTR)
            {
                continue;
            }
            else
            {
                perror("cannot accept client connect request");
                close(listen_fd);
                return 1;
            }
        }
        printf("com_fd=%d\n",com_fd);//打印建立连接的客户端产生的套节字
        if((pthread_create(&tid,NULL,thr_fn,&com_fd))==-1)
        {
            perror("pthread_create error");
            close(listen_fd);
            close(com_fd);
            return 1;
        }
    }
    return 0;
}
//打印线程 IDs
#include <pthread.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
pthread_t ntid;
void printids(const char *s) {
    pid_t pid;
    pthread_t tid;
    pid = getpid();
    tid = pthread_self();
    printf("%s pid %u tid %u (0x%x)\n", s, (unsigned int) pid,
    (unsigned int) tid, (unsigned int) tid);
}

void *thr_fn(void *arg) {
    printids("new thread: ");
    return ((void *) 0);
}

int main(void) {
    int err;
    err = pthread_create(&ntid, NULL, thr_fn, NULL);
    if (err != 0)
        printf("can‘t create thread: %s\n", strerror(err));
    printids("main thread:");
    sleep(1);
    exit(0);
}
时间: 2024-11-05 18:44:35

client_thread.c server_thread.c的相关文章

mjpg-streamer摄像头远程传输UVC

1 下载源代码 mjpg-streamer的源代码地址  https://github.com/codewithpassion/mjpg-streamer 嵌入式 mini2440版 https://github.com/vfonov/mjpg-streamer 2 编译 mjpg-streamermake 执行 export LD_LIBRARY_PATH="$(pwd)" ./mjpg_streamer -i "./input_uvc.so -y" -o &qu

远程视频监控之应用篇(mjpg-streamer)

转载请注明出处:http://blog.csdn.net/ruoyunliufeng/article/details/38515311 这篇文章将主要结合源码介绍mjpg-streamer,使小伙伴们了解视频监控的实现. 一.移植 tar xvf mjpg-streamer-r63.tar.gz cd mjpg-streamer-r63 修改所有的Makefile --(1) 将 CC=gcc 修改为 CC=arm-linux-gcc --(2) 修改plugins/input_uvc/Makf

Android Client 与 C# Server 的Socket通信

C# Socket Server 1.建立C# SocketServer 1 private void ServerStart() 2          { 3              //创建IPEndPoint 4              IPEndPoint ipep = new IPEndPoint(IPAddress.Parse("127.0.0.1"), 1234); 5              //创建Socket实例 6              server_S

python的socket通信实例

一.socket简介 1. 套接字 套接字是为特定网络协议(例如TCP/IP,ICMP/IP,UDP/IP等)套件对上的网络应用程序提供者提供当前可移植标准的对象. 它们允许程序接受并进行连接,如发送和接受数据.为了建立通信通道,网络通信的每个端点拥有一个套接字对象极为重要. 套接字为BSD UNIX系统核心的一部分,而且他们也被许多其他类似UNIX的操作系统包括Linux所采纳. 许多非BSD UNIX系统(如ms-dos,windows,os/2,mac os及大部分主机环境)都以库形式提供

第十七章 Python网络编程

Socket简介 在网络上的两个程序通过一个双向的通信连接实现数据的交换,这个链接的一端称为一个Socket(套接字),用于描述IP地址和端口. 建立网络通信连接至少要一对端口号(Socket),Socket本质是编程接口(API),对TCP/IP的封装,提供了网络通信能力. 每种服务都打开一个Socket,并绑定到端口上,不同的端口对应不同的服务,就像http对应80端口. Socket是面向C/S(客户端/服务器)模型设计,客户端在本地随机申请一个唯一的Socket号,服务器拥有公开的soc

Python网络编程(二)通过ThreadingMixIn实现多线程异步套接字程序

使用ThreadingMixIn类的特点: 在线程间共享应用的状态,与使用ForkingMixIn类相比避免进程间通信的复杂操作. 代码如下: 1 #! /usr/bin/python 2 3 import os 4 import socket 5 import threading 6 import SocketServer 7 8 SERVER_HOST = 'localhost' 9 SERVER_PORT = 0 10 BUF_SIZE = 1024 11 12 def client(ip

ForkingMixIn 示例

import os import socket import threading import SocketServer SERVER_HOST = 'localhost' SERVER_PORT = 0 #tells the kernel to pick up a port dynamically BUF_SIZE = 1024 ECHO_MSG = 'Hello echo server!' class ForkingClient(): '''A client to test forking

C#作业总结 (5)

这一块总结程序的核心部分,局域网内的聊天,这部分我没有使用固定的服务器,而是通过UDP确定聊天的对象,然后双方通过TCP进行聊天,点对点式的聊天. 首先分析一段TCP的服务器和客户端的代码,基本这个代码看懂了就差不多 服务器部分 #region 通信协议说明 // CONNECT|客户端名称 服务器接收 发送不同的客户端 初始化聊天室 // LISTEN|聊天室其他用户名称 客户端接收 初始化聊天室 // CHAT|客户名称|内容 服务器接收 发送消息 // JOIN|客户端名称 客户端接收 增

python 实现 netcat

import sys import socket import getopt import threading import subprocess listen = False command = False upload = False execute = "" target = "" upload_destination = "" port = 0 def usage():     print "BHP Net Tool"