工作中用到了C/S模型,所做的也無非是給服務器發數據,但開發階段會遇到程序自身的回環測試,需要用到簡單的服務端以便驗證數據發送的正確性。
寫軟件用C++,跑測試用python,這段時間也剛好看go語言,所以都要有demo。以下三組程序實現的功能相同,這里一起做下總結。
一、C++實現
Boost.Asio是一個跨平臺的C++庫,它用現代C++方法為網絡和底層I/O程序提供了一致的異步I/O模型。 為了跨平臺,我用boost庫實現,具體如下。
服務端代碼:
#include <iostream>
#include <boost/asio.hpp>
using boost::asio::ip::tcp;
enum {max_length = 1024};
typedef boost::shared_ptr<tcp::socket> socket_ptr;
int main()
{
boost::asio::io_service io_service;
tcp::acceptor a(io_service, tcp::endpoint(tcp::v4(), atoi("12345")));
for (;;)
{
socket_ptr sock(new tcp::socket(io_service));
a.accept(*sock);
char data[max_length];
boost::system::error_code error;
size_t length = sock->read_some(boost::asio::buffer(data), error);
data[length] = 0;
std::cout<<data<<std::endl;
sock->close();
}
return 0;
}
客戶端代碼:
using boost::asio::ip::tcp;
enum { max_length = 1024 };
int main(int argc, char* argv[])
{
boost::asio::io_service io_service;
tcp::resolver resolver(io_service);
tcp::resolver::query query(tcp::v4(), "127.0.0.1","12345");
tcp::resolver::iterator iterator = resolver.resolve(query);
tcp::socket s(io_service);
s.connect(*iterator);
std::cout << "Please input: ";
char request[max_length];
std::cin.getline(request, max_length);
size_t request_length = strlen(request);
boost::asio::write(s, boost::asio::buffer(request, request_length));
return 0;
}
編譯:g++ cli.cpp -o cli -lboost_system -lboost_thread-mt
二、python實現
服務端代碼:
客戶端代碼:
三、go語言實現
服務端代碼:
import(
"net"
"fmt"
"bufio"
)
func main() {
client,err := net.Listen("tcp","127.0.0.1:12345")
if err != nil {
fmt.Printf("Error : %s/n",err.String())
}
for {
if c, err := client.Accept(); err == nil {
defer c.Close()
line, _ := bufio.NewReader(c).ReadString('/n')
fmt.Println(line)
}
}
}
import(
"net"
"fmt"
)
func main() {
conn, err := net.Dial("tcp", "127.0.0.1:12345")
if err != nil {
fmt.Printf("Error : %s/n",err.String())
}
conn.Write([]byte("Just a test"))
}
運行效果(go語言為例):
好,就這些了,希望對你有幫助。
新聞熱點
疑難解答
圖片精選