C语言sendto()函数:经socket传送数据
生活随笔
收集整理的這篇文章主要介紹了
C语言sendto()函数:经socket传送数据
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
相關(guān)函數(shù):send, sendmsg, recv, recvfrom, socket
頭文件:#include <sys/types.h> ??#include <sys/socket.h>
定義函數(shù):int sendto(int s, const void * msg, int len, unsigned int flags, const struct?sockaddr * to, int tolen);
函數(shù)說(shuō)明:sendto() 用來(lái)將數(shù)據(jù)由指定的socket 傳給對(duì)方主機(jī). 參數(shù)s 為已建好連線的socket, 如果利用UDP協(xié)議則不需經(jīng)過(guò)連線操作. 參數(shù)msg 指向欲連線的數(shù)據(jù)內(nèi)容, 參數(shù)flags 一般設(shè)0, 詳細(xì)描述請(qǐng)參考send(). 參數(shù)to 用來(lái)指定欲傳送的網(wǎng)絡(luò)地址, 結(jié)構(gòu)sockaddr 請(qǐng)參考bind(). 參數(shù)tolen 為sockaddr 的結(jié)果長(zhǎng)度.
返回值:成功則返回實(shí)際傳送出去的字符數(shù), 失敗返回-1, 錯(cuò)誤原因存于errno 中.
錯(cuò)誤代碼:
1、EBADF 參數(shù)s 非法的socket 處理代碼.
2、EFAULT 參數(shù)中有一指針指向無(wú)法存取的內(nèi)存空間.
3、WNOTSOCK canshu s 為一文件描述詞, 非socket.
4、EINTR 被信號(hào)所中斷.
5、EAGAIN 此動(dòng)作會(huì)令進(jìn)程阻斷, 但參數(shù)s 的soket 為補(bǔ)課阻斷的.
6、ENOBUFS 系統(tǒng)的緩沖內(nèi)存不足.
7、EINVAL 傳給系統(tǒng)調(diào)用的參數(shù)不正確.
范例
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet.in.h>
#include <arpa.inet.h>
#define PORT 2345 /*使用的port */
main()
{
? ? int sockfd, len;
? ? struct sockaddr_in addr;
? ? char buffer[256];
? ? //建立socket
? ? if(sockfd = socket(AF_INET, SOCK_DGRAM, 0)) < 0)
? ? {
? ? ? ? perror ("socket");
? ? ? ? exit(1);
? ? }
? ? //填寫(xiě)sockaddr_in 結(jié)構(gòu)
? ? bzero(&addr, sizeof(addr));
? ? addr.sin_family = AF_INET;
? ? addr.sin_port = htons(PORT);
? ? addr.sin_addr = hton1(INADDR_ANY);
? ? if(bind(sockfd, &addr, sizeof(addr)) < 0)
? ? {
? ? ? ? perror("connect");
? ? ? ? exit(1);
? ? }
? ? while(1)
? ? {
? ? ? ? bezro(buffer, sizeof(buffer));
? ? ? ? len = recvfrom(socket, buffer, sizeof(buffer), 0, &addr &addr_len);
? ? ? ? //顯示client 端的網(wǎng)絡(luò)地址
? ? ? ? printf("receive from %s\n ", inet_ntoa(addr.sin_addr));
? ? ? ? //將字串返回給client 端
? ? ? ?sendto(sockfd, buffer, len, 0, &addr, addr_len);
? ? }
}
執(zhí)行:請(qǐng)參考recvfrom()
頭文件:#include <sys/types.h> ??#include <sys/socket.h>
定義函數(shù):int sendto(int s, const void * msg, int len, unsigned int flags, const struct?sockaddr * to, int tolen);
函數(shù)說(shuō)明:sendto() 用來(lái)將數(shù)據(jù)由指定的socket 傳給對(duì)方主機(jī). 參數(shù)s 為已建好連線的socket, 如果利用UDP協(xié)議則不需經(jīng)過(guò)連線操作. 參數(shù)msg 指向欲連線的數(shù)據(jù)內(nèi)容, 參數(shù)flags 一般設(shè)0, 詳細(xì)描述請(qǐng)參考send(). 參數(shù)to 用來(lái)指定欲傳送的網(wǎng)絡(luò)地址, 結(jié)構(gòu)sockaddr 請(qǐng)參考bind(). 參數(shù)tolen 為sockaddr 的結(jié)果長(zhǎng)度.
返回值:成功則返回實(shí)際傳送出去的字符數(shù), 失敗返回-1, 錯(cuò)誤原因存于errno 中.
錯(cuò)誤代碼:
1、EBADF 參數(shù)s 非法的socket 處理代碼.
2、EFAULT 參數(shù)中有一指針指向無(wú)法存取的內(nèi)存空間.
3、WNOTSOCK canshu s 為一文件描述詞, 非socket.
4、EINTR 被信號(hào)所中斷.
5、EAGAIN 此動(dòng)作會(huì)令進(jìn)程阻斷, 但參數(shù)s 的soket 為補(bǔ)課阻斷的.
6、ENOBUFS 系統(tǒng)的緩沖內(nèi)存不足.
7、EINVAL 傳給系統(tǒng)調(diào)用的參數(shù)不正確.
范例
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet.in.h>
#include <arpa.inet.h>
#define PORT 2345 /*使用的port */
main()
{
? ? int sockfd, len;
? ? struct sockaddr_in addr;
? ? char buffer[256];
? ? //建立socket
? ? if(sockfd = socket(AF_INET, SOCK_DGRAM, 0)) < 0)
? ? {
? ? ? ? perror ("socket");
? ? ? ? exit(1);
? ? }
? ? //填寫(xiě)sockaddr_in 結(jié)構(gòu)
? ? bzero(&addr, sizeof(addr));
? ? addr.sin_family = AF_INET;
? ? addr.sin_port = htons(PORT);
? ? addr.sin_addr = hton1(INADDR_ANY);
? ? if(bind(sockfd, &addr, sizeof(addr)) < 0)
? ? {
? ? ? ? perror("connect");
? ? ? ? exit(1);
? ? }
? ? while(1)
? ? {
? ? ? ? bezro(buffer, sizeof(buffer));
? ? ? ? len = recvfrom(socket, buffer, sizeof(buffer), 0, &addr &addr_len);
? ? ? ? //顯示client 端的網(wǎng)絡(luò)地址
? ? ? ? printf("receive from %s\n ", inet_ntoa(addr.sin_addr));
? ? ? ? //將字串返回給client 端
? ? ? ?sendto(sockfd, buffer, len, 0, &addr, addr_len);
? ? }
}
執(zhí)行:請(qǐng)參考recvfrom()
總結(jié)
以上是生活随笔為你收集整理的C语言sendto()函数:经socket传送数据的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Linux系统Shutdown命令定时关
- 下一篇: UDP sendto和recvfrom使