zhangmeng
2024-04-09 2561a007b8d8999a4750046d0cfb3b1ad5af50ac
test_socket/bus_test.cpp
@@ -4,8 +4,10 @@
#include "usg_common.h"
#include "mm.h"
#include "logger_factory.h"
static Logger *logger = LoggerFactory::getLogger();
#include "bus_error.h"
static Logger *logger = LoggerFactory::getLogger();
 
BusServerSocket * server_socket;
void sigint_handler(int sig) {
@@ -27,14 +29,24 @@
  void *recvbuf;
  int size;
  int key;
  struct timespec timeout = {2, 0};
  int rv;
  ShmModSocket *sk = (ShmModSocket *)skptr;
  while ( true) {
    logger->debug("=========run_recv=====");
    sk->recvfrom_timeout( &recvbuf, &size, &key, &timeout);
    printf("收到订阅消息:%s\n", recvbuf);
    free(recvbuf);
  struct timespec timeout = {2, 0};
  while (true) {
    printf("run_recv before\n");
    // rv = sk->recvfrom_timeout( &recvbuf, &size, &key, &timeout);
    rv = sk->recvfrom( &recvbuf, &size, &key);
    if(rv == 0) {
      printf("收到订阅消息:%s\n", recvbuf);
      free(recvbuf);
    } else {
      printf("recvfrom error %d\n", rv);
    }
  }
  return NULL;
  
}
@@ -42,18 +54,22 @@
  ShmModSocket *sk = new ShmModSocket();
  
  pthread_t tid;
  pthread_create(&tid, NULL, run_recv, (void *)sk);
  int size;
  
  char action[512];
  char topic[512];
  char content[512];
  long i = 0;
  pthread_create(&tid, NULL, run_recv, (void *)sk);
  while (true) {
    //printf("Usage: pub <topic> [content] or sub <topic>\n");
    printf("Can I help you? sub, pub, desub or quit\n");
    scanf("%s",action);
    printf("Can I help you? sub, pub, desub or quit %d\n", i++);
    // scanf("%s", action);
    std::cin >> action;
    if(strcmp(action, "sub") == 0) {
      printf("Please input topic!\n");
      scanf("%s", topic);
@@ -119,4 +135,4 @@
  
  return 0;
}
}