刚看的c++11多线程,写个聊天室试试
编译的时候加上 c++11 和 多线程库
g++ -Wall -std=c++0x -pthread -o server server.cpp
server 和client 都是 q 退出
​1. [代码]server.cpp

#include <iostream>
#include <thread>
#include <arpa/inet.h>
#include <cstring>
#include <vector>
#include <algorithm>
#include <unistd.h>
using namespace std;
    vector<int> cli_vec;
    int listenfd, port;
    const char *ip = "127.0.0.1";
void SendMsg(char* buf, int connfd){
    //cout<<"now send..."<<endl;
    char *data = buf;
    int len;
    for(auto i=cli_vec.begin(); i!=cli_vec.end(); ++i){
        if(*i == connfd) continue;
        if((len=send(*i, data, strlen(data),0)) == -1){
            //cout<<"send error"<<endl;
        }else{
            //cout<<"Send: "<<data<<endl;
        }
    }
}
 
void RecvMsg(int connfd){
    int len;
    char buf[100];
    while(1){
        memset(buf, 0, sizeof(buf));
        //cout<<"now receive..."<<connfd<<endl;
        if((len = recv(connfd, buf,sizeof(buf), 0)) == -1){
            //cout<<"Falid to receive"<<endl;
        }
        if(0 == len){
            cout<<connfd<<" has exit the chatting room"<<endl;
            auto pos = find(cli_vec.begin(), cli_vec.end(), connfd);
            if(pos != cli_vec.end()){
                cli_vec.erase(pos);
            }
            break;
        }
        SendMsg(buf,connfd);
    }
}       
 
void WaitQuit(){
    char buf[100];
    while(1){
        cin>>buf;
        if(0 == strcmp(buf,"q")){
            for(auto i=cli_vec.begin(); i!=cli_vec.end(); i++){
                close(*i);
            }
            cli_vec.clear();
            close(listenfd);
            break;
        }
    }
    exit(0);
}
 
int main()
{
    if((listenfd=socket(AF_INET,SOCK_STREAM,0)) == -1){
        cout<<"socket error"<<endl;
        return -1;
    }
    cout<<"请输入端口号:";
    cin>>port;
    struct sockaddr_in serv_addr,cli_addr;
    memset(&serv_addr, 0, sizeof(serv_addr));
    serv_addr.sin_family = AF_INET;
    serv_addr.sin_port   = htons(port);
    serv_addr.sin_addr.s_addr = inet_addr(ip); 
    if(bind(listenfd, (struct sockaddr*)&serv_addr, sizeof(serv_addr)) == -1){
        cout<<"bind error"<<endl;
        return -1;
    }http://www.enterdesk.com/special/dushen/​
    if(listen(listenfd, 10) == -1){
        cout<<"listen error"<<endl;
        return -1;赌神
    }   
    std::thread(WaitQuit).detach();
    cout<<"server is running..."<<endl;
    while(1){
        size_t cli_len = sizeof(cli_addr);
        memset(&cli_addr, 0, cli_len);
 
        int connfd = accept(listenfd, (struct sockaddr*)&cli_addr, &cli_len);
        if(connfd == -1){
            cout<<"accept error"<<endl;
            return -1;
        }
        cout<<connfd<<" has enter the chatting room"<<endl;
        cli_vec.push_back(connfd);
        std::thread(RecvMsg, connfd).detach();
    }
    return 0;
}
2. [代码]client.cpp

#include <iostream>
#include <arpa/inet.h> // socket 相关 ...
#include <unistd.h>    // close()
#include <thread> 
#include <string>
#include <cstring>
using namespace std;
 
int sockfd;
struct sockaddr_in serv_addr;
 
void SendMsg(const string &msg) {
    if(-1 == send(sockfd, msg.c_str(), msg.size(), 0))
        cout<<"Failed to send"<<endl;
}
 
void RMsg(){
    int len;
    char recv_buf[1024];
    while (1) {
        memset(recv_buf, 0, sizeof(recv_buf));
        len = recv(sockfd, recv_buf, sizeof(recv_buf), 0);
        if (-1 == len) {
            cout<<"Failed to recv"<<endl;
        }
        if(0 == len){
            close(sockfd);
            cout<<"与服务器断开链接!"<<endl;
            break;
        }
        cout<<"Receive message: "<<recv_buf<<endl;
    }
}
 
int main()
{
    string ip = "127.0.0.1";
    int port;
    cout<<"please input server port:";
    cin>>port;
    sockfd = socket(AF_INET, SOCK_STREAM, 0);
    if (-1 == sockfd) {
        cout<<"Failed to sockfd"<<endl;
        return -1;
    }
    memset(&serv_addr, 0, sizeof(serv_addr));
    serv_addr.sin_family = AF_INET;
    serv_addr.sin_port = htons(port);
    serv_addr.sin_addr.s_addr = inet_addr(ip.c_str());
 
    int stat = connect(sockfd, (struct sockaddr *) &serv_addr,sizeof(serv_addr));
    if (-1 == stat) {
        cout<<"Failed to connect"<<endl;
        return -1;
    }
    std::thread(RMsg).detach();
    while(1)
    {
        string send_msg;
         
        cin>>send_msg;
        if (send_msg == "q")
        {
            cout<<"结束客户端!"<<endl;
            break;
        }
        else
            SendMsg(send_msg);
    }
    close(sockfd);
    return 0;
}

