简单实例1

server.c

 #include <stdio.h>
 #include <string.h>
 #include <stdlib.h>
 #include <unistd.h>
 #include <netinet/in.h>
 #include <arpa/inet.h>
 #include <sys/socket.h>
 #include <pthread.h>

 int sockfd;//服务器socket
 ];//客户端的socketfd,100个元素,fds[0]~fds[99]
  ;//用来控制进入聊天室的人数为100以内
 char* IP = "0.0.0.0";
 ;
 typedef struct sockaddr SA;

 void init(){
     sockfd = socket(PF_INET,SOCK_STREAM,);
     ){
         perror("创建socket失败");
         exit(-);
     }
     struct sockaddr_in addr;
     addr.sin_family = PF_INET;
     addr.sin_port = htons(PORT);
     addr.sin_addr.s_addr = inet_addr(IP);
     ){
         perror("绑定失败");
         exit(-);
     }
     ) == -){
         perror("设置监听失败");
         exit(-);
     }
 }

 void SendMsgToAll(char* msg){
     int i;
     ;i < size;i++){
         ){
             printf("sendto%d\n",fds[i]);
             send(fds[i],msg,strlen(msg),);
         }
     }
 }

 void* service_thread(void* p){
     int fd = *(int*)p;
     printf("pthread = %d\n",fd);
     ){
         ] = {};
         ) <= ){
             int i;
             ;i < size;i++){
                 if (fd == fds[i]){
                     fds[i] = ;
                     break;
                 }
             }
                 printf("退出:fd = %dquit\n",fd);
                 pthread_exit((void*)i);
         }
         //把服务器接受到的信息发给所有的客户端
         SendMsgToAll(buf);
     }
 }

 void service(){
     printf("服务器启动\n");
     ){
         struct sockaddr_in fromaddr;
         socklen_t len = sizeof(fromaddr);
         int fd = accept(sockfd,(SA*)&fromaddr,&len);
         ){
             printf("客户端连接出错...\n");
             continue;
         }
         ;
         ;i < size;i++){
             ){
                 //记录客户端的socket
                 fds[i] = fd;
                 printf("fd = %d\n",fd);
                 //有客户端连接之后,启动线程给此客户服务
                 pthread_t tid;
                 pthread_create(&tid,,service_thread,&fd);
                 break;
             }
         if (size == i){
             //发送给客户端说聊天室满了
             char* str = "对不起,聊天室已经满了!";
             send(fd,str,strlen(str),);
             close(fd);
         }
         }
     }
 }

 int main(){
     init();
     service();
 }

client.c

 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 #include <unistd.h>
 #include <sys/socket.h>
 #include <netinet/in.h>
 #include <arpa/inet.h>
 #include <pthread.h>

 int sockfd;//客户端socket
 char* IP = "192.168.1.105";//服务器的IP
 ;//服务器服务端口
 typedef struct sockaddr SA;
 ];

 void init(){
     sockfd = socket(PF_INET,SOCK_STREAM,);
     struct sockaddr_in addr;
     addr.sin_family = PF_INET;
     addr.sin_port = htons(PORT);
     addr.sin_addr.s_addr = inet_addr(IP);
     ){
         perror("无法连接到服务器");
         exit(-);
     }
     printf("客户端启动成功\n");
 }

 void start(){
     pthread_t id;
     void* recv_thread(void*);
     pthread_create(&id,,recv_thread,);
     ] = {};
     sprintf(buf2,"%s进入了聊天室",name);
     send(sockfd,buf2,strlen(buf2),);
     ){
         ] = {};
         scanf("%s",buf);
         ] = {};
         sprintf(msg,"%s:%s",name,buf);
         send(sockfd,msg,strlen(msg),);
         ){
             memset(buf2,,sizeof(buf2));
             sprintf(buf2,"%s退出了聊天室",name);
             send(sockfd,buf2,strlen(buf2),);
             break;
         }
     }
     close(sockfd);
 }

 void* recv_thread(void* p){
     ){
         ] = {};
         ) <= ){
             return;
         }
         printf("%s\n",buf);
     }
 }

 int main(){
     init();
     printf("请输入您的名字:");
     scanf("%s",name);
     start();
     ;
 }

