wangzhengquan
2020-07-25 48ae739d196e8a1ad681e5a54ad992302119bd83
update
3个文件已删除
8个文件已修改
85 ■■■■ 已修改文件
demo/dgram_mod_req_rep.c 4 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/libshm_queue.a 补丁 | 查看 | 原始文档 | blame | 历史
src/queue/include/shm_queue.h 4 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/socket/dgram_mod_socket.c 3 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/socket/include/dgram_mod_socket.h 59 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/socket/include/mod_socket.h 3 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
test_socket/Makefile 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
test_socket/dgram_mod_bus 补丁 | 查看 | 原始文档 | blame | 历史
test_socket/dgram_mod_bus.c 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
test_socket/dgram_mod_req_rep.c 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
test_socket/dgram_mod_survey 补丁 | 查看 | 原始文档 | blame | 历史
demo/dgram_mod_req_rep.c
@@ -6,7 +6,7 @@
#include "usg_common.h"
void server(int port) {
  void *socket = dgram_mod_open_socket(REQ_REP);
  void *socket = dgram_mod_open_socket();
  dgram_mod_bind(socket, port);
  int size;
  void *recvbuf;
@@ -23,7 +23,7 @@
}
void client(int port, char *sendbuf) {
  void *socket = dgram_mod_open_socket(REQ_REP);
  void *socket = dgram_mod_open_socket();
  int size;
  void *recvbuf;
  dgram_mod_sendandrecv(socket, sendbuf, strlen(sendbuf) + 1, port, &recvbuf, &size);
src/libshm_queue.a
Binary files differ
src/queue/include/shm_queue.h
@@ -99,12 +99,12 @@
{
    SemUtil::dec( queue->mutex);
    queue->reference--;
    LoggerFactory::getLogger().debug("SHMQueue destructor  reference===%d", queue->reference.load());
//LoggerFactory::getLogger().debug("SHMQueue destructor  reference===%d", queue->reference.load());
    if(queue->reference.load() == 0) {
        delete queue;
        hashtable_t *hashtable = mm_get_hashtable();
        hashtable_remove(hashtable, KEY);
printf("SHMQueue destructor delete queue\n");
// LoggerFactory::getLogger().debug("SHMQueue destructor delete queue\n");
    } else {
        SemUtil::inc(queue->mutex);
    }
src/socket/dgram_mod_socket.c
@@ -17,7 +17,6 @@
static Logger logger = LoggerFactory::getLogger();
typedef struct dgram_mod_socket_t {
    socket_mod_t mod;
  shm_socket_t *shm_socket;
  // pthread_t recv_thread;
  // <主题, 订阅者>
@@ -85,7 +84,7 @@
int dgram_mod_get_socket_port(void * _socket) {
int dgram_mod_get_port(void * _socket) {
    dgram_mod_socket_t * socket = (dgram_mod_socket_t *) _socket;
    return socket->shm_socket->port;
}
src/socket/include/dgram_mod_socket.h
@@ -7,41 +7,76 @@
#endif
enum socket_mod_t
{
    PULL_PUSH = 1,
    REQ_REP = 2,
    PAIR = 3,
    PUB_SUB = 4,
    SURVEY = 5,
    BUS = 6
};
/**
 * 创建socket
 * @return socket地址
*/
void *dgram_mod_open_socket();
/**
 * 关闭socket
 * @return 0 成功, 其他值 失败的错误码
*/
int dgram_mod_close_socket(void * _socket);
/**
 * 绑定端口到socket, 如果不绑定则系统自动分配一个
 * @return 0 成功, 其他值 失败的错误码
*/
int dgram_mod_bind(void * _socket, int port);
/**
 * 发送信息
 * @port 发送给谁
 * @return 0 成功, 其他值 失败的错误码
 */
int dgram_mod_sendto(void *_socket, const void *buf, const int size, const int port);
/**
 * 接收信息
 * @port 从谁哪里收到的信息
 * @return 0 成功, 其他值 失败的错误码
*/
int dgram_mod_recvfrom(void *_socket, void **buf, int *size, int *port);
/**
 * 发送请求信息并等待接收应答
 * @port 发送给谁
 * @return 0 成功, 其他值 失败的错误码
*/
int dgram_mod_sendandrecv(void * _socket, const void *send_buf, const int send_size, const int port, void **recv_buf, int *recv_size) ;
int dgram_mod_get_socket_port(void * _socket) ;
/**
 * 获取soket端口号
 */
int dgram_mod_get_port(void * _socket) ;
/**
 * 释放存储接收信息的buf
 */
void dgram_mod_free(void *buf) ;
/**
 * 启动bus
 *
 * @return 0 成功, 其他值 失败的错误码
*/
int start_bus(void * _socket);
/**
 * 订阅指定主题
 * @topic 主题
 * @size 主题长度
 * @port 总线端口
 */
int sub(void * _socket, void *topic, int size, int port);
/**
 * 发布主题
 * @topic 主题
 * @content 主题内容
 * @port 总线端口
 */
int pub(void * _socket, void *topic, int topic_size, void *content, int content_size, int port);
src/socket/include/mod_socket.h
@@ -25,6 +25,7 @@
/**
 * 关闭socket
 * @return 0 成功, 其他值 失败的错误码
*/
int mod_close_socket(void * _socket);
@@ -59,7 +60,7 @@
int mod_recv(void * _socket, void **buf, int *size) ;
/**
 * 释放接收信息的buf
 * 释放存储接收信息的buf
 */
void mod_free(void *buf);
test_socket/Makefile
@@ -14,7 +14,7 @@
include $(ROOT)/Make.defines.$(PLATFORM)
PROGS =    dgram_mod_bus dgram_mod_survey
PROGS =    dgram_mod_bus dgram_mod_survey dgram_mod_req_rep
build: $(PROGS)
test_socket/dgram_mod_bus
Binary files differ
test_socket/dgram_mod_bus.c
@@ -58,7 +58,7 @@
    }
   
  }
  printf("(%d) quit\n", dgram_mod_get_socket_port(socket));
  printf("(%d) quit\n", dgram_mod_get_port(socket));
  dgram_mod_close_socket(socket);
}
test_socket/dgram_mod_req_rep.c
@@ -44,7 +44,7 @@
}
void server(int port) {
  void *socket = dgram_mod_open_socket(REQ_REP);
  void *socket = dgram_mod_open_socket();
  dgram_mod_bind(socket, port);
     initThreadPool(socket);
@@ -58,7 +58,7 @@
}
void client(int port) {
  void *socket = dgram_mod_open_socket(REQ_REP);
  void *socket = dgram_mod_open_socket();
  int size;
  void *recvbuf;
  char sendbuf[512];
@@ -80,10 +80,10 @@
  char sendbuf[512];
  int scale = 100000;
  int i;
  void *socket = dgram_mod_open_socket(REQ_REP);
  void *socket = dgram_mod_open_socket();
    
    char filename[512];
    sprintf(filename, "test%d.txt", targ->id);
    sprintf(filename, "test%d.tmp", targ->id);
    FILE *fp = NULL;
    fp = fopen(filename, "w+");
test_socket/dgram_mod_survey
Binary files differ