当前位置: 首页>>代码示例>>C++>>正文


C++ zmq_send函数代码示例

本文整理汇总了C++中zmq_send函数的典型用法代码示例。如果您正苦于以下问题:C++ zmq_send函数的具体用法?C++ zmq_send怎么用?C++ zmq_send使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。


在下文中一共展示了zmq_send函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: test_block_on_send_no_peers

void test_block_on_send_no_peers (void *ctx)
{
    void *sc = zmq_socket (ctx, ZMQ_REQ);
    assert (sc);

    int timeout = 100;
    int rc = zmq_setsockopt (sc, ZMQ_SNDTIMEO, &timeout, sizeof (timeout));
    assert (rc == 0);

    rc = zmq_send (sc, 0, 0, ZMQ_DONTWAIT);
    assert (rc == -1);
    assert (errno == EAGAIN);

    rc = zmq_send (sc, 0, 0, 0);
    assert (rc == -1);
    assert (errno == EAGAIN);

    rc = zmq_close (sc);
    assert (rc == 0);
}
开发者ID:gigfork,项目名称:libzmq,代码行数:20,代码来源:test_spec_req.cpp

示例2: main

int main (int argc, char *argv [])
{
    const char *host;
    int message_size;
    int message_count;
    void *handle;
    int eid;
    int counter;
    void *out_buf;
    int rc;

    /*  Parse command line arguments.  */
    if (argc != 4) {
        printf ("usage: c_remote_thr <hostname> <message-size> "
            "<message-count>\n");
        return 1;
    }
    host = argv [1];
    message_size = atoi (argv [2]);
    message_count = atoi (argv [3]);
    
    /*  Create 0MQ transport.  */
    handle = zmq_create (host);

    /*  Create the wiring.  */
    eid = zmq_create_exchange (handle, "E", ZMQ_SCOPE_LOCAL, NULL,
        ZMQ_STYLE_LOAD_BALANCING);
    assert (eid != -1);

    rc = zmq_bind (handle, "E", "Q", NULL, NULL);
    assert (rc != -1);

    /*  Create message data to send.  */
    out_buf = malloc (message_size);
    assert (out_buf);

    for (counter = 0; counter != message_count + 1; counter ++)
        zmq_send (handle, eid, out_buf, message_size, ZMQ_TRUE);

    /*  Wait till all messages are sent.  */
#ifdef ZMQ_HAVE_WINDOWS
    Sleep (5000);
#else
    sleep (5);
#endif

    /*  Destroy 0MQ transport.  */
    zmq_destroy (handle);

    /*  Clean up.  */
    free (out_buf);

    return 0;
}
开发者ID:lobraco,项目名称:zeromq1,代码行数:54,代码来源:c_remote_thr.c

示例3: zmqdrv_send

static void
zmqdrv_send(zmq_drv_t *drv, ErlIOVec *ev)
{
    ErlDrvBinary*  bin   = ev->binv[1];
    char*          bytes = bin->orig_bytes;
    uint32_t       idx   = ntohl(*(uint32_t*)(bytes+1));
    zmq_sock_info* si    = drv->get_socket_info(idx);
    uint32_t       flags = ntohl(*(uint32_t*)(bytes+5));
    void*          data  = (void *)(bytes + 9);
    size_t         size  = bin->orig_size - 9;

    if (idx > drv->zmq_socket_count || !si) {
        zmqdrv_error_code(drv, ENODEV);
        return;
    }

#ifdef ZMQDRV_DEBUG
    uint32_t events;
    size_t events_size = sizeof(events);
    zmq_getsockopt(si->socket, ZMQ_EVENTS, &events, &events_size);
    zmqdrv_fprintf("sending %p [idx=%d] %lu bytes (events=%d)\r\n", si->socket, idx, size, events);
#endif

    if (si->out_caller != 0) {
        // There's still an unwritten message pending
        zmqdrv_error_code(drv, EBUSY);
        return;
    }

    // Increment the reference count on binary so that zmq can
    // take ownership of it.
    driver_binary_inc_refc(bin);

    if (zmq_msg_init_data(&si->out_msg, data, size, &zmq_free_binary, bin)) {
        zmqdrv_error_code(drv, zmq_errno());
        driver_binary_dec_refc(bin);
        return;
    }

    if (zmq_send(si->socket, &si->out_msg, flags | ZMQ_NOBLOCK) == 0) {
        zmqdrv_ok(drv);
        zmqdrv_ready_input((ErlDrvData)drv, (ErlDrvEvent)si->fd);
    } else {
        int e = zmq_errno();
        if (e == EAGAIN) {
            // No msg returned to caller - make him wait until async
            // send succeeds
            si->out_caller = driver_caller(drv->port);
            return;
        }
        zmqdrv_error_code(drv, e);
    }
    zmq_msg_close(&si->out_msg);
}
开发者ID:aceleste,项目名称:erlzmq,代码行数:54,代码来源:zmq_drv.cpp

