【linux】多进程实现聊天室功能

一、设计思路二、 代码展示三、
摘要由CSDN通过智能技术生成

一、设计思路


采用多进程的方式,实现聊天室功能。


客户端:开启一个子线程,接受用户输入的信息。
主线程负责将用户的信息发送给服务器,并且接受并显示服务器发送过来的消息


 服务器端: 每当有一个客户端发送了连接请求,就创建一个子进程处理。
 程序启动时,会开启一个共享内存,存放客户端发送过来的消息。
 并且每个客户端发送过来的消息,都会发送给每个连接的客户端,实现聊天室的功能。


二、 代码展示


1. 客户端代码:

参见 http://blog.csdn.net/realizelizijun2013/article/details/24671999#t2


2. 服务器端代码

/*
 * 功能: 每当有一个客户端发送了连接请求,就创建一个子进程处理
 * 程序启动时,会开启一个共享内存,存放客户端发送过来的消息
 * 并且每个客户端发送过来的消息,都会发送给每个连接的客户端,实现聊天室的功能
 * 作者: lizijun
 * 日期: 2014.05.18
 * 版本: 1.0
 */
#include <stdio.h>
#include <string.h>
#include <sys/select.h>
#include <sys/types.h> 
#include <sys/socket.h>
#include <sys/time.h>
#include <unistd.h>
#include <errno.h>
#include <netinet/in.h>     //for INADDR_ANY
#include <semaphore.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <sys/mman.h>
#include <sys/msg.h>        //for IPC_CREAT
#include <signal.h>         //for SIGCLD  
#include "charrrom_server_02.h"


sem_t *sem = NULL;  //POSIX有名信号量
int shm_id;         //系统V共享内存标识
static int iCurrentClientIndex = -1; //当前客户端的索引号


int main(void)
{
	int listenSocket = -1;
    
    InitSign();
	InitSocket(&listenSocket);
    CreateSem();
    CreateShareMemory();
	HandleClientConnect(listenSocket);
    
    return 0;
}

/*
 * 功能:初始化信号
 */
void InitSign(void)
{
    //父进程可将SIGCHLD的处理函数设为SIG_IGN
    //以使内核可以自动回收已终止的子进程的资源,防止僵尸进程
    signal(SIGCLD, SIG_IGN); 
}


/* 
 * 功能: 创建POSIX有名信号量 
 */
void CreateSem(void)
{
    int flag = 0;
    unsigned int value = 0;

    flag = O_CREAT | O_EXCL;
    value = 1;

    sem = sem_open(SEM_NAME_PATH, flag, 0644, value);
    if (SEM_FAILED == sem) //信号量可能存在
    {
        //如果信号量存在,删除,重新创建,目的是保证信号量初始化值为1
        //这样做的目的: 当进程异常断开,此时信号量又没有释放,再加上有名信号量是随内核存在的
        //当下次进程重启的时候,信号量就会处于使用状态,初始化是为0
        if (errno == EEXIST) 
        {
            printf("sem exist, create again.\n");
            sem_unlink(SEM_NAME_PATH);
            sem = sem_open(SEM_NAME_PATH, flag, 0644, value);
        } 
        if (SEM_FAILED == sem)
        {
            printf("sem_open error\n");
            return;
        }
    }
}

/* 
 * 功能: 创建系统V共享内存 
 */
void CreateShareMemory(void)
{
    key_t key;
    key = ftok(SHARE_MEMORY_PATH,0);
  • 2
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Linux系统的基于进程的聊天室实现主要依靠进程之间的通信来实现。在 Linux 中,进程之间的通信主要有管道通信、信号通信、共享内存通信和套接字通信。其中,套接字通信是实现基于进程的聊天室的最常用的方式。 套接字是一种抽象的通信机制,可以在不同的进程之间进行通信。在实现基于进程的聊天室,服务端和客户端之间可以创建一个套接字来进行双方的通信。例如,在服务端端口上监听套接字,当有客户端链接上来,为其创建一个新的套接字,并与客户端进行通信。 基于进程的聊天室需要实现以下几个方面: 1.服务端的监听:服务端先创建一个监听套接字,并开始监听该套接字上的连接请求。 2.客户端的连接:客户端创建一个套接字,并向服务端发送连接请求。 3.服务端的响应:当服务端收到客户端的连接请求,为其创建一个新的套接字,并开始与客户端进行通信。 4.双方的消息传递:双方通过套接字进行消息的传递,可以使用多线程实现并发传输。 5.客户端的断开:当客户端关闭套接字,服务端需要及关闭与之关联的套接字,并通知其他客户端。 总的来说,基于进程的聊天室实现需要面对的问题较多,例如进程间的通信、并发控制、数据传输等,需要熟悉 Linux 系统编程和网络编程的相关知识。同,考虑到聊天室的稳定性和安全性,需要采取一系列的技术手段来保证其正常运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值