Ubuntu 下 nginx-1.24.0 源码分析 - ngx_list_init

ngx_list_init


定义src\core\ngx_list.h

static ngx_inline ngx_int_t
ngx_list_init(ngx_list_t *list, ngx_pool_t *pool, ngx_uint_t n, size_t size)
{list->part.elts = ngx_palloc(pool, n * size);if (list->part.elts == NULL) {return NGX_ERROR;}list->part.nelts = 0;list->part.next = NULL;list->last = &list->part;list->size = size;list->nalloc = n;list->pool = pool;return NGX_OK;
}

ngx_list_init 是 Nginx 中用于初始化链表结构的关键函数


函数签名

static ngx_inline ngx_int_t 
ngx_list_init(ngx_list_t *list, ngx_pool_t *pool, ngx_uint_t n, size_t size
);
1. static ngx_inline
  • static
    限制函数的作用域为当前编译单元(即当前源文件),防止与其他文件中的同名函数冲突。

  • ngx_inline
    Nginx 定义的宏(通常展开为 inline),提示编译器将函数内联展开,减少函数调用开销。适用于频繁调用的小函数(如初始化、简单操作)。


2. 返回值 ngx_int_t
  • 返回值含义
    • NGX_OK(成功):初始化成功,链表可用。
    • NGX_ERROR(失败):内存分配失败

3. 参数详解
(1) ngx_list_t *list
  • 类型:指向 ngx_list_t 结构的指针。
  • 作用:需要被初始化的链表对象。
(2) ngx_pool_t *pool
  • 类型:指向 Nginx 内存池的指针。
  • 作用:为链表提供内存分配服务。
  • 意义
    • 所有链表相关的内存(包括初始数据块和后续扩展的数据块)均从该内存池分配。
    • 内存池管理简化了内存释放流程(销毁池即可回收所有内存)。
(3) ngx_uint_t n
  • 类型:Nginx 自定义的无符号整型(typedef unsigned int ngx_uint_t)。
  • 作用:指定每个数据块预分配的元素数量。
  • 影响
    • 决定初始内存块的大小为 n * size
    • 值过大会浪费内存,过小会导致频繁分配新数据块。
(4) size_t size
  • 类型:标准库的无符号整型(通常为 unsigned long)。
  • 作用:指定链表中每个元素的大小(字节)。
  • 要求
    • 必须与实际存储的数据类型大小一致(如 sizeof(ngx_table_elt_t))。

详解


1. 分配初始内存块
list->part.elts = ngx_palloc(pool, n * size);

为链表的第一个数据块分配内存,大小为 n * size

ngx_pallocpool 分配内存,返回指针赋给 part.elts


2. 检查内存分配结果
if (list->part.elts == NULL) {return NGX_ERROR;
}

验证内存分配是否成功。

内存分配失败会导致后续操作崩溃,需立即返回错误。

eltsNULL,说明分配失败,返回 NGX_ERROR


3. 初始化当前块元素计数
list->part.nelts = 0;

设置当前块已用元素数量为 0。

nelts(number of elements)记录块内已使用的元素数,初始时未添加元素。

提供计数功能,便于后续判断是否需要分配新块。


4. 初始化当前块的后继指针
list->part.next = NULL;

标记当前块为最后一个块,无后续块。

链表初始仅包含一个块,后续块通过 next 指针链接。


5. 设置最后一个块的指针
list->last = &list->part;

last 指向链表的第一个块(即当前唯一块)。

last 是指向链表最后一个块的指针,用于快速追加元素。

&list->part 获取第一个块的地址,赋给 last

通过 last 直接定位到链表尾部,避免遍历整个链表,提升插入效率。


6. 保存元素大小
list->size = size;

记录每个元素的大小(字节)。

后续添加元素时需根据 size 计算内存偏移量。


7. 保存预分配元素数量
list->nalloc = n;

记录每个块预分配的元素数量。

新块分配时需按 n 预分配内存,平衡内存使用与性能。

控制内存分配粒度,减少碎片化。


8. 关联内存池
list->pool = pool;

保存内存池指针,用于后续内存分配。


9. 返回成功状态
return NGX_OK;

通知调用者初始化成功。

明确函数执行结果,便于错误处理。


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

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

相关文章

Linux切换Python版本

1、更新apt sudo apt update2、查询python安装路径 which python 或者which python33、查询安装版本 # 查看所有以 "python" 开头的命令(包括版本号) ls -l 安装路径* 例如 ls -l /usr/bin/python*4、修改软连接 udo unlink /usr/bin/pyt…

Spring Cloud之注册中心之Nacos的使用

目录 Naacos 服务注册/服务发现 引⼊Spring Cloud Alibaba依赖 引入Nacos依赖 引入Load Balance依赖 配置Nacos地址 服务端调用 启动服务 Naacos Nacos是Spring Cloud Alibaba的组件, Spring Cloud Alibaba遵循Spring Cloud中定义的服务注册, 服务发现规范. 因此使⽤Na…

使用通义万相Wan2.1进行视频生成

使用通义万相Wan2.1进行视频生成 源代码准备运行环境准备创建Python虚拟环境并激活安装依赖包 模型下载生成视频官网的视频生成例子简单描述场景视频生成示例详细描述场景视频生成示例 最近通义万相开源了其视频生成模型。模型有两个版本,一个是1.3B的,一…

鸿蒙HarmonyOS 开发简介

鸿蒙开发入门教程 一、技术简介 鸿蒙操作系统(HarmonyOS)是面向万物互联时代的全场景分布式操作系统,具备分布式软总线、分布式数据管理、分布式任务调度等核心能力,能让设备间实现无缝连接与协同,为用户提供统一、流…