示例4: reply_config

    void reply_config()
    {
      //zmq_msg_t reply;
      std::stringstream config_s;
      config_s << config;
      int reply_size = config_s.str().size();
      zmq_send(zmq_responder,
	       config_s.str().c_str(),
	       reply_size,
	       0);
    }
开发者ID:mahrz,项目名称:xxp,代码行数:11,代码来源:xxp.hpp

示例5: logevent

/* Send formatted message to url */
int
logevent(const char *url, const char *message)
{
	int rc, result;
	void *ctx, *socket;
	zmq_msg_t query;
	zmq_pollitem_t items[1];

	/* Send the message */
	rc = zmq_msg_init_size(&query, strlen(message));
	assert(rc == 0);

	memcpy(zmq_msg_data(&query), message, strlen(message));

	ctx = zmq_init (1, 1, ZMQ_POLL);
	assert(ctx);

	socket = zmq_socket(ctx, ZMQ_REQ);
	assert(socket);

	rc = zmq_connect(socket, url);
	assert(rc == 0);

	rc = zmq_send(socket, &query, 0);
	assert(rc == 0);

	zmq_msg_close(&query);

	/* Wait for a reply */
	rc = zmq_msg_init(&query);
	assert(rc == 0);

	items[0].socket = socket;
	items[0].events = ZMQ_POLLIN;
	rc = my_zmqpoll(items, 1, SEND_TIMEOUT);
	assert(rc >= 0);

	rc = zmq_recv(socket, &query, ZMQ_NOBLOCK);
	if (rc == -1 && errno == EAGAIN) {
		result = 0;
	} else {
		assert(rc == 0);
		zmq_msg_close(&query);
		result = 1;
	}

	/* Clean up - FIXME: random SEGV on zmq_term
	zmq_close(socket);
	zmq_term(ctx);
	*/

	return result;
}
开发者ID:dermoth,项目名称:supybot_NagiosLogger,代码行数:54,代码来源:client.c

示例6: endFrame

