0

另一个问题中,用户提供了一种通过 UDP 向 QuartzComposer 发送数据的方法。看起来 QuartzComposer 对发送给它的字节数据的填充非常讲究。特别是它要求发送的每个字符都以“\0\0\0”开头。

我能够模拟一个快速的 Python 程序来解决这个问题:

from socket import *

PORT = 50000
N = 3.14159265358

# connect to Quartz Composer on localhost port 50000
s = socket(AF_INET, SOCK_DGRAM)
s.bind(('', 0))
s.setsockopt(SOL_SOCKET, SO_BROADCAST, 1)

for c in str(N):
    out = out + '\0\0\0' + c
s.sendto(out, ('225.0.0.0', PORT))

我需要在 C++ 中实现的关键部分是填充浮点数的位。这是关键部分的快速 Python 模型:

def padfloat(n):
    out = ''
    for c in str(n):
        out = out + '\0\0\0' + c
    return out

if __name__ == '__main__':
    print(padfloat(3.14159265358))

诚然,我的 C++ 代码不是那么紧,但我能够使用 boost 来启动和运行 UDP 并发送一条硬编码消息“0.7”:

//
// Working C++ to Quartz Network Test
// 

#include <cstdlib>
#include <cstring>
#include <iostream>
#include <boost/asio.hpp>

using boost::asio::ip::udp;

enum { max_length = 1024 };

int main(int argc, char* argv[])
{
  try
  {
boost::asio::io_service io_service;

udp::socket s(io_service, udp::endpoint(udp::v4(), 0));

udp::resolver resolver(io_service);
udp::resolver::query query(udp::v4(), "225.0.0.0", "50000");
udp::resolver::iterator iterator = resolver.resolve(query);

using namespace std; // For strlen.

// TODO: alter code to take in any number

for (;;) {
  std::cout << "Press Any Key to send 0.7: ";
  char request[max_length];
  std::cin.getline(request, max_length);
  // size_t request_length = strlen(request);
  char test [] = {0,0,0,'0',0,0,0,'.',0,0,0,'7','\0'};
  s.send_to(boost::asio::buffer(test, 12), *iterator);
  std::cout << "Sent\n";
}
  }
  catch (std::exception& e)
  {
std::cerr << "Exception: " << e.what() << "\n";
  }
  return 0;
}

我需要帮助的一个相当微不足道的问题是如何接收浮点数并将其正确格式化为 char 数组,以便在所有 "\0\0\0" 填充前正确发送。我即将做一些丑陋的事情,但如果有人能指出我的优雅修复,我会很乐意学习一点。

4

1 回答 1

1

我手边没有编译器,但这应该足够了。

  1. 我们进行字符串转换
  2. 创建一个大小为 4 倍的缓冲区(为空终止加 1),初始化为 0
  3. 在每第四个位置复制字符串。

我不确定 asio 是否希望空终止符成为其大小的一部分,所以我按照您的示例进行操作。

float float_value = 4.2f;
std::string str = boost::lexical_cast<std::string>(float_value);

std::vector<char> char_buff((str.size() * 4) + 1, 0);

for (size_t i = 0; i < str.size(); i++)
  char_buff[(i * 4) + 3] = str[i];

s.send_to(boost::asio::buffer(&char_buff[0], char_buff.size()), *iterator);
于 2011-09-09T22:11:53.040 回答