【探索Linux】—— 强大的命令行工具 P.26(网络编程套接字基本概念—— socket编程接口 | socket编程接口相关函数详细介绍 )

在这里插入图片描述

阅读导航

  • 引言
  • 一、socket 常见API表
  • 二、函数详细介绍
      • 01. socket()
      • 02. bind()
      • 03. listen()
      • 04. accept()
      • 05. connect()
      • 06. send()
      • 07. recv()
      • 08. close()
      • 09. select()
      • 10. getaddrinfo()
      • 11. sendto()
      • 12. recvfrom()
      • 13. setsockopt()
      • 14. getsockopt()
      • 15. shutdown()
      • 16. inet_pton()
      • 17. htons() / htonl() / ntohs() / ntohl()
  • 温馨提示

引言

本文将深入探讨使用套接字进行网络通信的基本步骤,包括创建套接字、绑定地址、监听连接(对于服务器端)、连接远程主机(对于客户端)、以及发送和接收数据等操作。套接字编程涉及一系列系统调用和函数,如 socket()bind()listen()connect()send()recv() 等。开发人员可以利用这些接口实现各种网络应用。通过本文,读者将了解如何使用套接字进行网络通信,并掌握关键步骤和函数调用,为构建网络应用打下坚实基础。

一、socket 常见API表

函数描述
socket()创建一个新的套接字
bind()将套接字绑定到特定的IP地址和端口号上
listen()将套接字标记为被动套接字,用于监听连接请求
accept()接受客户端的连接请求,并返回一个新的套接字用于通信
connect()建立与服务器端的连接
send()发送数据
recv()接收数据
sendto()用于UDP协议中发送数据
recvfrom()用于UDP协议中接收数据
close()关闭套接字连接
select()多路复用,同时监视多个套接字的状态
getaddrinfo()主机名和服务名之间的转换
setsockopt()设置套接字选项
getsockopt()获取套接字选项的值
inet_pton()IP地址的转换
inet_ntop()IP地址的转换
htons()主机字节序和网络字节序之间的转换(16位整数)
ntohs()主机字节序和网络字节序之间的转换(16位整数)
htonl()主机字节序和网络字节序之间的转换(32位整数)
ntohl()主机字节序和网络字节序之间的转换(32位整数)

二、函数详细介绍

01. socket()

  • 头文件:#include <sys/socket.h>

  • 函数原型:int socket(int domain, int type, int protocol);

  • 参数类型

    • domain:协议族(如AF_INET、AF_INET6等)
    • type:套接字类型(如SOCK_STREAM、SOCK_DGRAM等)
    • protocol:具体使用的协议(如IPPROTO_TCP、IPPROTO_UDP等)
  • 应用示例

    int sockfd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
    

02. bind()

  • 头文件:#include <sys/socket.h>

  • 函数原型:int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);

  • 参数类型

    • sockfd:套接字描述符
    • addr:指向要绑定的地址结构的指针
    • addrlen:地址结构的长度
  • 应用示例

    struct sockaddr_in server_address;
    server_address.sin_family = AF_INET;
    server_address.sin_port = htons(12345);
    server_address.sin_addr.s_addr = INADDR_ANY;
    bind(sockfd, (struct sockaddr *)&server_address, sizeof(server_address));
    

03. listen()

  • 头文件:#include <sys/socket.h>

  • 函数原型:int listen(int sockfd, int backlog);

  • 参数类型

    • sockfd:套接字描述符
    • backlog:未完成连接队列的最大长度
  • 应用示例

    listen(sockfd, 5);
    

04. accept()

  • 头文件:#include <sys/socket.h>

  • 函数原型:int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);

  • 参数类型

    • sockfd:套接字描述符
    • addr:指向结构体的指针,用于存储客户端地址信息
    • addrlen:地址结构的长度
  • 应用示例

    int client_sockfd = accept(sockfd, (struct sockaddr *)&client_address, &addr_len);
    

05. connect()

  • 头文件:#include <sys/socket.h>

  • 函数原型:int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);

  • 参数类型

    • sockfd:套接字描述符
    • addr:指向要连接的目标地址结构的指针
    • addrlen:地址结构的长度
  • 应用示例

    connect(sockfd, (struct sockaddr *)&server_address, sizeof(server_address));
    

06. send()

  • 头文件:#include <sys/socket.h>

  • 函数原型:ssize_t send(int sockfd, const void *buf, size_t len, int flags);

  • 参数类型

    • sockfd:套接字描述符
    • buf:指向待发送数据的指针
    • len:待发送数据的长度
    • flags:传输控制标志
  • 应用示例

    char *message = "Hello, server!";
    send(sockfd, message, strlen(message), 0);
    

