1.        两台计算机通信需要协议,通信的两台计算机IP必须唯一

2.        同一个计算机可以进行多个应用程序与其他计算机通信,IP地址唯一,而端口号是区别同一计算机(同一IP)的唯一标示。

3.        实际上就类似于一个办公室的总机号码(IP)和分机号码(端口号)

4.        协议:为了进行网络中的数据交换(通信)而建立的规则、标准或约定

5.        协议=语义+语法+规则

6.        不同层具有各自不同的协议

7.        上层使用下层提供的服务,实际通信在最底层完成

8.        对等层实体之间虚拟通信|

9.        TCP:面向连接的可靠的传输协议

10.      UDP:面向无连接的不可靠的传输协议

11.    端口是一种抽象的软件结构。应用程序通过系统调用与某端口建立连接后,传输层传给端口的数据都被响应的进行所接收,相应进程发给传输层的数据都通过该端口输出。

12.    端口用一个整数型标示符来表示。端口号跟协议相关,TCP/IP传输层的两个协议TCP和UDP是完全独立的两个软件模块,因此各自的端口号也相互独立。

13.    端口使用一个16位的数字来表示,它的范围是0~65535,1024以下的端口号保留给预定义的服务。例如:http使用的是80端口。

14.    socket(套接字):windows sockets只支持一个通信区域:网际域(AF_INET),这个域被使用网际协议簇通信的进程使用。

15.    C/S模式:客户机向服务器提出请求,服务器接收到请求后,提供相应的服务。

16.    套接字的类型

  a)        流式套接字:(SOCK_STREAM):面向连接可靠的数据传输服务,按顺序接收

  b)       数据包式套接字:(SOCK_DGRAM):无连接服务。接收顺序混乱。

  c)       原始套接字(SOCK_RAM)

17.    基于TCP(面向连接)的socket编程

a)        服务器端程序:

i.             创建套接字socket

ii.             将套接字绑定到一个本地地址和端口上bind

iii.             将套接字设为监听模式,准备接收客户请求listen

iv.             等待客户请求到了;当请求到来后,接收连接请求,返回一个新的对应于此次连接的套接字accept

v.             用返回的套接字和客户端进行通信send/recv

vi.             返回,等待另一客户请求

vii.             关闭套接字

b)       客户端程序:

i.             创建套接字socket

ii.             向服务端发出连接请求connect

iii.             和服务器端进行通信rend/recv

iv.             关闭套接字

18.    基于UDP的socket编程

a)        服务器端(接收端)程序:

i.             创建套接字socket

ii.             将套接字绑定到一个本地地址和端口上bind

iii.             等待接收数据recv/from

iv.             关闭套接字

b)       客户端(发送端)程序:

i.             创建套接字socket

ii.             向服务器发送数据sendto

iii.             关闭套接字

19.int WSAStartup (

  WORD wVersionRequested, //打算使用的最高winsock版本号 
  LPWSADATA lpWSAData  //是个结构体,接收socket的详细信息

);

20.    alt+F8:格式化代码

21.    面向TCP的连接,服务器端

  a) 套接字

SOCKET socket (
  int af,       //指定地址簇
  int type,     //socket类型
  int protocol  //协议

);

  b) 绑定

int bind (
  SOCKET s,                          //要绑定的套接字
  const struct sockaddr FAR*  name,  //指定了该套接字的本地地址信息
  int namelen                        //该地址结构的长度
);

struct sockaddr {

u_short    sa_family;

char       sa_data[14];

};

  c)       监听

int listen (
  SOCKET s,    
  int backlog  
);

  d)       接受连接

SOCKET accept (
  SOCKET s,                   
  struct sockaddr FAR* addr
  int FAR* addrlen            
);
 e)  发送
int send (
  SOCKET s,              //建立连接的socket
  const char FAR * buf,  //发送的数据
  int len,               //发送数据的长度
  int flags              
);
  f)  接收
