. UDP Socket编程

先讲一讲UDP编程,因为比TCP要简单多了。首先,我们需要明白UDP是用户数据报协议,英文名为User Datagram Protocol,它是面向无连接的。

注意:Socket通信一定有要服务端和客户端。
1.1 UDP Socket客户端 客户端的工作流程:首先调用socket函数创建一个Socket,然后指定服务端的IP地址和端口号,就可以调用sendto将字符串传送给服务器端,并可以调用recvfrom接收服务器端返回的字符串,最后关闭该socket。 笔者这里分成了四步: 第一步:创建socket并配置socket,如服务端ip地址和端口号
第二步:调用sendto发送消息到服务器端
第三步:调用recvfrom接收来自服务器端的消息
第四步:调用close关闭socket 1.1. 客户端的代码实现: - (void)udpClient {
int clientSocketId;
ssize_t len;
socklen_t addrlen;
struct sockaddr_in client_sockaddr;
char buffer[] = "Hello, server, how are you?"; // 第一步:创建Socket
clientSocketId = socket(AF_INET, SOCK_DGRAM, );
if(clientSocketId < ) {
NSLog(@"creat client socket fail\n");
return;
} addrlen = sizeof(struct sockaddr_in);
bzero(&client_sockaddr, addrlen);
client_sockaddr.sin_family = AF_INET;
client_sockaddr.sin_addr.s_addr = inet_addr("192.168.1.107");
client_sockaddr.sin_port = htons(); int count = ;
do {
bzero(buffer, sizeof(buffer));
sprintf(buffer, "%s", "Hello, server, how are you?"); // 第二步:发送消息到服务端
// 注意:UDP是面向无连接的,因此不用调用connect()
// 将字符串传送给server端
len = sendto(clientSocketId, buffer, sizeof(buffer), , (struct sockaddr *)&client_sockaddr, addrlen); if (len > ) {
NSLog(@"发送成功");
} else {
NSLog(@"发送失败");
} // 第三步:接收来自服务端返回的消息
// 接收server端返回的字符串
bzero(buffer, sizeof(buffer));
len = recvfrom(clientSocketId, buffer, sizeof(buffer), , (struct sockaddr *)&client_sockaddr, &addrlen);
NSLog(@"receive message from server: %s", buffer); count--;
} while (count >= ); // 第四步:关闭socket
// 由于是面向无连接的,消息发出处就可以了,不用管它收不收得到,发完就可以关闭了
close(clientSocketId);
} 1.1. 客户端的打印日志 -- ::36.095 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.286 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.286 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.291 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.291 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.296 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.296 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.316 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.317 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.324 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.324 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.328 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.329 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.339 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.339 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.355 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.356 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.366 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.366 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.372 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.373 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.392 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you? 1.2 UDP Socket服务器端 服务器端的工作流程:首先调用socket函数创建一个套接字,然后调用bind函数将其与本机地址以及一个本地端口号绑定,接收到一个客户端时,服务器显示该客户端的IP地址,并将字串返回给客户端。 笔者这里分成了五步: 第一步:创建socket并配置socket
第二步:调用bind绑定服务器本机ip及端口号
第三步:调用recvfrom接收来自客户端的消息
第四步:调用sendto将接收到服务器端的信息返回给客户端
第四步:调用close关闭socket 1.2. 服务器端代码实现 - (void)udpServer {
int serverSockerId = -;
ssize_t len = -;
socklen_t addrlen;
char buff[];
struct sockaddr_in ser_addr; // 第一步:创建socket
// 注意,第二个参数是SOCK_DGRAM,因为udp是数据报格式的
serverSockerId = socket(AF_INET, SOCK_DGRAM, ); if(serverSockerId < ) {
NSLog(@"Create server socket fail");
return;
} addrlen = sizeof(struct sockaddr_in);
bzero(&ser_addr, addrlen); ser_addr.sin_family = AF_INET;
ser_addr.sin_addr.s_addr = htonl(INADDR_ANY);
ser_addr.sin_port = htons(); // 第二步:绑定端口号
if(bind(serverSockerId, (struct sockaddr *)&ser_addr, addrlen) < ) {
NSLog(@"server connect socket fail");
return;
} do {
bzero(buff, sizeof(buff)); // 第三步:接收客户端的消息
len = recvfrom(serverSockerId, buff, sizeof(buff), , (struct sockaddr *)&ser_addr, &addrlen);
// 显示client端的网络地址
NSLog(@"receive from %s\n", inet_ntoa(ser_addr.sin_addr));
// 显示客户端发来的字符串
NSLog(@"recevce:%s", buff); // 第四步:将接收到的客户端发来的消息,发回客户端
// 将字串返回给client端
sendto(serverSockerId, buff, len, , (struct sockaddr *)&ser_addr, addrlen);
} while (strcmp(buff, "exit") != ); // 第五步:关闭socket
close(serverSockerId);
} 1.2. 服务器端的打印日志 -- ::36.268 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.269 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.372 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.372 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.377 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.377 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.382 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.382 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.405 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.405 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.409 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.410 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.414 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.415 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.425 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.426 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.441 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.441 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.452 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.452 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.472 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.473 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you? 我们这里打印出了客户端发来的消息,由于上面实现的代码中,只发10次,所以这里只有10条。 参考:https://github.com/CoderJackyHuang/iOS-Socket-C-Version 注意:这里面有两个工程,一个是客户端,一个是服务器端。运行时,先运行服务器端,然后再选择客户端。另外,客户端所指定的服务器端的ip地址一定要修改成您本机对应的ip,不然使用笔者这里的ip就会失败。

