1. /********************************************************************//**
  2. Adds a node as the last node in a list. */
  3. UNIV_INTERN
  4. void
  5. flst_add_last(
  6. /*==========*/
  7. flst_base_node_t* base, /*!< in: pointer to base node of list */
  8. flst_node_t* node, /*!< in: node to add */
  9. mtr_t* mtr) /*!< in: mini-transaction handle */
  10. {
  11. ulint space;
  12. fil_addr_t node_addr;
  13. ulint len;
  14. fil_addr_t last_addr;
  15. flst_node_t* last_node;
  16.  
  17. ut_ad(mtr && base && node);
  18. ut_ad(base != node);
  19. ut_ad(mtr_memo_contains_page(mtr, base, MTR_MEMO_PAGE_X_FIX));
  20. ut_ad(mtr_memo_contains_page(mtr, node, MTR_MEMO_PAGE_X_FIX));
  21. len = flst_get_len(base, mtr);
  22. last_addr = flst_get_last(base, mtr); //获得base的FLST_LAST最后一个节点的page,offset
  23.  
  24. buf_ptr_get_fsp_addr(node, &space, &node_addr);//返回file page 中的space, page_no,page_offset 详见 /* If the list is not empty, call flst_insert_after */
  25. ) {
  26. if (last_addr.page == node_addr.page) {
  27. last_node = page_align(node) + last_addr.boffset;
  28. } else {
  29. ulint zip_size = fil_space_get_zip_size(space);
  30.  
  31. last_node = fut_get_ptr(space, zip_size, last_addr,
  32. RW_X_LATCH, mtr);
  33. }
  34.  
  35. flst_insert_after(base, last_node, node, mtr);
  36. } else {
  37. /* else call flst_add_to_empty */
  38. flst_add_to_empty(base, node, mtr);
  39. }
  40. }
  1. /********************************************************************//**
  2. Inserts a node after another in a list. */
  3. UNIV_INTERN
  4. void
  5. flst_insert_after(
  6. /*==============*/
  7. flst_base_node_t* base, /*!< in: pointer to base node of list */
  8. flst_node_t* node1, /*!< in: node to insert after */
  9. flst_node_t* node2, /*!< in: node to add */
  10. mtr_t* mtr) /*!< in: mini-transaction handle */
  11. {
  12. ulint space;
  13. fil_addr_t node1_addr;
  14. fil_addr_t node2_addr;
  15. flst_node_t* node3;
  16. fil_addr_t node3_addr;
  17. ulint len;
  18.  
  19. ut_ad(mtr && node1 && node2 && base);
  20. ut_ad(base != node1);
  21. ut_ad(base != node2);
  22. ut_ad(node2 != node1);
  23. ut_ad(mtr_memo_contains_page(mtr, base, MTR_MEMO_PAGE_X_FIX));
  24. ut_ad(mtr_memo_contains_page(mtr, node1, MTR_MEMO_PAGE_X_FIX));
  25. ut_ad(mtr_memo_contains_page(mtr, node2, MTR_MEMO_PAGE_X_FIX));
  26.  
  27. buf_ptr_get_fsp_addr(node1, &space, &node1_addr);
  28. buf_ptr_get_fsp_addr(node2, &space, &node2_addr);
  29.  
  30. node3_addr = flst_get_next_addr(node1, mtr);
  31.  
  32. /* Set prev and next fields of node2 */
  33. flst_write_addr(node2 + FLST_PREV, node1_addr, mtr);
  34. flst_write_addr(node2 + FLST_NEXT, node3_addr, mtr);
  35.  
  36. if (!fil_addr_is_null(node3_addr)) {
  37. /* Update prev field of node3 */
  38. ulint zip_size = fil_space_get_zip_size(space);
  39.  
  40. node3 = fut_get_ptr(space, zip_size,
  41. node3_addr, RW_X_LATCH, mtr);
  42. flst_write_addr(node3 + FLST_PREV, node2_addr, mtr);
  43. } else {
  44. /* node1 was last in list: update last field in base */
  45. flst_write_addr(base + FLST_LAST, node2_addr, mtr);
  46. }
  47.  
  48. /* Set next field of node1 */
  49. flst_write_addr(node1 + FLST_NEXT, node2_addr, mtr);
  50.  
  51. /* Update len of base node */
  52. len = flst_get_len(base, mtr);
  53. mlog_write_ulint(, MLOG_4BYTES, mtr);
  54. }