07. recv()

  • 头文件:#include <sys/socket.h>

  • 函数原型:ssize_t recv(int sockfd, void *buf, size_t len, int flags);

  • 参数类型

    • sockfd:套接字描述符
    • buf:指向存储接收数据的缓冲区
    • len:接收数据的最大长度
    • flags:接收操作的附加选项
  • 应用示例

    char buffer[1024];
    ssize_t bytes_received = recv(sockfd, buffer, 1024, 0);
    

08. close()

  • 头文件:#include <unistd.h>

  • 函数原型:int close(int sockfd);

  • 参数类型

    • sockfd:要关闭的套接字描述符
  • 应用示例

    close(sockfd);
    

09. select()

  • 头文件:#include <sys/select.h>

  • 函数原型:int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout);

  • 参数类型

    • nfds:所有文件描述符的范围(最大文件描述符+1)
    • readfds:可读文件描述符集合
    • writefds:可写文件描述符集合
    • exceptfds:异常文件描述符集合
    • timeout:超时时间
  • 应用示例

    fd_set readfds;
    FD_ZERO(&readfds);
    FD_SET(sockfd, &readfds);
    int activity = select(sockfd + 1, &readfds, NULL, NULL, NULL);
    

10. getaddrinfo()

  • 头文件:#include <sys/types.h>
    #include <sys/socket.h>
    #include <netdb.h>

  • 函数原型:int getaddrinfo(const char *node, const char *service, const struct addrinfo *hints, struct addrinfo **res);

  • 参数类型

    • node:主机名或IP地址字符串
    • service:服务名或端口号字符串
    • hints:指向地址信息结构的指针,用于设置期望的返回结果
    • res:指向存储结果的链表的指针
  • 应用示例

    struct addrinfo hints, *res;
    memset(&hints, 0, sizeof(hints));
    hints.ai_family = AF_UNSPEC;
    hints.ai_socktype = SOCK_STREAM;
    getaddrinfo("www.example.com", "http", &hints, &res);
    

11. sendto()

  • 头文件:#include <sys/socket.h>

  • 函数原型:ssize_t sendto(int sockfd, const void *buf, size_t len, int flags, const struct sockaddr *dest_addr, socklen_t addrlen);

  • 参数类型

    • sockfd:套接字描述符
    • buf:指向待发送数据的指针
    • len:待发送数据的长度
    • flags:传输控制标志
    • dest_addr:目标地址结构
    • addrlen:目标地址结构的长度
  • 应用示例

    char *message = "Hello, server!";
    sendto(sockfd, message, strlen(message), 0, (struct sockaddr *)&server_address, sizeof(server_address));
    

12. recvfrom()

  • 头文件:#include <sys/socket.h>

  • 函数原型:ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags, struct sockaddr *src_addr, socklen_t *addrlen);

  • 参数类型

    • sockfd:套接字描述符
    • buf:指向存储接收数据的缓冲区
    • len:接收数据的最大长度
    • flags:接收操作的附加选项
    • src_addr:发送方地址结构
    • addrlen:发送方地址结构的长度
  • 应用示例

    char buffer[1024];
    struct sockaddr_in client_address;
    socklen_t addr_len = sizeof(client_address);
    ssize_t bytes_received = recvfrom(sockfd, buffer, 1024, 0, (struct sockaddr *)&client_address, &addr_len);
    

13. setsockopt()

  • 头文件:#include <sys/socket.h>

  • 函数原型:int setsockopt(int sockfd, int level, int optname, const void *optval, socklen_t optlen);

  • 参数类型

    • sockfd:套接字描述符
    • level:选项所在的协议层
    • optname:选项名
    • optval:指向设置选项值的指针
    • optlen:选项值的长度
  • 应用示例

    int reuse = 1;
    setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse));
    

14. getsockopt()

  • 头文件:#include <sys/socket.h>

  • 函数原型:int getsockopt(int sockfd, int level, int optname, void *optval, socklen_t *optlen);

  • 参数类型

    • sockfd:套接字描述符
    • level:选项所在的协议层
    • optname:选项名
    • optval:指向存储选项值的缓冲区
    • optlen:输入时为缓冲区大小,输出时为实际选项值的长度
  • 应用示例

    int buffer_size;
    socklen_t optlen = sizeof(buffer_size);
    getsockopt(sockfd, SOL_SOCKET, SO_RCVBUF, &buffer_size, &optlen);
    

15. shutdown()

  • 头文件:#include <sys/socket.h>

  • 函数原型:int shutdown(int sockfd, int how);

  • 参数类型

    • sockfd:套接字描述符
    • how:关闭连接的方式,常用的取值为:
      • SHUT_RD:关闭读端
      • SHUT_WR:关闭写端
      • SHUT_RDWR:同时关闭读写端
  • 应用示例

    shutdown(sockfd, SHUT_RDWR);
    