void endFrame()
{
	dataCache_t * temp = dataCacheHead;

	rI2CTX_beginFrame();

	while(temp != NULL)
	{
/*
		printf("%d ",temp->decParam.index);
		switch(temp->decParam.type)
		{
			case rI2C_INT8: printf("\tINT8 %d\n",*(int8_t*)(temp->decParam.val));break;
			case rI2C_UINT8: printf("\tUINT8 %d\n",*(uint8_t*)(temp->decParam.val));break;
			case rI2C_INT16: printf("\tINT16 %d\n",*(int16_t*)(temp->decParam.val));break;
			case rI2C_UINT16: printf("\tUINT16 %d\n",*(uint16_t*)(temp->decParam.val));break;
			case rI2C_INT32: printf("\tINT32 %d\n",*(int32_t*)(temp->decParam.val));break;
			case rI2C_UINT32: printf("\tUINT32 %d\n",*(uint32_t*)(temp->decParam.val));break;
			case rI2C_INT64: printf("\tINT64 %"PRId64"\n",*(int64_t*)(temp->decParam.val));break;
			case rI2C_UINT64: printf("\tUINT64 %"PRId64"\n",*(uint64_t*)(temp->decParam.val));break;
			case rI2C_FLOAT: printf("\tFLOAT %f\n",*(float*)(temp->decParam.val));break;
			case rI2C_DOUBLE: printf("\tDOUBLE %f\n",*(double*)(temp->decParam.val));break;
		}*/

		switch(temp->decParam.type)
		{
			case rI2C_INT8: rI2CTX_addParameter_int8(temp->decParam.index, *(int8_t*)(temp->decParam.val));break;
			case rI2C_UINT8: rI2CTX_addParameter_uint8(temp->decParam.index,*(uint8_t*)(temp->decParam.val));break;
			case rI2C_INT16: rI2CTX_addParameter_int16(temp->decParam.index,*(int16_t*)(temp->decParam.val));break;
			case rI2C_UINT16: rI2CTX_addParameter_uint16(temp->decParam.index,*(uint16_t*)(temp->decParam.val));break;
			case rI2C_INT32: rI2CTX_addParameter_int32(temp->decParam.index,*(int32_t*)(temp->decParam.val));break;
			case rI2C_UINT32: rI2CTX_addParameter_uint32(temp->decParam.index,*(uint32_t*)(temp->decParam.val));break;
			case rI2C_INT64: rI2CTX_addParameter_int64(temp->decParam.index,*(int64_t*)(temp->decParam.val));break;
			case rI2C_UINT64: rI2CTX_addParameter_uint64(temp->decParam.index,*(uint64_t*)(temp->decParam.val));break;
			case rI2C_FLOAT: rI2CTX_addParameter_float(temp->decParam.index,*(float*)(temp->decParam.val));break;
			case rI2C_DOUBLE: rI2CTX_addParameter_double(temp->decParam.index,*(double*)(temp->decParam.val));break;
		}
		temp = temp->next;
	}
	rI2CTX_endFrame();

	if((rI2CTX_bufferPos + strlen(nodeName) + strlen(nodeName)) < sizeof(buffer)){
		char * t = "telemetry ";
		memcpy(&buffer,t,strlen(t));
		memcpy(buffer + strlen(t),nodeName,strlen(nodeName));
		memcpy(buffer + strlen(t) + strlen(nodeName), &rI2CTX_buffer,rI2CTX_bufferPos + strlen(t) + strlen(nodeName));
		zmq_send(pubTelemetry, buffer, rI2CTX_bufferPos+strlen(t)+strlen(nodeName), 0);
	}else{
		printf("ZMQ TX buffer too small.\n");
	}


}
开发者ID:rLoopTeam,项目名称:bsc-slave-tools,代码行数:53,代码来源:uarttelemetry.c

示例7: while

void *run(void *arg)
{
        int ret;
        char buf[256];
        while (1) {
                        zmq_recv(rep, buf, sizeof(buf), 0);
                        printf("rep recv: %s\n", buf);

                        ret = zmq_send(rep, "rep recv done", 16, 0);
                        assert(ret == 16);
        }
}
开发者ID:github188,项目名称:doc-1,代码行数:12,代码来源:server.c

示例8: main

int main (int argc, char *argv [])
{
    const char *bind_to;
    int roundtrip_count;
    int message_size;
    void *ctx;
    void *s;
    int rc;
    int i;
    zmq_msg_t msg;

    if (argc != 4) {
        printf ("usage: local_lat <bind-to> <message-size> "
            "<roundtrip-count>\n");
        return 1;
    }
    bind_to = argv [1];
    message_size = atoi (argv [2]);
    roundtrip_count = atoi (argv [3]);

    ctx = zmq_init (1, 1, 0);
    assert (ctx);

    s = zmq_socket (ctx, ZMQ_REP);
    assert (s);

    rc = zmq_bind (s, bind_to);
    assert (rc == 0);

    rc = zmq_msg_init (&msg);
    assert (rc == 0);

    for (i = 0; i != roundtrip_count; i++) {
        rc = zmq_recv (s, &msg, 0);
        assert (rc == 0);
        assert (zmq_msg_size (&msg) == message_size);
        rc = zmq_send (s, &msg, 0);
        assert (rc == 0);
    }

    rc = zmq_msg_close (&msg);
    assert (rc == 0);

    zmq_sleep (1);

    rc = zmq_close (s);
    assert (rc == 0);

    rc = zmq_term (ctx);
    assert (rc == 0);

    return 0;
}
开发者ID:kmnb,项目名称:zeromq2,代码行数:53,代码来源:local_lat.c

示例9: while

