简单客户端服务器模型(C++、python和go语言示例)
工作中用到了C/S模型,所做的也无非是给服务器发数据,但开发阶段会遇到程序自身的回环测试,需要用到简单的服务端以便验证数据发送的正确性。写软件用C++,跑测试用python,这段时间也刚好看go语言,所以都要有demo。以下三组程序实现的功能相同,这里一起做下总结。
一、C++实现
Boost.Asio是一个跨平台的C++库,它用现代C++方法为网络和底层I/O程序提供了一致的异步I/O模型。 为了跨平台,我用boost库实现,具体如下。
服务端代码:
1 /*
2 File : svr.cpp
3 Author : Mike
4 E-Mail : Mike_Zhang@live.com
5 */
6
7 #include
8 #include
9
10 using boost::asio::ip::tcp;
11 enum {max_length = 1024};
12
13 typedef boost::shared_ptr socket_ptr;
14
15 int main()
16 {
17 boost::asio::io_service io_service;
18 tcp::acceptor a(io_service, tcp::endpoint(tcp::v4(), atoi("12345")));
19 for (;;)
20 {
21 socket_ptr sock(new tcp::socket(io_service));
22 a.accept(*sock);
23 char data;
24 boost::system::error_code error;
25 size_t length = sock->read_some(boost::asio::buffer(data), error);
26 data = 0;
27 std::cout
页:
[1]