c++ socket学习(1.6)
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                c++ socket学习(1.6)
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.                        
                                本文學(xué)習(xí)相關(guān)資料:
 C/C++ socket編程教程
環(huán)境:vs2015
 源碼:本文代碼
這次來看看UDP
 之前在c++ socket學(xué)習(xí)(1.2)講過UDP怎么發(fā)送了,那現(xiàn)在來做一個可以一直發(fā)送的。
這次沒有什么接收端和發(fā)送端了,畢竟誰發(fā)送誰就是發(fā)送端,誰接受就是接收端
先發(fā)送數(shù)據(jù)的叫發(fā)送端,先接收的叫接收端(使用bind函數(shù)的)
接收端
//前面省略了 bind(servSock, (SOCKADDR*)&sockAddr, sizeof(SOCKADDR));while (1) {//udp接收信息,先收為敬int recvlen = recvfrom(servSock, buf, readlen, 0,(sockaddr*)&clntAddr, &nSize);if (strcmp(buf, "exit") == 0) {break;}std::cout << clntAddr.sin_port << " " << "收到的信息是:" << buf << std::endl;//將接收的數(shù)據(jù)處理一下,再發(fā)回去buf[recvlen / 2] = 0;sendto(servSock, buf, recvlen, 0, (sockaddr*)&clntAddr, nSize); }發(fā)送端
int nSize = sizeof(sockaddr); while (1) {std::string sendMessage;std::cout << "輸入要發(fā)送的內(nèi)容(輸入exit結(jié)束):";std::cin >> sendMessage;sendto(client, sendMessage.c_str(), sendMessage.size() + 1, 0, (sockaddr*)&servAddr, sizeof(sockaddr));if (sendMessage.compare("exit") == 0) {break;}recvfrom(client, buf, readlen, 0, (sockaddr*)&servAddr, &nSize);std::cout << "我收到了接收端的:" << buf << std::endl; }接收端要綁定了,才能收到發(fā)送端的信息
那么發(fā)送端沒有綁定啊,是怎么接收到接收端處理過的信息呢?
原來發(fā)送端在調(diào)用sendto的時候,就需要一個IP地址和端口,程序沒有指明的話就由系統(tǒng)自己來分配了。
接收端可以通過recvfrom獲得了發(fā)送端的IP地址和端口,照著發(fā)回去就好了。
總結(jié)
以上是生活随笔為你收集整理的c++ socket学习(1.6)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: c++ socket学习(1.5)
- 下一篇: 颐和园退役军人免门票吗