16. inet_pton()

  • 头文件:#include <arpa/inet.h>

  • 函数原型:int inet_pton(int af, const char *src, void *dst);

  • 参数类型

    • af:地址族,如AF_INET(IPv4)或AF_INET6(IPv6)
    • src:待转换的点分十进制字符串形式的地址
    • dst:存储转换后的二进制格式地址的缓冲区
  • 应用示例

    struct sockaddr_in server_address;
    inet_pton(AF_INET, "127.0.0.1", &(server_address.sin_addr));
    

17. htons() / htonl() / ntohs() / ntohl()

这些函数用于主机字节序和网络字节序之间的转换,分别用于16位和32位整数的主机到网络字节序以及网络到主机字节序的转换。

  • 头文件:#include <arpa/inet.h>

  • 函数原型

    • uint16_t htons(uint16_t hostshort);
    • uint32_t htonl(uint32_t hostlong);
    • uint16_t ntohs(uint16_t netshort);
    • uint32_t ntohl(uint32_t netlong);

这些函数在实际网络编程中经常用于端口号和IP地址等数据的转换。

温馨提示

感谢您对博主文章的关注与支持!如果您喜欢这篇文章,可以点赞、评论和分享给您的同学,这将对我提供巨大的鼓励和支持。另外,我计划在未来的更新中持续探讨与本文相关的内容。我会为您带来更多关于Linux以及C++编程技术问题的深入解析、应用案例和趣味玩法等。如果感兴趣的话可以关注博主的更新,不要错过任何精彩内容!

再次感谢您的支持和关注。我们期待与您建立更紧密的互动,共同探索Linux、C++、算法和编程的奥秘。祝您生活愉快,排便顺畅!
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/271661.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

昇腾芯片解析:华为自主研发的人工智能处理器全面分析

在当今科技发展的浪潮中&#xff0c;昇腾芯片作为一种新兴的处理器&#xff0c;正引起广泛的关注和讨论。升腾芯片究竟是由哪家公司生产的&#xff1f;这个问题一直困扰着许多人。下面小编将全面介绍、分析升腾芯片的生产商及各类参数、应用&#xff0c;以便读者对其有更全面的…

centos7 python3.12.1 报错 No module named _ssl

https://blog.csdn.net/Amio_/article/details/126716818 安装python cd /usr/local/src wget https://www.python.org/ftp/python/3.12.1/Python-3.12.1.tgz tar -zxvf Python-3.12.1.tgz cd Python-3.12.1/ ./configure -C --enable-shared --with-openssl/usr/local/opens…

C++:Stack和Queue的模拟实现

创作不易&#xff0c;感谢三连&#xff01; 一、容器适配器 适配器是一种设计模式(设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结)&#xff0c;该种模式是将一个类的接口转换成客户希望的另外一个接口。 就如同是电源适配器将不适用的交流电…

css实现背景渐变叠加

