4 连接接口设计

4 连接接口设计

1 数据结构

1.1 连接实体 connections_s

struct connections_s {
    event_t *read;
    event_t *write;

    ukey_pool_t *m_cpool;
};

说明:
每个连接有一个内存块,并且连接分为读事件、写事件。

2 函数

2.1 conn_init

函数签名:
void conn_init(connections_t *c, int size)

函数实体:

void conn_init(connections_t *c, int size) {    
    int i;
    for (i = 0; i < size; i++) {
        c[i].m_cpool = ukey_create_pool(1024);
        c[i].read = NULL;
        c[i].write = NULL;
    }
}

说明:

初始化每个连接,给每个连接申请内存区域,初始化读事件、写事件

2.2 conn_set

函数签名:
int conn_set(int fd, int events, void (call_back)(int, int, void ))

函数实体:

int conn_set(int fd, int events, void (*call_back)(int, int, void *)) {
    if (fd > g_manager.nconnections) {
        fprintf(stderr, "fd max limits\n");
        return -1;
    }

    connections_t *new_conn = &g_manager.conn[fd];
    if (new_conn == NULL) {
        fprintf(stderr, "conn set error\n");
        return -1;
    }
    event_t *new_ev = (event_t *)ukey_palloc(new_conn->m_cpool, sizeof(event_t));
    if (new_ev == NULL) {
        fprintf(stderr, "alloc from coon m_cpoll error\n");
        return -1;
    }
    void *arg = (void *)new_ev;
    event_set(new_ev, fd, call_back, arg);
    event_add(g_manager.ep_fd, events, new_ev, 1);
    if (events & EPOLLIN) {
        new_conn->read = new_ev;
    }
    if (events & EPOLLOUT) {
        new_conn->write = new_ev;
    }
    
    return 0;
}   

说明:

根据传进的 fd ,找到对应的连接,设置连接的事件,并且注册回调函数

2.3 conn_free

函数签名:
void conn_free(int fd)

函数实体:

void conn_free(int fd) {
    
    if (fd == -1)
        return;
    connections_t *c = &g_manager.conn[fd];
    if (c == NULL)
        return ;
    if (c->read != NULL) {
        event_del(g_manager.ep_fd, c->read);
        event_set(c->read, -1, NULL, 0);
        
    } else if (c->write != NULL) {
        event_del(g_manager.ep_fd, c->write);
        event_set(c->write, -1, NULL, 0);
    }
}

说明:

根据传进的描述符,删除连接对应的事件,并不回收资源,复用描述符

转载于:https://www.cnblogs.com/eemjwu/p/10609640.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值