91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

UDP服務器客戶端編程流程的示例分析

發布時間:2021-12-06 12:22:41 來源:億速云 閱讀:150 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關UDP服務器客戶端編程流程的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

UDP編程流程

UDP提供的是無連接、不可靠的、數據報服務

UDP服務器客戶端編程流程的示例分析

UDP是盡最大能力進行傳輸,但是并不能保證可靠性,TCP的可靠性是因為一系列的機制保證可靠性,UDP丟包并不會重發,兩種協議并沒有優略之分,要區分不同的場景來區分,比如:進行文件傳輸,不能有數據丟失,TCP協議就更合

適,而進行實時視頻通話,UDP會根據恒定的速率進行發送,這樣的情況容許部分數據的丟失去追求更好的實時性,所以UDP更合適

流程:首先服務端與客戶端都需要套接字的創建socket()(UDP并沒有嚴格意義上的服務端與客戶端),然后服務端需要確定ip與端口bind(),等待接收接收數據recvfrom()(會記錄對方的ip和端口),在這里我們并沒有跟某個客戶端進行連接,只是接收發送過來的數據,客戶端發送數據sendto()(需要指定ip與端口),因為UDP并不像TCP建立連接,通過文件描述符來識別客戶端,只能通過發送與接收時識別ip與端口的方式來區分不同的數據,收發結束關閉套接字close()

UDP服務端代碼實現

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
#include<assert.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<arpa/inet.h>

int main()
{
	//創建套接字
	//參數:
	//AF_INET ipv4
	//SOCK_DGRAM UDP使用的數據報服務類型 (SOCK_STREAM 流式套接字TCP使用的服務類型
	//標志位 一般給 0
	int sockfd = socket(AF_INET,SOCK_DGRAM,0);
	assert(sockfd != -1);

	//創建套接字地址結構
	struct sockaddr_in saddr,caddr;
	memset(&saddr,0,sizeof(saddr));
	saddr.sin_family = AF_INET;
	saddr.sin_port = htons(6000);
	saddr.sin_addr.s_addr = inet_addr("127.0.0.1");

	//命名套接字
	int res = bind(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));
	assert(res != -1);

	while(1)
	{
		int len = sizeof(caddr);//這里專門存放在len中,是因為在recvfrom的時候接收一個指針
		char buff[128] = {0};

		//接受數據
		//參數:
		//服務端套接字
		//存放數據
		//存放大小
		//標志位 一般給0
		//存放客戶端地址信息(ip與端口)
		//caddr的大小
		recvfrom(sockfd,buff,127,0,(struct sockaddr*)&caddr,&len);
		printf("buff=%s\n",buff);

		//發送數據
		//參數:
		//服務端套接字
		//發送的數據
		//發送數據大小
		//標志位 一般給0
		//發送目標的地址信息
		//地址信息的大小
		sendto(sockfd,"ok",2,0,(struct sockaddr*)&caddr,sizeof(caddr));
	}
	//關閉套接字
	close(sockfd);
}

UDP客戶端代碼實現

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
#include<assert.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<arpa/inet.h>

int main()
{
	int sockfd = socket(AF_INET,SOCK_DGRAM,0);
	assert(sockfd != -1);

	//只需要指定服務器的ip與端口,客戶端自己的ip與端口由系統自動指定
	struct sockaddr_in saddr;
	memset(&saddr,0,sizeof(saddr));
	saddr.sin_family = AF_INET;
	saddr.sin_port = htons(6000);
	saddr.sin_addr.s_addr = inet_addr("127.0.0.1");

	while(1)
	{
		char buff[128] = {0};
		printf("input:\n");
		fgets(buff,128,stdin);

		if(strncmp(buff,"end",3) == 0)
		{
			break;
		}

		sendto(sockfd,buff,strlen(buff),0,(struct sockaddr*)&saddr,sizeof(saddr));
		memset(buff,0,128);
		int len = sizeof(saddr);
		recvfrom(sockfd,buff,127,0,(struct sockaddr*)&saddr,&len);
		//占用了saddr存放獲取對方的ip與端口,實際上并沒有改變都是一樣的
		printf("buff=%s\n",buff);
	}
	close(sockfd);
}

UDP服務端客戶端代碼詳解

執行服務端與客戶端的代碼

UDP服務器客戶端編程流程的示例分析

當我們打開多個窗口,啟動多個客戶端向服務端發送數據

UDP服務器客戶端編程流程的示例分析

UDP服務端的接收只是根據是否有數據發送過來,只要有發送過來的數據就進行接收,并不進行連接,即使將服務端關閉重新開啟,使用原本的客戶端依舊可以進行發送數據,因為他們本身之間并不存在相互的連接

UDP服務器客戶端編程流程的示例分析

假如將,服務端進行關閉不重啟,客戶端發送依舊發送出去sendto()不阻塞,但是會阻塞在recvfrom()這一步,簡單的說就是服務器只管接收數據或者向發送方發送數據,無論是誰都可以向其發送數據且無需任何連接

如果我們將服務端代碼進行修改

UDP服務器客戶端編程流程的示例分析

我們再通過客戶端向服務端發送數據

UDP服務器客戶端編程流程的示例分析

使用UDP協議的時候,當數據傳輸過來我們將數據包拆開只讀取設定大小的數據,其余就會丟掉,繼而丟失

UDP服務器客戶端編程流程的示例分析

每次發送都是一個獨立的數據包,因為每次的發送可能目的地址都不相同,對于TCP是可以將多次的數據合并進行發送的,因為在同一描述符同一連接內發送對象只有連接的另一方

感謝各位的閱讀!關于“UDP服務器客戶端編程流程的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

udp
AI

峡江县| 清水县| 治多县| 沧源| 辰溪县| 广昌县| 秀山| 广饶县| 元朗区| 佳木斯市| 安多县| 太康县| 门头沟区| 乐安县| 泸溪县| 会泽县| 杂多县| 贡山| 兰坪| 白朗县| 绿春县| 涿州市| 宁陕县| 林芝县| 岑巩县| 秭归县| 桐城市| 通辽市| 九龙城区| 九寨沟县| 安仁县| 大田县| 三原县| 济源市| 伊宁市| 亳州市| 南郑县| 满洲里市| 吴堡县| 唐河县| 曲水县|