TCP/IP网络编程笔记-ch1.理解网络编程和套接字

2023-11-22 17:18

本文主要是介绍TCP/IP网络编程笔记-ch1.理解网络编程和套接字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 函数
    • 服务器
      • 创建套接字:
      • 为套接字分配地址:
      • 将套接字转化成可接受连接状态:
      • 接收连接:
      • 接收连接的套接字创建过程:
    • 客户端
      • 请求连接:
    • 文件操作
      • 打开文件
      • 关闭文件
      • 数据写入文件
  • 实例

函数

服务器

创建套接字:

#include<sys/socket.h>
int socket(int domain,int type,int protocol)
//成功返回文件描述符,失败返回-1

为套接字分配地址:

#include<sys/socket.h>
int bind(int sockfd,struct sockaddr *myaddr,socklen_t addrlen);
//成功返回0,失败返回-1并设置errno常见的errno:EACCES:被绑定的地址是受保护的地址,仅超级用户能访问。比如普通用户将socket绑定到知名服务端口(端口号0~1023上)时,bind将返回EACCES错误。EADDRINUSE:被绑定地址正在使用。(如将socket绑定到一个处于TIME_WAIT状态的socket地址)

将套接字转化成可接受连接状态:

#include<sys/socket.h>
int listen(int sockfd,int backlog);
//成功返回0,失败返回-1并设置errnobacklog参数提示内核监听队列的最大长度,若监听队列长度超过backlog,服务器不再受理新的客户连接
,客户端也会收到ECONNREFUSE错误信息。内核2.2之前的Linux中,backlog指所有处于半连接状态(SYN_RCVD)和完全连接(ESTABLISHED)的socket的上限2.2之后,它只表示处于完全连接状态的socket的上限,处于半连接的socket的上限,处于半连接状态的socket的上限则由/proc/sys/net/ipv4/tcp_max_syn_backlog内核参数定义。backlog典型值为5.

在这里插入图片描述

半连接与全连接:
TCP全连接和半连接

接收连接:

#include<sys/socket.h>
int accept(int sockfd,struct sockaddr *addr,socklen_t *addrlen);
//成功返回文件描述符,失败返回-1

接收连接的套接字创建过程:

socket创建套接字
bind分配IP地址和端口号
listen转为可接受请求状态
accept受理连接请求

客户端

请求连接:

#include<sys/socket.h>
int connect(int sockfd,struct sockaddr *serv_addr,socklen_t addrlen);
//成功返回0,失败返回-10

文件操作

打开文件

#include<sys/types.h>
#include<sys/stat.h>
#include<fcnt1.h>@param path:文件名字符串地址
@param flag:文件打开模式信息
int open(const char*path,int flag);
//成功返回文件描述符,失败返回-1

文件打开模式:

打开模式含义
O_CREAT必要时创建文件
O_TRUNC删除全部现有数据
O_APPEND维持现有数据,保存到其后面
O_RDONLY只读打开
O_WRONLY只写打开
O_RDWR读写打开

关闭文件

#include<unistd.h>int close(int fd);
//成功返回0,失败返回-1

数据写入文件

#include<unistd.h>@param fd:显示数据传输对象的文件描述符
@param buf:保存要传输数据的缓冲地址值
@param nbytes:要传输数据的字节数
ssize_t write(int fd,const void *buf,size_t nbytes);
//成功返回写入字节数,失败返回-1

实例

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cQORjkLL-1641630369443)(https://note.youdao.com/yws/res/8/WEBRESOURCEd3850f795cf1a57d05e5a2016e4da908)][外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5HTDAkhu-1641630369444)(https://note.youdao.com/yws/res/a/WEBRESOURCE55efd2a1b11b3ddbf2ed2a21ec75909a)]

这篇关于TCP/IP网络编程笔记-ch1.理解网络编程和套接字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/411682

相关文章

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

shell脚本快速检查192.168.1网段ip是否在用的方法

《shell脚本快速检查192.168.1网段ip是否在用的方法》该Shell脚本通过并发ping命令检查192.168.1网段中哪些IP地址正在使用,脚本定义了网络段、超时时间和并行扫描数量,并使用... 目录脚本:检查 192.168.1 网段 IP 是否在用脚本说明使用方法示例输出优化建议总结检查 1

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

SpringBoot实现基于URL和IP的访问频率限制

《SpringBoot实现基于URL和IP的访问频率限制》在现代Web应用中,接口被恶意刷新或暴力请求是一种常见的攻击手段,为了保护系统资源,需要对接口的访问频率进行限制,下面我们就来看看如何使用... 目录1. 引言2. 项目依赖3. 配置 Redis4. 创建拦截器5. 注册拦截器6. 创建控制器8.

Linux限制ip访问的解决方案

《Linux限制ip访问的解决方案》为了修复安全扫描中发现的漏洞,我们需要对某些服务设置访问限制,具体来说,就是要确保只有指定的内部IP地址能够访问这些服务,所以本文给大家介绍了Linux限制ip访问... 目录背景:解决方案:使用Firewalld防火墙规则验证方法深度了解防火墙逻辑应用场景与扩展背景: