网络编程之TCP/UDP及其流程比较(转)

TCP与UDP的区别

  1. 基于连接与无连接

  2. 对系统资源的要求(TCP较多,UDP少)

  3. UDP程序结构较简单

  4. 流模式与数据报模式
    TCP保证数据正确性,UDP可能丢包
    TCP保证数据顺序,UDP不保证

具体编程时的区别

  1. socket()的参数不同

  2. UDP Server不需要调用listen和accept

  3. UDP收发数据用sendto/recvfrom函数

  4. TCP:地址信息在connect/accept时确定
    UDP:在sendto/recvfrom函数中每次均 需指定地址信息

  5. UDP:shutdown函数无效

部分满足以下几点要求时,应该采用UDP 面向数据报方式

  1. 网络数据大多为短消息

  2. 拥有大量Client

  3. 对数据安全性无特殊要求

  4. 网络负担非常重,但对响应速度要求高

例子:ICQ、ping

服务器程序流程(多进程):

  1. 程序初始化

  2. 填写本机地址信息

  3. 绑定并监听一个固定的端口

  4. 收到Client的连接后建立一个socket连接

  5. 产生一个新的进程与Client进行通信和信息处理

  6. 子通信结束后中断与Client的连接

客户端程序流程:

  1. 程序初始化

  2. 填写服务器地址信息

  3. 连接服务器

  4. 与服务器通信和信息处理

  5. 通信结束后断开连接

服务器代码

#include <stdio.h>

#include <stdlib.h>

#include <errno.h>

#include <string.h>

#include <sys/types.h>

#include <netinet/in.h>

#include <sys/socket.h>

#include <sys/wait.h>

#define MYPORT
3490                
/* 监听的端口 */

#define BACKLOG
10                
/* listen的请求接收队列长度 */

void main() {

int sockfd,
new_fd;            
/* 监听端口,数据端口 */

struct sockaddr_in sa;         /*
自身的地址信息 */

struct sockaddr_in their_addr; /* 连接对方的地址信息 */

int sin_size;

if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {

perror("socket");

exit(1);

}

sa.sin_family = AF_INET;

sa.sin_port =
htons(MYPORT);         /* 网络字节顺序
*/

sa.sin_addr.s_addr = INADDR_ANY;     /* 自动填本机IP */

bzero(&(sa.sin_zero),
8);             /*
其余部分置0 */

if (bind(sockfd, (struct sockaddr *)&sa, sizeof(sa)) == -1) {

perror("bind");

exit(1);

}

if (listen(sockfd, BACKLOG) == -1) {

perror("listen");

exit(1);

}

/* 主循环 */

while(1) {

sin_size = sizeof(struct sockaddr_in);

new_fd = accept(sockfd, (struct sockaddr *)&their_addr,
&sin_size))

if (new_fd == -1) {

perror("accept");

continue;

}

printf(”Got connection from %s\n", inet_ntoa(their_addr.sin_addr));

if (fork() == 0) {

/* 子进程 */

if (send(new_fd, "Hello, world!\ n", 14, 0) == -1)

perror("send");

close(new_fd);

exit(0);

}

close(new_fd);

/*清除所有子进程 */

while(waitpid(-1,NULL,WNOHANG) > 0);

}

}

客户端代码

#include <stdio.h>

#include <stdlib.h>

#include <errno.h>

#include <string.h>

#include <netdb.h>

#include <sys/types.h>

#include <netinet/in.h>

#include <sys/socket.h>

#define PORT 3490 /* Server的端口 */

#define MAXDATASIZE 100 /*一次可以读的最大字节数 */

int main(int argc, char *argv[])

{

int sockfd, numbytes;

char buf[MAXDATASIZE];

struct hostent *he; /* 主机信息 */

struct sockaddr_in their_addr; /* 对方地址信息 */

if (argc != 2) {

fprintf(stderr,"usage: client hostname\n");

exit(1);

}

/* get the host info */

if ((he=gethostbyname(argv[1])) == NULL) {

/* 注意:获取DNS信息时,显示出错需要用herror而不是perror */

herror("gethostbyname");

exit(1);

}

if ((sockfd=socket(AF_INET,SOCK_STREAM,0))==-1) {

perror("socket");

exit(1);

}

their_addr.sin_family = AF_INET;

their_addr.sin_port = htons(PORT); /* short, NBO */

their_addr.sin_addr = *((struct in_addr *)he->h_addr);

bzero(&(their_addr.sin_zero), 8); /* 其余部分设成0 */

if (connect(sockfd, (struct sockaddr *)&their_addr, sizeof(struct
sockaddr)) == -1) {

perror("connect");

exit(1);

}

if ((numbytes=recv(sockfd,buf,MAXDATASIZE,0))==-1) {

perror("recv");

exit(1);

}

buf[numbytes] = ‘\0‘;

printf("Received: %s",buf);

close(sockfd);

return 0;

}