网络编程之socket编程实例的更多相关文章

  1. 网络编程之Socket代码实例

    网络编程之Socket代码实例 一.基本Socket例子 Server端: # Echo server program import socket HOST = '' # Symbolic name ...

  2. java网络编程之Socket编程

    概念 网络编程分为BIO(传统IO).NIO.AIO.Socket编程属于BIO这种传统IO. InetAddress java.net.InetAddress是JAVA中管理IP地址的类,常用 pu ...

  3. linux网络编程之socket编程(一)

    今天开始,继续来学习linux编程,这次主要是研究下linux下的网络编程,而网络编程中最基本的需从socket编程开始,下面正式开始学习: 什么是socket: 在学习套接口之前,先要回顾一下Tcp ...

  4. linux网络编程之socket编程(八)

    学习socket编程继续,今天要学习的内容如下: 先来简单介绍一下这五种模型分别是哪些,偏理论,有个大致的印象就成,做个对比,因为最终只会研究一个I/O模型,也是经常会用到的, 阻塞I/O: 先用一个 ...

  5. linux网络编程之socket编程(三)

    今天继续对socket编程进行学习,在学习之前,需要回顾一下上一篇中编写的回射客户/服务器程序(http://www.cnblogs.com/webor2006/p/3923254.html),因为今 ...

  6. linux网络编程之socket编程(二)

    今天继续对socket编程进行研究,这里会真正开如用socket写一个小例子,进入正题: TCP客户/服务器模型:   关于这个模型的流程这里就不多说了,比较容易理解,下面则利用这种模型来编写一个实际 ...

  7. linux网络编程之socket编程(十二)

    今天继续学习socket编程,期待的APEC会议终于在京召开了,听说昨晚鸟巢那灯火通明,遍地礼花,有点08年奥运会的架势,有种冲动想去瞅见一下习大大的真容,"伟大的祖国,我爱你~~~&quo ...

  8. linux网络编程之socket编程(十一)

    今天继续学习socket编程,这次主要是学习超时方法的封装,内容如下: ①.alarm[不常用,了解既可] 它的实现思路是这样的: 但是这种方案有一定的问题,因为闹钟可能会作为其它的用途,这时所设置的 ...

  9. linux网络编程之socket编程(十)

    今天继续socket编程的学习,最近晚上睡觉都没有发热,没有暖气的日子还是种煎熬,快乐的十一也已经走来,幸福有暖气的日子也快啦,好了,回到正题~ ①close终止了数据传送的两个方向. ②shutdo ...

随机推荐

  1. PAT 天梯赛 L2-005. 集合相似度 【SET】

    题目链接 https://www.patest.cn/contests/gplt/L2-005 思路 因为集合中的元素 是不重复的 所以用SET 来保存 集合 然后最后 查找一下 两个集合中共有元素 ...

  2. 通过socket和Udp协议简单实现一个群体聊天工具(控制台)

    编写一个聊天程序.有收数据的部分 和 发数据的部分.这两个部分需要同时执行,这就用到多线程技术,一个线程负责收,一个现象负责发. 因为收和发动作是不一致的,所以要定义两个run方法而且这两个方法要封装 ...

  3. ubuntu android studio 编译及运行错误Error retrieving parent for item: No resource found that matches the given name

    安装好android studio并且安装其它需要的SDK或组件后,根据向导生成新的项目, 编译或运行时可能会出现下面的错误: Error:Error retrieving parent for it ...

  4. java WEB学习笔记32:HttpSession 接口常用方法 及 HttpServletRequest接口中的Session方法 Demo

    本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...

  5. 手机端网页web开发要点

    1.初始化 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" c ...

  6. 使用Nginx后如何在web应用中获取用户ip及原理解释

    当nginx作为反向代理功能时,转发请求到后端服务器 通常需要使用如下命令为转发的请求增加请求头 X-Forwarded-For proxy_set_header X-Forwarded-For &q ...

  7. Spark操作算子本质-RDD的容错

    Spark操作算子本质-RDD的容错spark模式1.standalone master 资源调度 worker2.yarn resourcemanager 资源调度 nodemanager在一个集群 ...

  8. SetOperations

    无序集合,add的顺序不是存储顺序 1.add(K key, V value) 2.difference(K key, otherK[s]) :差集,返回Set 3.differenceAndStor ...

  9. zTree获取(子)节点

    var ids=[]; ids=getChildren(ids, treeNode);//TreeNode是选中节点,ids是子节点id数组,格式:123,223,4,55 1.获取直接子节点的id ...

  10. uva 111 History Grading(lcs)

    题目描述 在信息科学中有一些是关于在某些条件限制下,找出一些计算的最大值. 以历史考试来说好了,学生被要求对一些历史事件根据其发生的年代顺序来排列.所有事件顺序都正确的学生无疑的可以得满分.但是那些没 ...