int recv (
  SOCKET s,       
  char FAR* buf
  int len,        
  int flags       
);
  g)  需要的文件
#include <winsock2.h>
需要连接一个动态链接库:ws2_32.lib

  22.    服务器端:

  a)        Socket

  b)       连接:connect

 int connect (
  SOCKET s,                          
  const struct sockaddr FAR*  name
  int namelen                        
);

  c)       接收:recv

  d)       发送:send

  e)        关闭:closesocket

参考文献:

1、VC++ socket通信实例 总结

2、VC++ 使用socket基于TCP、UDP通信

VC++使用socket进行TCP、UDP通信实例总结的更多相关文章

  1. Python的网络编程[0] -> socket[2] -> 利用 socket 建立 TCP/UDP 通信

    Socket 目录 socket 的 TCP/IP 通信基本建立过程 socket 的 UDP 通信基本建立过程 socket 的 UDP 广播式通信基本建立过程 socket 的多线程通信建立过程 ...

  2. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.3

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  3. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.2

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  4. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.1

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  5. 高性能 TCP & UDP 通信框架 HP-Socket v3.4.1

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  6. 高性能 TCP & UDP 通信框架 HP-Socket v3.3.1

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  7. HP-SOCKET TCP/UDP通信框架库解析

    项目概述: HP-SOCKET是一套通用TCP/UDP通信框架,包括服务器.客户端.Agent组件:其目标是提供高性能.通用性.简易性.可扩展.可定制: 鉴于此,其仅实现基本的通用框架通信.数据收发功 ...

  8. 高性能 TCP & UDP 通信框架 HP-Socket v3.2.3

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  9. 高性能 TCP & UDP 通信框架 HP-Socket v3.2.2 正式发布

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

随机推荐

  1. Spring Boot 打包jar部署服务器

    部署方式:打包成jar部署 部署方式有两种,一种是传统的war包,另一种是打包成jar,推荐第二种方式部署 部署准备 1. jar包内置tomcat,无需服务器安装tomcat环境 2.需要JDK,且 ...

  2. java EE 新手入门了解

    郑重申明:本文转载至https://blog.csdn.net/Neuf_Soleil/article/details/80962686,在此深表感谢! 为什么选择java? 想必有很多初学者会像我一 ...

  3. Shiro官方快速入门10min例子源码解析框架2-Session

    Shiro自身维护了一套session管理组件,它可以独立使用,并不单纯依赖WEB/Servlet/EJB容器等环境,使得它的session可以任何应用中使用. 2-Session)主要介绍在quic ...

  4. 10、springboot之集成druid

    在pom.xml中添加 <dependency> <groupId>com.alibaba</groupId> <artifactId>druid< ...

  5. Delegate背后的秘密

    表面上看来使用delegate是一件很简单的事. 用delegate关键字定义,使用老套的new创建一个instance ,使用熟悉的方法调用写法调用,只不过不在是方法名,而是委托名. 但是在这背后C ...

  6. error: unpack failed: error Missing tree

    最近新建一个仓库,push时遇到如下问题,试了好多方法,最后在stackoverflow上找到解决办法了,可是在开始时就试过这方法,但不成.至于为嘛出现的这种错误,还是不明白原因. git.exe p ...

  7. csharp:Conversion Between DataTable and List

    /// <summary> /// http://www.codeproject.com/Tips/784090/Conversion-Between-DataTable-and-List ...

  8. [HNOI2006]最短母串问题

    题目大意:给定一个字符串集,求一个最短字串,使得该集合内的串都是该串的一个子串 算法:AC自动机+最短路+状压DP 注意空间限制 #include"cstdio" #include ...

  9. JS计算十万块钱 分31期 利息万分之五 每个月的还款数

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. Java设计模式—解释器模式&迭代器模式简介

       解释器模式在实际的系统开发中使用得非常少,因为它会引起效率.性能以及维护等问题,一般在大中型的框架型项目能够找到它的身影,如一些数据分析工具.报表设计工具.科学计算工具等,若你确实遇到" ...