iOS Socket编程-C语言版(UDP)的更多相关文章

  1. iOS Socket编程-C语言版(TCP)

    . TCP Socket编程 TCP是面向连接的,安全可靠的传输层协议.TCP的程序基本框架设计图: TCP的程序基本框架设计图.jpg 注意:Socket通信一定有要服务端和客户端. 1.1 TCP ...

  2. 计算机网络(十三),Socket编程实现TCP和UDP

    十三.Socket编程实现TCP和UDP 1.TCP (1)TCPServer.java类 package com.interview.javabasic.socket; import com.int ...

  3. 教孩子学编程 python语言版PDF高清完整版免费下载|百度云盘|Python入门

    百度云盘:教孩子学编程 python语言版PDF高清完整版免费下载 提取码:mnma 内容简介 本书属于no starch的经典系列之一,英文版在美国受到读者欢迎.本书全彩印刷,寓教于乐,易于学习:读 ...

  4. python socket 编程(TCP与UDP)

    实验环境:python2 一.TCP编程 1.建立TCP服务器 ①创建TCPServer.py文件 ②编写服务器代码 1)创建socket对象,调用socket构造函数 2)绑定ip端口(IP号和端口 ...

  5. Socket编程(C语言实现):socket()函数英文翻译

    最近开始研究使用Socket API来网络编程,想着把自己的感想.感悟写下来.我发现在编程之外还有不少概念性的东西要学习.我觉得应该有以下几点吧: 1.得了解下计算机网络的基本概念,如OSI的7层模型 ...

  6. win32 socket 编程(六)——UDP

    基于 UDP 无连接的 socket 编程 一.服务器端操作流程 1.1加载套接字库(WSAStartup) 1.2 创建套接字  (socket) 1.3将创建的套接字绑定到一个本地地址和端口上   ...

  7. iOS Socket编程(一)基本概念

    1.Socket的解释 Socket翻译过来中文称为套接字, 这里我找到了一段比较官方的解释Socket是什么东西: Socket是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元,包含进行 ...

  8. iOS socket编程 第三方库 AsyncSocket(GCDAsyncSocket)

    Socket描述了一个IP.端口对.它简化了程序员的操作,知道对方的IP以及PORT就可以给对方发送消息,再由服务器端来处理发送的这些消息.所以,Socket一定包含了通信的双发,即客户端(Clien ...

  9. python网络编程socket编程(TCP、UDP客户端服务器)

    摘录 python核心编程 使用socket()模块函数创建套接字——通信端点 >>> from socket import * >>> tcpSock = soc ...

随机推荐

  1. react native android 编译

    修改 Maven 仓库地址 React Native 在初始化时会从 jcenter.binary.com 这个地方下载一些东西,网上搜索了一下,好像是在下载 Maven 相关的依赖. 针对全局进行修 ...

  2. 2.TypeScript 基础入门(二)

    变量类型的那些事 1.基本注解 类型注解使用:TypeAnnotation 语法.类型声明空间中可用的任何内容都可以用作类型注解. const num: number = 123; function ...

  3. zw版【转发·台湾nvp系列Delphi例程】HALCON SetComprise1

    zw版[转发·台湾nvp系列Delphi例程]HALCON SetComprise1 procedure TForm1.Button1Click(Sender: TObject);var image0 ...

  4. LR和SVM的相同和不同

    之前一篇博客中介绍了Logistics Regression的理论原理:http://www.cnblogs.com/bentuwuying/p/6616680.html. 在大大小小的面试过程中,经 ...

  5. 返回xml过长时被nginx截断的解决办法

    返回xml过长时被nginx截断的解决办法 问题描述:通过网页获取数据,数据格式为xml.当xml比较短时,可以正常获取数据.但是xml长度过长时不能正常获取数据,通过观察返回数据的源代码,发现xml ...

  6. SpringBoot之统一异常处理

    异常,不仅仅是程序运行状态的描述,还可以使得代码编写更加的规范   1.自定义异常:FieldValueInvalidException package com.geniuses.sewage_zer ...

  7. 远程登录 dos命令

    1.桌面连接命令 mstsc /v: 192.168.1.250 /console 2.若需要远程启动所有Internet服务,可以使用iisreset命令来实现. 进入“命令提示符”窗口.在提示符后 ...

  8. PHP开发者的路书

    初学者 作为初学者,通常情况下,我们都会买一本PHP教材,或者在网上看免费教程,这当然是学习的好途径.因为,这些书籍和网上的免费教程,基本上都是由浅入深的渐进式教学方式,基础知识居多,高级知识占少量的 ...

  9. POJ1061 青蛙的约会(扩展欧几里得)题解

    Description 两只青蛙在网上相识了,它们聊得很开心,于是觉得很有必要见一面.它们很高兴地发现它们住在同一条纬度线上,于是它们约定各自朝西跳,直到碰面为止.可是它们出发之前忘记了一件很重要的事 ...

  10. 【第二十六章】 hystrix-dashboard + turbine

    一.使用turbine的意义 引入多个hystrix stream: 1.使用hystrix-dashboard的可以添加多个stream的功能 图中添加的两个stream会在真正monitor的时候 ...