Linux下c++11多线程聊天室的更多相关文章

  1. Linux以下基于TCP多线程聊天室(client)

    不怎么会弄这个博客的排版,就直接将代码附上: 主要是使用多线程去等待接受数据和发送数据.以下是client的代码: tcpsed.h文件 1 2 3 4 5 6 7 8 9 10 11 12 13 1 ...

  2. Linux以下基于TCP多线程聊天室(server)

    接上篇博文,本文是server端的实现,主要实现的功能,就是现实client的连接.转发client发送的消息.以及client掉线提示等功能,同一时候能够在这这上面扩展和TCP以及线程相关的功能木块 ...

  3. linux下C语言多线程编程实例

    用一个实例.来学习linux下C语言多线程编程实例. 代码目的:通过创建两个线程来实现对一个数的递加.代码: //包含的头文件 #include <pthread.h> #include ...

  4. 【C++】基于socket的多线程聊天室(控制台版)

    以前学习socket网络编程和多线程编程的时候写的一个练手程序 聊天室基本功能: 1.用户管理:登录,注册,登出,修改用户名,修改密码 2.聊天室功能:群聊,私聊,获取在线用户列表,获取所有用户列表 ...

  5. TCP多线程聊天室

    TCP协议,一个服务器(ServerSocket)只服务于一个客户端(Socket),那么可以通过ServerSocket+Thread的方式,实现一个服务器服务于多个客户端. 多线程服务器实现原理— ...

  6. linux下C++的多线程编程

    1. 引言 线程(thread)技术早在60年代就被提出,但真正应用多线程到操作系统中去,是在80年代中期,solaris是这方面的佼佼者.传统的Unix也支持线程的概念,但是在一个进程(proces ...

  7. linux 下 多进程与多线程

    [Linux]多进程与多线程之间的区别 http://blog.csdn.net/byrsongqq/article/details/6339240 网络编程中设计并发服务器,使用多进程与多线程 ,请 ...

  8. 使用Html5下WebSocket搭建简易聊天室

    一.Html5WebSocket介绍 WebSocket protocol 是HTML5一种新的协议(protocol).它是实现了浏览器与服务器全双工通信(full-duplex). 现在,很多网站 ...

  9. Linux下c语言TCP多线程聊天室

    开发环境:Linux,GCC 相关知识:TCP(博客:传送门),线程 附加:项目可能还有写不足之处,有些bug没调出来(如:对在线人数的控制),希望大佬赐教. 那么话不多说,放码过来: 码云:传送门, ...

随机推荐

  1. Ubuntu14下Hadoop开发&lt;1&gt; 基础环境安装

    准备了一台淘汰的笔记本.单核CPU.3G内存.160G硬盘:准备一个2G的U盘 在官网下载了64位的14.04版本号(麒麟)的ISO.下载UNetbootin(Ubuntu专用U盘安装工具) 使用UN ...

  2. centos7 中文输入法设置

    安装centos7 后,他有自带的中文输入法安装包找到 applications->systemTools->settings->region&language 2:在 in ...

  3. csv文件中出现乱码的解决方法

    1.首先用UE打开CSV文件,发现没有乱码了. 2.然后新建一个txt文本,把CSV中的数据复制到txt文本中,保存格式为ANSI/ASCII. 3.复制txt文件,再把副本后缀改为CSV格式,再用E ...

  4. bzoj3174【TJOI2013】解救小矮人

    3174: [Tjoi2013]解救小矮人 Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 573  Solved: 293 [Submit][Stat ...

  5. Wormholes - poj 3259 (Bellman-Ford算法)

      Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 34934   Accepted: 12752 Description W ...

  6. mongodb 指南

    mongodb概述 mongodb安装 mongodb启动参数 mongodb权限体系 mongodb管理命令 mongodb备份恢复

  7. android菜鸟学习笔记21----ContentProvider(一)ContentProvider的简单使用

    ContentProvider是Android四大组件之一,它用来封装数据,并通过ContentResolver接口将数据提供给其他应用.只有当需要在多个应用之间共享数据时才会用到ContentPro ...

  8. POJ 2092 Grandpa is Famous【水---找出现第二多的数】

    链接: http://poj.org/problem?id=2092 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=27454#probl ...

  9. POJ 2187 Beauty Contest【旋转卡壳求凸包直径】

    链接: http://poj.org/problem?id=2187 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=22013#probl ...

  10. python+NLTK 自然语言学习处理四:获取文本语料和词汇资源

    在前面我们通过from nltk.book import *的方式获取了一些预定义的文本.本章将讨论各种文本语料库 1 古腾堡语料库 古腾堡是一个大型的电子图书在线网站,网址是http://www.g ...