Boost and ACE

都是非常好的东东,直到最近才开始看到,实在遗憾。
学习的时候一直觉得c++不够实用,原来是自己没有发现Boost这样优秀的地方,实在是太损失了。
最近已经基本完成了一个WinSock开发的重叠IO模型的SOCKET程序,然后又发现了ACE,之前也是不知道这么好的东东,sigh!
Boost库Boost库是一个经过千锤百炼、可移植、提供源代码的C++库,是一个可移植、开放源码的C++库,作为标准库的后备,是C++标准化进程的发动机之一。 Boost库由C++标准委员会库工作组成员发起,其中有些内容有望成为下一代C++标准库内容。在C++社区中影响甚大,其成员已近2000人。 Boost库为我们带来了最新、最酷、最实用的技术,是不折不扣的“准”标准库。
可从http://sourceforge.net/project/showfiles.php?group_id=7586下载安装boost库。大 部分boost库功能的使用只需包括相应头文件即可,少数(如正则表达式库,文件系统库等)需要链接库。里面有许多具有工业强度的库,如graph库。
C++名库 http://www.kuqin.com/redianjishu/boost.html

ACE  自适配通信环境(ADAPTIVE  Communication  Environment)是可自由使用、开放源码的面向
对象(OO)框架(framework),它实现了许多用于并发通信软件的核心模式。ACE 提供了一组丰富的可
重用C++包装外观(wrapper  facade)和框架组件,可跨多种平台完成通用的通信软件任务,其中包括:
事件多路分离和事件处理器分派、信号处理、服务初始化、进程间通信、共享内存管理、消息路由、分
布式服务动态(重)配置、并发执行和同步,等等。
ACE 的目标用户是高性能和实时通信服务和应用的开发者。它简化了使用进程间通信、事件多路分
离、显式动态链接和并发的OO 网络应用和服务的开发。此外,通过服务在运行时与应用的动态链接,A
CE 使系统的配置和重配置得以自动化。
ACE 正在进行持续的改进。Riverace 公司(http://www.riverace.com)采用开放源码商业模式对ACE
进行商业支持。此外,ACE 开发组的许多成员目前正在进行The  ACE  ORB(TAO,http://www.cs.wustl.
edu/~schmidt/TAO.html)的开发工作。
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Linux C++中实现WebSocket服务器端转发行情数据,可以使用以下步骤: 1. 使用第三方C++,如libwebsockets或uWebSockets等,来实现WebSocket服务器端。 2. 在服务器端编写代码,以便将行情数据发送到WebSocket客户端。可以使用网络,如boost::asio或ACE等,来管理网络连接和数据传输。 3. 在WebSocket服务器端中,使用JSON格式将行情数据打包并发送给客户端。可以使用第三方JSON,如RapidJSON或nlohmann/json等。 4. 为了便于管理和扩展,可以将WebSocket服务器端和行情数据转发逻辑分离到不同的模块中。 下面是一个简单的示例代码,展示如何使用libwebsockets实现WebSocket服务器端转发行情数据: ```c++ #include <libwebsockets.h> #include <iostream> #include <string> #include <vector> using namespace std; // 行情数据结构体 struct Quote { string symbol; double price; }; // 行情数据源 class QuoteSource { public: void addQuote(const Quote& quote) { quotes.push_back(quote); } const vector<Quote>& getQuotes() const { return quotes; } private: vector<Quote> quotes; }; // WebSocket服务器端 class WebSocketServer { public: WebSocketServer(int port) : port(port), context(NULL), listen_socket(NULL), quote_source(NULL) {} ~WebSocketServer() { if (listen_socket) { libwebsocket_close_and_free_session(context, listen_socket, LWS_CLOSE_STATUS_GOINGAWAY); } if (context) { libwebsocket_context_destroy(context); } } void setQuoteSource(QuoteSource* qs) { quote_source = qs; } bool start() { // 创建WebSocket协议上下文 struct libwebsocket_protocols protocols[] = { { "http-only", callback_http, 0 }, { "quote", callback_quote, sizeof(struct Quote) }, { NULL, NULL, 0 } }; struct libwebsocket_context_creation_info info = { .port = port, .protocols = protocols, .gid = -1, .uid = -1 }; context = libwebsocket_create_context(&info); if (!context) { cerr << "Failed to create WebSocket context" << endl; return false; } // 监听WebSocket连接 listen_socket = libwebsocket_create_server(context, 0, protocols, NULL, NULL, NULL, NULL, -1, -1); if (!listen_socket) { cerr << "Failed to create WebSocket server" << endl; libwebsocket_context_destroy(context); return false; } cout << "WebSocket server started on port " << port << endl; return true; } private: // HTTP回调函数 static int callback_http(struct libwebsocket_context* context, struct libwebsocket* wsi, enum libwebsocket_callback_reasons reason, void* user, void* in, size_t len) { return 0; } // 行情数据回调函数 static int callback_quote(struct libwebsocket_context* context, struct libwebsocket* wsi, enum libwebsocket_callback_reasons reason, void* user, void* in, size_t len) { switch (reason) { case LWS_CALLBACK_ESTABLISHED: // 新客户端连接 cout << "WebSocket client connected" << endl; break; case LWS_CALLBACK_SERVER_WRITEABLE: // 发送行情数据到客户端 if (quote_source) { const vector<Quote>& quotes = quote_source->getQuotes(); for (size_t i = 0; i < quotes.size(); ++i) { libwebsocket_write(wsi, (unsigned char*)&quotes[i], sizeof(Quote), LWS_WRITE_BINARY); } } break; case LWS_CALLBACK_CLOSED: // 客户端断开连接 cout << "WebSocket client disconnected" << endl; break; default: break; } return 0; } private: int port; struct libwebsocket_context* context; struct libwebsocket* listen_socket; QuoteSource* quote_source; }; int main() { // 创建WebSocket服务器 WebSocketServer server(8080); // 创建行情数据源 QuoteSource quote_source; // 添加行情数据 quote_source.addQuote({ "AAPL", 123.45 }); quote_source.addQuote({ "GOOGL", 234.56 }); // 设置行情数据源 server.setQuoteSource(&quote_source); // 启动WebSocket服务器 if (!server.start()) { return 1; } // 运行事件循环 while (true) { libwebsocket_service(server.getContext(), 50); } return 0; } ``` 在上面的示例代码中,我们使用libwebsockets创建了一个WebSocket服务器,并且在服务器端实现了一个行情数据源。在行情数据源中,我们添加了两个行情数据(AAPL和GOOGL),然后将行情数据源设置为WebSocket服务器的属性。在回调函数中,我们使用libwebsocket_write函数将行情数据发送到WebSocket客户端。 当我们运行这个示例程序时,它将启动一个WebSocket服务器,监听8080端口。如果我们使用浏览器或其他WebSocket客户端连接到这个服务器,它将发送行情数据到客户端。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值