lru.c
来自「这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易」· C语言 代码 · 共 76 行
C
76 行
/* * lru lists are circular with a list head * pointing to the start and end of the list */#include <u.h>#include "lru.h"/* * Create an lru chain of buffers */voidlruinit(Lru *h){ h->lprev = h->lnext = h;}/* * Add a member to an lru chain */voidlruadd(Lru *h, Lru *m){ h->lprev->lnext = m; m->lprev = h->lprev; h->lprev = m; m->lnext = h;}/* * Move to end of lru list */voidlruref(Lru *h, Lru *m){ if(h->lprev == m) return; /* alread at end of list */ /* * remove from list */ m->lprev->lnext = m->lnext; m->lnext->lprev = m->lprev; /* * add in at end */ h->lprev->lnext = m; m->lprev = h->lprev; h->lprev = m; m->lnext = h;}/* * Move to head of lru list */voidlruderef(Lru *h, Lru *m){ if(h->lnext == m) return; /* alread at head of list */ /* * remove from list */ m->lprev->lnext = m->lnext; m->lnext->lprev = m->lprev; /* * add in at head */ h->lnext->lprev = m; m->lnext = h->lnext; h->lnext = m; m->lprev = h;}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?