void Chat::run()
{
	char buff[1024] = { 0 };
	zmq_pollitem_t items[3] = { 0 };

	items[0].socket = subscriber_;
	items[0].events = ZMQ_POLLIN;

	items[1].socket = gate_;
	items[1].events = ZMQ_POLLIN;

	items[2].fd = STDIN_FILENO;
	items[2].events = ZMQ_POLLIN;

	while(true)
	{
		int len;
		int ret = zmq_poll(items, 3, -1);

		if (items[0].revents & ZMQ_POLLIN)
		{
			len = zmq_recv(items[0].socket, buff, sizeof(buff), 0);
			if (len > 0)
			{
				buff[len] = 0;
				std::cout << buff << std::endl;
			}
			else
			{
				std::cerr << zmq_strerror(errno);
			}
		}

		if (items[1].revents & ZMQ_POLLIN)
		{
			len = zmq_recv(items[1].socket, buff, sizeof(buff), 0);
			if (len > 0)
			{
				handle_gate((Action*)buff);
			}
			else
			{
				std::cerr << zmq_strerror(errno);
			}
		}

		if (items[2].revents & ZMQ_POLLIN)
		{
			std::cin.getline(buff, sizeof(buff));
			zmq_send(publisher_, buff, std::cin.gcount(), 0);
		}
	}
}
开发者ID:jinesliang,项目名称:GroupChat,代码行数:53,代码来源:chat.cpp

示例10: LOG_DEBUG

void Statistic::reporter()
{
  LOG_DEBUG("Initializing inproc://%s statistic reporter", _statname.c_str());

  _publisher = stack_data.stats_aggregator->get_internal_publisher(_statname);

  std::vector<std::string> new_value;

  while (_stat_q.pop(new_value))
  {
    LOG_DEBUG("Send new value for statistic %s, size %d", _statname.c_str(), new_value.size());
    std::string status = "OK";

    // If there's no message, just send the envelope and status line.
    if (new_value.empty())
    {
      zmq_send(_publisher, _statname.c_str(), _statname.length(), ZMQ_SNDMORE);
      zmq_send(_publisher, status.c_str(), status.length(), 0);
    }
    else
    {
      // Otherwise send the envelope, status line, and body, remembering to set SNDMORE on all
      // but the last section.
      zmq_send(_publisher, _statname.c_str(), _statname.length(), ZMQ_SNDMORE);
      zmq_send(_publisher, status.c_str(), status.length(), ZMQ_SNDMORE);
      std::vector<std::string>::iterator it;
      for (it = new_value.begin(); it + 1 != new_value.end(); ++it)
      {
        zmq_send(_publisher, it->c_str(), it->length(), ZMQ_SNDMORE);
      }
      zmq_send(_publisher, it->c_str(), it->length(), 0);
    }
  }
}
开发者ID:sa4250mnpo70,项目名称:sprout,代码行数:34,代码来源:statistic.cpp

示例11: main

int main(int argc, char * argv[])
{
	void * pCtx = NULL;
	void * pSock = NULL;
	//使用tcp协议进行通信,需要连接的目标机器IP地址为192.168.1.2
	//通信使用的网络端口 为7766 
	const char * pAddr = "tcp://127.0.0.1:7766";//"tcp://192.168.1.198:7766";

	//创建context 
	if ((pCtx = zmq_ctx_new()) == NULL)
	{
		return 0;
	}
	//创建socket 
	if ((pSock = zmq_socket(pCtx, ZMQ_DEALER)) == NULL)
	{
		zmq_ctx_destroy(pCtx);
		return 0;
	}
	int iSndTimeout = 5000;// millsecond
	//设置接收超时 
	if (zmq_setsockopt(pSock, ZMQ_RCVTIMEO, &iSndTimeout, sizeof(iSndTimeout)) < 0)
	{
		zmq_close(pSock);
		zmq_ctx_destroy(pCtx);
		return 0;
	}
	//连接目标IP192.168.1.2,端口7766 
	if (zmq_connect(pSock, pAddr) < 0)
	{
		zmq_close(pSock);
		zmq_ctx_destroy(pCtx);
		return 0;
	}
	//循环发送消息 
	while (1)
	{
		static int i = 0;
		char szMsg[1024] = { 0 };
		sprintf_s(szMsg, "hello world : %3d", i++);
		printf("Enter to send...\n");
		if (zmq_send(pSock, szMsg, sizeof(szMsg), 0) < 0)
		{
			fprintf(stderr, "send message faild\n");
			continue;
		}
		printf("send message : [%s] succeed\n", szMsg);
		getchar();
	}

	return 0;
}
开发者ID:zhouxicai,项目名称:ToolCode,代码行数:52,代码来源:zmq_send_1.cpp