线性渐变效果图: .box{width: 100vw;height: 100vh;background:linear-gradient(to bottom,transparent,#fff 30%),linear-gradient(to right,pink,skyblue);}径像渐变效果图&#xff1a; .box{width: 100vw;height: 100vh;background:linear-gradient(to bottom,transparent,#…

【JavaEE初阶】 JVM类加载简介

文章目录 &#x1f343;前言&#x1f332;类加载过程&#x1f6a9;加载&#x1f6a9;验证&#x1f6a9;准备&#x1f6a9;解析&#x1f6a9;初始化 &#x1f384;双亲委派模型&#x1f6a9;什么是双亲委派模型&#xff1f;&#x1f6a9;双亲委派模型的优点 ⭕总结 &#x1f343…

Vue.js 实用技巧:深入理解 Vue.mixin

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

开发一套小程序所需的费用取决于多个因素

随着移动互联网的发展&#xff0c;小程序已经成为许多企业和个人推广业务和服务的重要工具。 不过&#xff0c;对于很多想要开发小程序的人来说&#xff0c;最大的疑问就是开发一套小程序要花多少钱。 这个问题的答案并不是固定的&#xff0c;因为开发一个小程序的成本取决于几…

业务代码中如何使用装饰器模式?

装饰器模式&#xff08;Decorator Pattern&#xff09;介绍 装饰器模式&#xff08;Decorator Pattern&#xff09;是一种结构型设计模式&#xff0c;我们可以动态地给一个对象添加额外的职责。而不是通过继承增加子类的方式来扩展对象的功能&#xff0c;装饰器模式使用组合的…

Java注解介绍

Java注解 注解介绍元注解RetentionTargetDocumentedInherited接口类测试结果 注解介绍 Java注解&#xff08;Annotation&#xff09;是一种元数据&#xff08;Metadata&#xff09;的形式&#xff0c;它可以被添加到Java代码中的类、方法、变量、参数等元素上&#xff0c;以提…

AI时代PPT如何制作?用这10款pptai生成器一键制作!

ppt如何制作&#xff1f; 这可能是很多职场人或大学生日常头疼的问题&#xff0c;职场上随便一个工作汇报、提案展示、团队会议&#xff0c;学校里的小组作业、论文答辩等场景&#xff0c;都会用到ppt。 都说人是视觉动物&#xff0c;在两份文档内容质量一致的情况下&#xf…

Linux的top命令解析

Top命令是什么 TOP命令是Linux下常用的性能分析工具&#xff0c;能够实时显示系统中各个进程的资源占用状况。 TOP是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.比较准确的说,top命令提供了实时的对系…

Day16:信息打点-语言框架开发组件FastJsonShiroLog4jSpringBoot等

目录 前置知识 指纹识别-本地工具-GotoScan&#xff08;CMSEEK&#xff09; Python-开发框架-Django&Flask PHP-开发框架-ThinkPHP&Laravel&Yii Java-框架组件-Fastjson&Shiro&Solr&Spring 思维导图 章节知识点 Web&#xff1a;语言/CMS/中间件/…

【物联网】stm32芯片结构组成,固件库、启动过程、时钟系统、GPIO、NVIC、DMA、UART以及看门狗电路的全面详解

一、stm32的介绍 1、概述 stm32: ST&#xff1a;指意法半导体 M&#xff1a;指定微处理器 32&#xff1a;表示计算机处理器位数 与ARM关系:采用ARM推出cortex-A&#xff0c;R,M三系中的M系列&#xff0c;其架构主要基于ARMv7-M实现 ARM分成三个系列&#xff1a; Cortex-A&…

开源模型应用落地-工具使用篇-Ollama(六)

一、前言 在AI大模型百花齐放的时代&#xff0c;很多人都对新兴技术充满了热情&#xff0c;都想尝试一下。但是&#xff0c;实际上要入门AI技术的门槛非常高。除了需要高端设备&#xff0c;还需要面临复杂的部署和安装过程&#xff0c;这让很多人望而却步。不过&#xff0c;随着…

RFID-科技的“隐秘耳语者”

RFID-科技的“隐秘耳语者” 想象一下&#xff0c;你身处一个光线昏暗的环境中&#xff0c;周围的一切都被厚厚的阴影笼罩。这时&#xff0c;你需要识别并获取一个物体的信息&#xff0c;你会选择怎么做&#xff1f;是点亮灯光&#xff0c;用肉眼仔细观察&#xff0c;还是打开扫…

神经网络的矢量化,训练与激活函数

我们现在再回到我们的神经元部分&#xff0c;来看我们如何用python进行正向传递。 单层的正向传递&#xff1a; 我们回到我们的线性回归的函数。我们每个神经元通过上述的方法&#xff0c;就可以得到我们的激发值&#xff0c;从而可以继续进行下一层。 我们用这个方法就可以得…

智慧城市如何助力疫情防控:科技赋能城市安全

目录 一、引言 二、智慧城市与疫情防控的紧密结合 三、智慧城市在疫情防控中的具体应用 1、智能监测与预警系统 2、智慧医疗与健康管理 3、智能交通与物流管理 4、智慧社区与基层防控 四、科技赋能城市安全的未来展望 五、结论 一、引言 近年来&#xff0c;全球范围内…

Platformview在iOS与Android上的实现方式对比

Android中早期版本Platformview的实现基于Virtual Display。VirtualDisplay方案的原理是&#xff0c;先将Native View绘制到虚显&#xff0c;然后Flutter通过从虚显输出中获取纹理并将其与自己内部的widget树进行合成&#xff0c;最后作为Flutter在 Android 上更大的纹理输出的…

链表|206.反转链表

力扣题目链接 struct ListNode* reverseList(struct ListNode* head){//保存cur的下一个结点struct ListNode* temp;//pre指针指向前一个当前结点的前一个结点struct ListNode* pre NULL;//用head代替cur&#xff0c;也可以再定义一个cur结点指向head。while(head) {//保存下…

测试常用的Linux命令

前言 直接操作硬件 将把操作硬件的代码封装成系统调用&#xff0c;供程序员使用 虚拟机软件 可以模拟的具有完整硬件系统的功能 可以在虚拟机上安装不同的操作系统 Linux内核只有一个&#xff0c;发行版有很多种 内核来运行程序和管理像磁盘和打印机等硬件设备的核心程序 终端…