函数flst_add_last的更多相关文章

  1. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

  2. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  3. JavaScript权威指南 - 函数

    函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...

  4. C++对C的函数拓展

    一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...

  5. 菜鸟Python学习笔记第一天:关于一些函数库的使用

    2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...

  6. javascript中的this与函数讲解

    前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...

  7. 复杂的 Hash 函数组合有意义吗?

    很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...

  8. JS核心系列:浅谈函数的作用域

    一.作用域(scope) 所谓作用域就是:变量在声明它们的函数体以及这个函数体嵌套的任意函数体内都是有定义的. function scope(){ var foo = "global&quo ...

  9. C++中的时间函数

    C++获取时间函数众多,何时该用什么函数,拿到的是什么时间?该怎么用?很多人都会混淆. 本文是本人经历了几款游戏客户端和服务器开发后,对游戏中时间获取的一点总结. 最早学习游戏客户端时,为了获取最精确 ...

随机推荐

  1. Demo学习: Dialogs Anonymous Callback

    Dialogs\Dialogs Anonymous Callback 窗体回调函数使用. 1. 标准回调函数 ShowMessage(const Msg: string; CallBack: TUni ...

  2. 支持异步通知的globalfifo平台设备驱动程序及其测试代码

    驱动: #include <linux/module.h> #include <linux/types.h> #include <linux/fs.h> #incl ...

  3. Matlab生成动态链接库供C#调用

    1.首先在Matlab中编写一个或几个.m文件 2.然后在命令空间中输入命令:deploytool 3.修改工程名称,修改需要生成文件后缀 4.添加类,添加文件,然后点击生成.

  4. iOS开发学习路线图

    很多初学iOS开发的人会经常问:“我想学iOS应该从何入手呢?”.作为一个做了2年多各种iOS开发的程序员,只想写写自己的一些心得体会,好和体验与不好的体验.写的不好,请多包涵.希望能起到抛砖引玉的作 ...

  5. (转载)Cocos2dx-OpenGL ES2.0教程:你的第一个立方体(5)

    在上篇文章中,我们介绍了VBO索引的使用,使用VBO索引可以有效地减少顶点个数,优化内存,提高程序效率. 本教程将带领大家一起走进3D–绘制一个立方体.其实画立方体本质上和画三角形没什么区别,所有的模 ...

  6. Python socket模拟HTTP请求

    0x00 起 最近在做一个对时间要求比较高的扫描器,需要封装一下SOCKET模拟HTTP发包的一些常用函数.简单的说,就是重写一下requests中的get.post方法. 今天在写的时候,遇到一枚很 ...

  7. 请求管道与IHttpModule接口

    IHttpModule向实现类提供模块初始化和处置事件.  IHttpModule包含兩個方法: public void Init(HttpApplication context);public vo ...

  8. Deferred Shading(延迟渲染)

    1.简介      在计算机图形学的词典里,Shading表示“对受光物体的渲染”,这个渲染过程包括下面几步[1]: 1) 计算几何多边形(也就是Mesh).      2) 决定表面材质特性,例如法 ...

  9. 如果Android和C#在一起?

    先看两则新闻.   一则来自新浪科技:   谷歌上诉遭拒绝 需向甲骨文支付Java使用费 大意是说,针对谷歌Android操作系统侵犯甲骨文Java知识产权的指控,美国法院最近做出了有利于甲骨文的裁决 ...

  10. 同一台Windows机器中启动多个Memcached服务

    同一台Windows机器中启动多个Memcached服务 这就需要在一台机器上启动多个Memcached服务了. 假设Memcached在如下目录:C:\memcached\memcached.exe ...