服务器程序流程(单进程):

  1. 程序初始化

  2. 填写本机地址信息

  3. 绑定一个固定的端口

  4. 收到Client的数据报后进行处理与通信

  5. 通信结束后断开连接

客户端程序流程:

  1. 程序初始化

  2. 填写服务器地址信息

  3. 连接服务器

  4. 与服务器通信和信息处理

  5. 通信结束后断开连接

UDP方式下服务器与客户端程序差别不大,仅第三步不同。

服务器

#include <stdio.h>

#include <stdlib.h>

#include <errno.h>

#include <string.h>

#include <sys/types.h>

#include <netinet/in.h>

#include <sys/socket.h>

#include <sys/wait.h>

#define MYPORT 3490 /* 监听端口 */

void main()

{

int sockfd; /* 数据端口 */

struct sockaddr_in my_addr; /* 自身的地址信息 */

struct sockaddr_in their_addr; /* 连接对方的地址信息 */

int sin_size, retval;

char buf[128];

if ((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) == -1) {

perror("socket");

exit(1);

}

my_addr.sin_family = AF_INET;

my_addr.sin_port = htons(MYPORT); /* 网络字节顺序 */

my_addr.sin_addr.s_addr = INADDR_ANY; /* 自动填本机IP */

bzero(&(my_addr.sin_zero), 8); /* 其余部分置0 */

if (bind(sockfd, (struct sockaddr *)&my_addr, sizeof(my_addr)) == -1)
{

perror("bind");

exit(1);

}

/* 主循环 */

while(1) {

retval = recvfrom(sockfd, buf, 128, 0, (struct sockaddr
*)&their_addr, &sin_size);

printf("Received datagram from %s\n",inet_ntoa(their_addr.sin_addr));

if (retval == 0) {

perror (“recvfrom");

close(sockfd);

break;

}

retval = sendto(sockfd, buf, 128, 0, (struct sockaddr *)&their_addr,
sin_size);

}

}

客户端

#include <stdio.h>

#include <stdlib.h>

#include <errno.h>

#include <string.h>

#include <netdb.h>

#include <sys/types.h>

#include <netinet/in.h>

#include <sys/socket.h>

#define PORT 3490 /* Server的端口 */

#define MAXDATASIZE 100 /*一次可以读的最大字节数 */

int main(int argc, char *argv[])

{

int sockfd, numbytes, sin_size;

char buf[MAXDATASIZE] = “Hello, world!”;

struct hostent *he; /* 主机信息 */

struct sockaddr_in their_addr; /* 对方地址信息 */

if (argc != 2) {

fprintf(stderr,"usage: client hostname\n");

exit(1);

}

/* get the host info */

if ((he=gethostbyname(argv[1])) == NULL) {

herror("gethostbyname");

exit(1);

}

if ((sockfd=socket(AF_INET,SOCK_DGRAM,0))==-1) {

perror("socket");

exit(1);

}

their_addr.sin_family = AF_INET;

their_addr.sin_port = htons(PORT); /* short, NBO */

their_addr.sin_addr = *((struct in_addr *)he->h_addr);

bzero(&(their_addr.sin_zero), 8); /* 其余部分设成0 */

numbytes = sendto(sockfd, buf, MAXDATASIZE, 0, (struct sockaddr
*)&their_addr,sizeof(their_addr));

if (numbytes == -1) {

perror(“sendto");

exit(1);

}

printf(“Send: %s",buf);

numbytes = recvfrom(sockfd, buf, MAXDATASIZE, 0, (struct sockaddr
*)&their_addr, &sin_size);

if (numbytes == -1) {

perror("recvfrom");

exit(1);

}

buf[numbytes] = ‘\0‘;

printf("Received: %s",buf);

close(sockfd);

return 0;

}

时间: 2024-08-03 03:01:55

网络编程之TCP/UDP及其流程比较(转)的相关文章

4.Java网络编程之TCP/UDP

常见传输协议: UDP , TCP UDP协议:    特点:         1.将数据及源和目的封装成数据包中,不需要建立连接         2.每个数据包的大小限制在64K内         3.因无连接,是不可靠协议         4.不需要建立连接,速度快 举例:比如你向家里邮寄一个包裹,无论家里此时是否有人,都会发送.当快递员发送到你家时,如果有人,家里人就收到了包裹,如果家里此时没有人,包裹(数据包)就被丢弃了. 自我理解: 当我们建立连接后,你说了一句:"你吃过饭了么?&qu

【Unity3D自学记录】网络编程之TCP&amp;UDP的区别

TCP(Transmission Control Protocol,传输控制协议)是基于连接的协议,也就是说,在正式收发数据前,必须和对方建立可靠的连接.一个TCP连接必须要经过三次"对话"才能建立起来,其中的过程非常复杂,我们这里只做简单.形象的介绍,你只要做到能够理解这个过程即可.我们来看看这三次对话的简单过程:主机A向主机B发出连接请求数据包:"我想给你发数据,可以吗?",这是第一次对话:主机B向主机A发送同意连接和要求同步(同步就是两台主机一个在发送,一个在

网络编程之TCP/IP各层详解

网络编程之TCP/IP各层详解 我们将应用层,表示层,会话层并作应用层,从TCP/IP五层协议的角度来阐述每层的由来与功能,搞清楚了每层的主要协议,就理解了整个物联网通信的原理. 首先,用户感知到的只是最上面一层--应用层,自上而下每层都依赖于下一层,所以我们从最下层开始切入,比较好理解. 每层都运行特定的协议,越往上越靠近用户,越往下越靠近硬件. 一.物理层 由来:孤立的计算机之间要一起"玩耍",就必须接入Internet,即计算机之间必须完成组网. 物理层功能:主要是基于电器特性发

java网络编程之TCP实例

Dgram类 package Socket; import java.net.DatagramPacket; import java.net.InetAddress; public class Dgram { public static DatagramPacket toDatagram(String s, InetAddress destIA, int destPort) { byte[] buf = new byte[s.length() + 1]; s.getBytes(0, s.leng

扯谈网络编程之Tcp SYN flood洪水攻击

简介 TCP协议要经过三次握手才能建立连接: (from wiki) 于是出现了对于握手过程进行的攻击.攻击者发送大量的FIN包,服务器回应(SYN+ACK)包,但是攻击者不回应ACK包,这样的话,服务器不知道(SYN+ACK)是否发送成功,默认情况下会重试5次(tcp_syn_retries).这样的话,对于服务器的内存,带宽都有很大的消耗.攻击者如果处于公网,可以伪造IP的话,对于服务器就很难根据IP来判断攻击者,给防护带来很大的困难. 攻与防 攻击者角度 从攻击者的角度来看,有两个地方可以

linux网络编程之TCP/IP基础篇(一)

从今天起,将会接触到网络编程,平台是linux,实现语言C语言,最后将会实现一个简易的miniftp服务器. 主要的内容安排为:linux网络编程之TCP/IP基础篇,SOCKET编程篇,进程间通信篇,线程篇,实战ftp篇. 1.ISO/OSI参考模型:open system interconnection开放系统互联模型是由OSI(international organization for standardization )国际标准化组织定义的网络分层模型,共七层. 各层的具体含义: 物理层

网络编程之TCP编程

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption

应聘复习基础笔记1:网络编程之TCP与UDP的优缺点,TCP三次握手、四次挥手、传输窗口控制、存在问题

重要性:必考 一.TCP与UDP的优缺点 ①TCP---传输控制协议,提供的是面向连接.可靠的字节流服务.当客户和服务器彼此交换数据前,必须先在双方之间建立一个TCP连接,之后才能传输数据.TCP提供超时重发,丢弃重复数据,检验数据,流量控制等功能,保证数据能从一端传到另一端的可靠传输.对可靠性要求较高的应用层协议,如FTP.Telnet.SMTP.HTTP.POP3 ②UDP---用户数据报协议,是一个简单的面向数据报的运输层协议.UDP不提供可靠性,它只是把应用程序传给IP层的数据报发送出去

J2SE网络编程之 TCP与UDP

1.什么是TCP TCP(Transmission Control Protocol传输控制协议)是一种面向连接的.可靠的.基于字节流的通信协议,位于传输层.这三个特点中,面向连接就如同打电话,双方的电话必须保持连接状态才能通话:可靠就如同QQ上的视频,一方发送视频请求,另一方必须同意后才能建立视频连接,也可以说安全性好:基于字节流,继续看下文就行.TCP最重要的思想就是大名鼎鼎的“三次握手”: 客户端向服务端发送请求报文: 服务端收到后向客户端回复: 客户端确认收到服务端的回复. 三次握手完成