示例12: main

int main(int argc, char *argv[])
{
  if (argc < 2) return EXIT_FAILURE;
  int N = atoi(argv[1]);

  printf("N: %d\n", N);

  void *ctx = zmq_init(1);
  void *server = zmq_socket(ctx, ZMQ_REQ); // Server
  assert(server);

  int rc;
  rc = zmq_connect(server, "tcp://localhost:8889"); // Actively connect to subscribers
  assert(rc == 0);

  int *val = (int *)calloc(N, sizeof(int));
  zmq_msg_t msg;

  long long start_time = sc_time();

  // Send
  int *buf = (int *)calloc(N, sizeof(int));
  memcpy(buf, val, N * sizeof(int));
  zmq_msg_init_data(&msg, buf, N * sizeof(int), _dealloc, NULL);
  zmq_send(server, &msg, 0);
  zmq_msg_close(&msg);

  // Receive
  zmq_msg_init(&msg);
  zmq_recv(server, &msg, 0);
  memcpy(val, (int *)zmq_msg_data(&msg), zmq_msg_size(&msg));
  zmq_msg_close(&msg);

  long long end_time = sc_time();

  printf("%s: Time elapsed: %f sec\n", argv[0], sc_time_diff(start_time, end_time));

#ifdef __DEBUG__
  int i;
  printf("%s [ ", argv[0]);
  for (i=0; i<N; ++i) {
    printf("%d ", val[i]);
  }
  printf("]\n");
#endif

  free(val);
  zmq_close(server);
  zmq_term(ctx);

  return EXIT_SUCCESS;
}
开发者ID:D4vidH4mm3r,项目名称:sessc,代码行数:52,代码来源:zmq0_p2p.c

示例13: zmq_send

	void ZmqAppender::append(const log4cplus::spi::InternalLoggingEvent& event)
	{
		if (m_responder != NULL)
		{
			log4cplus::tostringstream oss;
			layout->formatAndAppend(oss, event);
			tstring formattedEvent = oss.str();

			zmq_send(m_responder, formattedEvent.c_str(), formattedEvent.length(), 0);
			char controlByte;
			zmq_recv(m_responder, &controlByte, 1, 0);
		}
	}
开发者ID:SlavaC1,项目名称:ControlSW,代码行数:13,代码来源:ZmqAppender.cpp

示例14: strcpy

void Heartbeat::report_newcomer(const std::string& peer_id, const std::string& peer_ip)
{
	Action action;
	action.type_ = JOIN;
	strcpy(action.id_, peer_id.c_str());
	strcpy(action.ip_, peer_ip.c_str());

	int ret = zmq_send(gate_, (void*)&action, sizeof(action), 0);
	if (ret < 0)
	{
		zmq_strerror(errno);
	}
}
开发者ID:jinesliang,项目名称:GroupChat,代码行数:13,代码来源:heartbeat.cpp

示例15: main

int main(void)
{
  void *ctx = zmq_ctx_new();
  void *sock = zmq_socket(ctx, ZMQ_ROUTER);
  int rc = zmq_bind(sock, "tcp://127.0.0.1:5555");
  assert(0 == rc);

  char buf[128];
  int recvBytes = 0;
  while (1) {
    // recv  id
    recvBytes = zmq_recv(sock, buf, sizeof(buf), 0);
    if (0 < recvBytes) {
      // send it back
      printf("recv id bytes=%d\n", recvBytes);

      zmq_send(sock, buf, recvBytes, ZMQ_SNDMORE);
    }

    // delimiter emtpy frame
    recvBytes = zmq_recv(sock, buf, sizeof(buf), 0);
    assert(0 == recvBytes);

    recvBytes = zmq_recv(sock, buf, sizeof(buf), 0);
    // actual message
    if (0 < recvBytes) {
      // send it back
      buf[recvBytes] = '\0';
      printf("recv msg %s, bytes=%d\n", buf, recvBytes);

      zmq_send(sock, "", 0, ZMQ_SNDMORE);
      zmq_send(sock, buf, recvBytes, 0);
    }
  }

  zmq_close(sock);
  zmq_ctx_destroy(ctx);
  return 0;
}
开发者ID:oopschen,项目名称:zeromq-learn,代码行数:39,代码来源:router.c


注:本文中的zmq_send函数示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。