


nginx advanced data structure source code analysis (1) ----- doubly linked list
ng_queue_t is a sequential container provided by Nginx, which organizes data together in a doubly linked list.
The advantage of a linked list as a sequential container is that it can efficiently perform operations such as insertion, deletion, and merging. When moving elements in the linked list, you only need to modify the pointing of the pointer. Therefore, it is very suitable for frequently modifying the container. occasion.
Compared with other sequential containers, it has the following three advantages:
(1) It implements the sorting function and uses insertion sorting, although it is not suitable for sorting very large-scale data. But simple and practical.
(2) It is very lightweight and is not responsible for the allocation of memory occupied by linked list elements. ngx_queue_t just links these allocated memory elements with a doubly linked list
(3) Supports the merging of two linked lists.
When Nginx designed this doubly linked list, since the container and elements share the ngx_queue_t structure, in order to avoid confusion in the meaning of the members of this structure, Nginx encapsulates all methods of the linked list container and elements.
ngx_queue_t header file:
typedef struct ngx_queue_s ngx_queue_t; struct ngx_queue_s { ngx_queue_t *prev; ngx_queue_t *next; }; #define ngx_queue_init(q) \初始化,为空,都指向容器结构体 (q)->prev = q; \ (q)->next = q #define ngx_queue_empty(h) \是否为空 (h == (h)->prev) #define ngx_queue_insert_head(h, x) \插入链表容器头部 (x)->next = (h)->next; \ (x)->next->prev = x; \ (x)->prev = h; \ (h)->next = x #define ngx_queue_insert_after ngx_queue_insert_head #define ngx_queue_insert_tail(h, x) \插入链表容器尾部 (x)->prev = (h)->prev; \ (x)->prev->next = x; \ (x)->next = h; \ (h)->prev = x #define ngx_queue_head(h) \返回第一个结构体指针 (h)->next #define ngx_queue_last(h) \返回最后一个结构体指针 (h)->prev #define ngx_queue_sentinel(h) \返回容器结构体指针 (h) #define ngx_queue_next(q) \返回q的下一个元素 (q)->next #define ngx_queue_prev(q) \返回q的上一个元素 (q)->prev #if (NGX_DEBUG) #define ngx_queue_remove(x) \ (x)->next->prev = (x)->prev; \ (x)->prev->next = (x)->next; \ (x)->prev = NULL; \ (x)->next = NULL #else #define ngx_queue_remove(x) \删除x (x)->next->prev = (x)->prev; \ (x)->prev->next = (x)->next #endif #define ngx_queue_split(h, q, n) \拆分成两个链表 (n)->prev = (h)->prev; \ (n)->prev->next = n; \ (n)->next = q; \ (h)->prev = (q)->prev; \ (h)->prev->next = h; \ (q)->prev = n; #define ngx_queue_add(h, n) \合并链表 (h)->prev->next = (n)->next; \ (n)->next->prev = (h)->prev; \ (h)->prev = (n)->prev; \ (h)->prev->next = h; #define ngx_queue_data(q, type, link) \返回q所属结构体地址 (type *) ((u_char *) q - offsetof(type, link))
n There are only two methods in the implementation file of gx_queue_t: one is to return the The central element and one is to sort the linked list.
ngx_queue_t * ngx_queue_middle(ngx_queue_t *queue) //返回链表中心元素 { ngx_queue_t *middle, *next; middle = ngx_queue_head(queue); if (middle == ngx_queue_last(queue)) { //特殊情况也要单独判断,如果只有一个,则返回这个元素 return middle; } next = ngx_queue_head(queue); for ( ;; ) { middle = ngx_queue_next(middle); //一个指针走一步,另外一个指针走两步 next = ngx_queue_next(next); if (next == ngx_queue_last(queue)) { //next每走一步都要判断一下的 return middle; } next = ngx_queue_next(next); if (next == ngx_queue_last(queue)) { //这也要判断,考虑真全面啊 return middle; } } } /* the stable insertion sort */ void ngx_queue_sort(ngx_queue_t *queue, ngx_int_t (*cmp)(const ngx_queue_t *, const ngx_queue_t *)) //用插入法排序 { ngx_queue_t *q, *prev, *next; q = ngx_queue_head(queue); if (q == ngx_queue_last(queue)) { //只有一个节点就不用排了 return; } for (q = ngx_queue_next(q); q != ngx_queue_sentinel(queue); q = next) { prev = ngx_queue_prev(q); //分别保存q的前后节点 next = ngx_queue_next(q); ngx_queue_remove(q); do { if (cmp(prev, q) <br><p><span></span></p><div> <p>Copyright Statement: This article is an original article by the blogger and may not be reproduced without the blogger's permission. </p> <p> The above introduces nginx advanced data structure source code analysis (1) ----- doubly linked list, including aspects of the content. I hope it will be helpful to friends who are interested in PHP tutorials. </p> <p> </p> </div>

PHPisusedforsendingemailsduetoitsintegrationwithservermailservicesandexternalSMTPproviders,automatingnotificationsandmarketingcampaigns.1)SetupyourPHPenvironmentwithawebserverandPHP,ensuringthemailfunctionisenabled.2)UseabasicscriptwithPHP'smailfunct

The best way to send emails is to use the PHPMailer library. 1) Using the mail() function is simple but unreliable, which may cause emails to enter spam or cannot be delivered. 2) PHPMailer provides better control and reliability, and supports HTML mail, attachments and SMTP authentication. 3) Make sure SMTP settings are configured correctly and encryption (such as STARTTLS or SSL/TLS) is used to enhance security. 4) For large amounts of emails, consider using a mail queue system to optimize performance.

CustomheadersandadvancedfeaturesinPHPemailenhancefunctionalityandreliability.1)Customheadersaddmetadatafortrackingandcategorization.2)HTMLemailsallowformattingandinteractivity.3)AttachmentscanbesentusinglibrarieslikePHPMailer.4)SMTPauthenticationimpr

Sending mail using PHP and SMTP can be achieved through the PHPMailer library. 1) Install and configure PHPMailer, 2) Set SMTP server details, 3) Define the email content, 4) Send emails and handle errors. Use this method to ensure the reliability and security of emails.

ThebestapproachforsendingemailsinPHPisusingthePHPMailerlibraryduetoitsreliability,featurerichness,andeaseofuse.PHPMailersupportsSMTP,providesdetailederrorhandling,allowssendingHTMLandplaintextemails,supportsattachments,andenhancessecurity.Foroptimalu

The reason for using Dependency Injection (DI) is that it promotes loose coupling, testability, and maintainability of the code. 1) Use constructor to inject dependencies, 2) Avoid using service locators, 3) Use dependency injection containers to manage dependencies, 4) Improve testability through injecting dependencies, 5) Avoid over-injection dependencies, 6) Consider the impact of DI on performance.

PHPperformancetuningiscrucialbecauseitenhancesspeedandefficiency,whicharevitalforwebapplications.1)CachingwithAPCureducesdatabaseloadandimprovesresponsetimes.2)Optimizingdatabasequeriesbyselectingnecessarycolumnsandusingindexingspeedsupdataretrieval.

ThebestpracticesforsendingemailssecurelyinPHPinclude:1)UsingsecureconfigurationswithSMTPandSTARTTLSencryption,2)Validatingandsanitizinginputstopreventinjectionattacks,3)EncryptingsensitivedatawithinemailsusingOpenSSL,4)Properlyhandlingemailheaderstoa


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

Dreamweaver Mac version
Visual web development tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.