docker和containerd从TLS harbor拉取镜像

私有镜像仓库配置了自签名证书,https访问,好处是不需要处理免费证书和付费证书带来的证书文件变更,证书文件变更后需要重启服务,自签名证书需要将一套客户端证书存放在/etc/docker/cert.d目录下,或者/etc/containerd/c…

linux ununtu通过nginx-1.6.2.tar.gz安装nginx并安装在自定义目录XXX下 的步骤

Ubuntu 下通过源码安装 Nginx 1.6.2 到自定义目录 /home/aot/nginx 的步骤 以下是将 Nginx 1.6.2 源码包离线安装到自定义目录的详细流程,包含依赖管理、编译配置和服务管理: 一、准备工作 1. 下载源码包和依赖(需联网环境准备)…

C++ 变量的输入输出教程

一、变量的基本概念 在 C 中,变量是用于存储数据的命名内存位置。在使用变量之前,需要先声明它的类型和名称,这样编译器才能为其分配适当大小的内存空间。例如: int age; // 声明一个整型变量 age double salary; // 声明一个…

React底层常见的设计模式

在React中,常见的设计模式为开发者提供了结构化和可重用的解决方案,有助于提高代码的可维护性和可扩展性。以下是对React中几种常见设计模式的详细解析,并附上示例代码和注释: 1. 容器组件与展示组件模式(Container/P…

【MATLAB例程】三维下的IMM(交互式多模型),模型使用CV(匀速)和CA(匀加速)

给出三维下的交互式多模型(IMM)matlab例程,模型使用匀速运动CV和匀加速运动CA,滤波使用EKF(扩展卡尔曼滤波) 文章目录 代码运行结果程序结构 代码讲解模型定义:轨迹生成:IMM核心流程…

物理内存组织与分配的核心概念

在 Linux 内核内存管理(尤其是 Buddy System 伙伴系统)中,node、zone、type 和 order 是描述物理内存组织与分配的核心概念。以下是它们的详细解释: 1. Node(NUMA 节点) 定义: 在 NUMA&#xf…

智科技赋能宠物关怀新时代

在科技日新月异的今天,智能宠物监控技术正悄然引领宠物护理领域的新变革。借助尖端的传感器技术、高清摄像头以及强大的数据分析能力,这些智能系统为宠物主人开辟了前所未有的宠物关怀途径,让爱与关怀跨越时空限制。 智能宠物监控系统的核心…

SOME/IP 教程知识点总结

总结关于SOME/IP的教程,首先通读整个文件,理解各个部分的内容。看起来这个教程从介绍开始,讲到了为什么在车辆中使用以太网,然后详细讲解了SOME/IP的概念、序列化、消息传递、服务发现(SOME/IP-SD)、发布/订阅机制以及支持情况。 首先,我需要确认每个章节的主要知识点。…

playbin之autoplug_factories源码剖析

一、autoplug_factories_cb /* Called when we must provide a list of factories to plug to pad with caps.* We first check if we have a sink that can handle the format and if we do, we* return NULL, to expose the pad. If we have no sink (or the sink does not…

58区间和+44开发商购买土地(前缀和)

58. 区间和(第九期模拟笔试) 题目描述 给定一个整数数组 Array,请计算该数组在每个指定区间内元素的总和。 输入描述 第一行输入为整数数组 Array 的长度 n,接下来 n 行,每行一个整数,表示数组的元素。…

laravel11设置中文语言包

安装中文语言包 Laravel 11 默认没有内置完整中文语言包,推荐使用第三方维护的完整翻译: # 通过 Composer 安装语言包 composer require laravel-lang/common --dev# 发布中文语言文件到项目 php artisan lang:add zh_CN这会自动将中文语言文件生成到 l…

智能文档解析与语义分割:LlamaIndex 节点解析器模块全解

节点解析器模块 - LlamaIndex 文件内容的节点解析器 有几种基于文件的节点解析器,它们会根据解析的内容类型(JSON、Markdown 等)创建节点。 最简单的流程是将 FlatFileReader 与 SimpleFileNodeParser 结合使用,自动为每种内容类型选择最佳节点解析器。然后,可以将基于…

实现遍历Windows所有字体的基本属性

参考podofo #include <windows.h> #include <string> #include <memory> #include <set> #include <unordered_map> #include <vector> #include <algorithm> #include <iostream> #include <iomanip> #include <fst…

postman--接口测试工具安装和使用教程

postman–接口测试工具 postman是一款支持http协议的接口调试与测试工具&#xff0c;其主要特点就是功能强大&#xff0c;使用简单且易用性好 。 无论是开发人员进行接口调试&#xff0c;还是测试人员做接口测试&#xff0c;postman都是我们的首选工具之一 。 下面先通过一张…

综合练习 —— 递归、搜索与回溯算法

目录 一、1863. 找出所有子集的异或总和再求和 - 力扣&#xff08;LeetCode&#xff09; 算法代码&#xff1a; 代码思路 问题分析 核心思想 实现细节 代码解析 初始化 DFS 函数 时间复杂度 空间复杂度 示例运行 输入 运行过程 总结 二、 47. 全排列 II - 力扣&a…

代码随想录算法训练day64---图论系列8《拓扑排序dijkstra(朴素版)》

代码随想录算法训练 —day64 文章目录 代码随想录算法训练前言一、53. 117. 软件构建—拓扑排序二、47. 参加科学大会---dijkstra&#xff08;朴素版&#xff09;总结 前言 今天是算法营的第64天&#xff0c;希望自己能够坚持下来&#xff01; 今天继续图论part&#xff01;今…