欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于UDP服務(wù)器客戶端編程流程介紹

 更新時間:2021年12月06日 10:08:12   作者:悲傷土豆拌飯  
大家好,本篇文章主要講的是關(guān)于UDP服務(wù)器客戶端編程流程介紹,感興趣的同學(xué)趕快來看看吧,對你有幫助的話記得收藏

UDP編程流程

UDP提供的是無連接、不可靠的、數(shù)據(jù)報服務(wù)

在這里插入圖片描述

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

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

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

UDP服務(wù)端代碼實現(xiàn)

#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()
{
	//創(chuàng)建套接字
	//參數(shù):
	//AF_INET ipv4
	//SOCK_DGRAM UDP使用的數(shù)據(jù)報服務(wù)類型 (SOCK_STREAM 流式套接字TCP使用的服務(wù)類型
	//標(biāo)志位 一般給 0
	int sockfd = socket(AF_INET,SOCK_DGRAM,0);
	assert(sockfd != -1);

	//創(chuàng)建套接字地址結(jié)構(gòu)
	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};

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

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

UDP客戶端代碼實現(xiàn)

#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);

	//只需要指定服務(wù)器的ip與端口,客戶端自己的ip與端口由系統(tǒng)自動指定
	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服務(wù)端客戶端代碼詳解

執(zhí)行服務(wù)端與客戶端的代碼

在這里插入圖片描述

當(dāng)我們打開多個窗口,啟動多個客戶端向服務(wù)端發(fā)送數(shù)據(jù)

在這里插入圖片描述

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

在這里插入圖片描述

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

如果我們將服務(wù)端代碼進行修改

在這里插入圖片描述

我們再通過客戶端向服務(wù)端發(fā)送數(shù)據(jù)

在這里插入圖片描述

使用UDP協(xié)議的時候,當(dāng)數(shù)據(jù)傳輸過來我們將數(shù)據(jù)包拆開只讀取設(shè)定大小的數(shù)據(jù),其余就會丟掉,繼而丟失

在這里插入圖片描述

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

到此這篇關(guān)于關(guān)于UDP服務(wù)器客戶端編程流程介紹的文章就介紹到這了,更多相關(guān)UDP客戶端編程程流內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言實現(xiàn)自動發(fā)牌程序

    C語言實現(xiàn)自動發(fā)牌程序

    這篇文章主要介紹了利用C語言實現(xiàn)自動發(fā)牌程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • C語言中字符串和數(shù)字的相互轉(zhuǎn)換實現(xiàn)代碼

    C語言中字符串和數(shù)字的相互轉(zhuǎn)換實現(xiàn)代碼

    以下是對C語言中字符串和數(shù)字的相互轉(zhuǎn)換實現(xiàn)代碼進行了分析介紹,需要的朋友可以參考下
    2013-07-07
  • C++簡單又好用的基本運算符重載

    C++簡單又好用的基本運算符重載

    繼友元知識過后,就到了今天的C++運算符重載的內(nèi)容了,運算符重載是C++里比較重要的內(nèi)容。這篇博文不會一下子講完各種運算符重載,因為太多了了也不好吸收掌握,所以運算符重載我準備分多次記錄和分享,那么接下來進入正文
    2022-06-06
  • C++實現(xiàn)五子棋游戲

    C++實現(xiàn)五子棋游戲

    這篇文章主要為大家詳細介紹了C++實現(xiàn)五子棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C++中volatile關(guān)鍵字的使用詳解以及常見的誤解

    C++中volatile關(guān)鍵字的使用詳解以及常見的誤解

    volatile 關(guān)鍵字是一種類型修飾符,用它聲明的類型變量表示可以被某些編譯器未知的因素更改,比如:操作系統(tǒng),硬件或者其他線程等
    2020-01-01
  • C++的數(shù)據(jù)共享與保護你了解嗎

    C++的數(shù)據(jù)共享與保護你了解嗎

    這篇文章主要為大家詳細介紹了C語言零基礎(chǔ)入門的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • C語言使用DP動態(tài)規(guī)劃思想解最大K乘積與乘積最大問題

    C語言使用DP動態(tài)規(guī)劃思想解最大K乘積與乘積最大問題

    Dynamic Programming動態(tài)規(guī)劃方法采用最優(yōu)原則來建立用于計算最優(yōu)解的遞歸式,并且考察每個最優(yōu)決策序列中是否包含一個最優(yōu)子序列,這里我們就來展示C語言使用DP動態(tài)規(guī)劃思想解最大K乘積與乘積最大問題
    2016-06-06
  • C語言實現(xiàn)影院售票管理系統(tǒng)

    C語言實現(xiàn)影院售票管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)影院售票管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Linux中rm命令使用以及C/C++代碼實現(xiàn)

    Linux中rm命令使用以及C/C++代碼實現(xiàn)

    m 是remove 的縮寫,Linux中 rm 命令的功能為刪除一個目錄中的一個或多個文件或目錄,它也可以將某個目錄及其下的所有文件及子目錄均刪除,這篇文章主要給大家介紹了關(guān)于Linux中rm命令使用以及C/C++代碼實現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • C++實現(xiàn)高性能轉(zhuǎn)換大小寫算法示例

    C++實現(xiàn)高性能轉(zhuǎn)換大小寫算法示例

    大小寫轉(zhuǎn)換是我們作為一名程序員經(jīng)常會遇到,也必須要會的一個功能,下面這篇文章主要給大家介紹了關(guān)于C++實現(xiàn)高性能轉(zhuǎn)換大小寫算法的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。
    2018-01-01

最新評論