1.对双向链表的具体操作如下:

  1. list_add ———向链表添加一个条目
  2. list_add_tail ———添加一个条目到链表尾部
  3. __list_del_entry ———从链表中删除相应的条目
  4. list_replace———用新条目替换旧条目
  5. list_del_init———从链表中删除条目后重新初始化
  6. list_move———从一个链表中删除并加入为另一个链表的头部
  7. list_move_tail———从一个列表中删除并加入为另一个链表的尾部
  8. list_is_last———测试是否为链表的最后一个条目
  9. list_empty———测试链表是否为空
  10. list_empty_careful———测试链表是否为空并没有被修改
  11. list_rotate_left———向左转动链表
  12. list_is_singular———测试链表是否只有一个条目
  13. list_cut_position———将链表一分为二
  14. list_splice———将两个链表进行合并
  15. list_splice_tail———将两个链表进行合并为一个链表
  16. list_splice_init———将两个链表进行合并为一个链表并初始化为空表
  17. list_splice_tail_init———将两个链表进行合并为一个链表(从尾部合并)并初始化为空表
  18. list_entry———获取条目的结构,实现对container_of 的封装
  19. list_first_entry———获取链表的第一个元素
  20. list_first_entry_or_null———获取链表的第一个元素
  21. list_for_each———遍历链表
  22. list_for_each_prev———反向遍历链表
  23. list_for_each_safe———遍历链表并删除链表中相应的条目
  24. list_for_each_prev_safe———反向遍历链表并删除链表中相应的条目
  25. list_for_each_entry———遍历指定类型的链表
  26. list_for_each_entry_reverse———反向遍历指定类型的链表
  27. list_prepare_entry———准备一个用于list_for_each_entry_continue 的条目
  28. list_for_each_entry_continue———从指定点开始继续遍历指定类型的链表
  29. list_for_each_entry_continue_reverse———从指定点开始反向遍历链表
  30. list_for_each_entry_from———从当前点遍历指定类型的链表
  31. list_for_each_entry_safe———反向遍历指定类型的链表并删除链表中相应的条目
  32. list_for_each_entry_safe_continue———继续遍历链表并删除链表中相应的条目
  33. list_for_each_entry_safe_from———从当前点遍历链表并删除链表中相应的条目
  34. list_for_each_entry_safe_reverse———反向遍历链表并删除链表中相应的条目
  35. list_safe_reset_next———获得下一个指定类型的条目
  36. hlist_for_each_entry———遍历指定类型的单指针表头链表
  37. hlist_for_each_entry_continue———从当前点继续遍历单指针表头链表
  38. hlist_for_each_entry_from———从当前点继续遍历单指针表头链表
  39. hlist_for_each_entry_safe———遍历指定类型的单指针表头链表并删除链表中相应的条目

2.字符串相关

内核中经常会有字符串转换的需要, 其接口如下:

  1. simple_strtoull———变换一个字符串为无符号的long long 型
  2. simple_strtoul———变换一个字符串为无符号的long 型
  3. simple_strtol———变换一个字符串为有符号的long 型
  4. simple_strtoll———变换一个字符串为有符号的long long 型
  5. vsnprintf———格式化一个字符串并放入缓冲区
  6. vscnprintf———格式化一个字符串并放入缓冲区
  7. snprintf———格式化一个字符串并放入缓冲区
  8. scnprintf———格式化一个字符串并放入缓冲区
  9. vsprintf———格式化一个字符串并放入缓冲区
  10. sprintf———格式化一个字符串并放入缓冲区
  11. vbin_printf———解析格式化字符串并将二进制值放入缓冲区
  12. bstr_printf———对二进制参数进行格式化字符串操作并放入缓冲区
  13. bprintf———解析格式化字符串并将二进制值放入缓冲区
  14. vsscanf———从格式化字符串中分离出的参数列表
  15. sscanf———从格式化字符串中分离出的参数列表
  16. kstrtol———变换一个字符串为long 型
  17. kstrtoul———变换一个字符串为无符号的long 型
  18. kstrtoull———变换一个字符串为无符号的long long 型
  19. kstrtoll———变换一个字符串为long long 型
  20. kstrtouint———变换一个字符串为无符号的int 型
  21. kstrtoint———变换一个字符串为int 型

示例:

char buf[]="";
unsigned int rate;
kstrtouint(buf,,&rate); //buf:输入字符串,0:自动识别,也可以是10(10进制)或16(16进制),rate:存放转换后的整形值.
//当没有错误时返回值是0;

3.另外字符串本身的操作接口如下:

  1. strnicmp———长度有限的字符串比较,这里不分大小写
  2. strcpy———复制一个以NULL 结尾的字符串
  3. strncpy———复制一个以NULL 结尾的有限长度字符串
  4. strlcpy———复制一个以NULL 结尾的有限长度字符串到缓冲区中
  5. strcat———在字符串后附加以NULL 结尾的字符串
  6. strncat———在字符串后附加以NULL 结尾的一定长度的字符串
  7. strlcat———在字符串后附加以NULL 结尾的一定长度的字符串
  8. strcmp———比较两个字符串
  9. strncmp———比较两个限定长度的字符串
  10. strchr———在字符串中查找第一个出现指定字符的位置
  11. strrchr———在字符串中查找最后出现指定字符的位置
  12. strnchr———在字符串中查找出现指定字符串的位置
  13. skip_spaces———从字符串中移除前置空格
  14. strim———从字符串中移除前置及后置的空格
  15. strlen———获得字符串的长度
  16. strnlen———获得一个有限长度字符串的长度
  17. strspn———计算一个仅包含可接受字母集合的字符串的长度
  18. strcspn———计算一个不包含指定字母集合的字符串的长度
  19. strpbrk———找到字符集合在字符串第一次出现的位置
  20. strsep———分割字符串
  21. sysfs_streq———字符串比较,用于sysfs
  22. strtobool———用户输入转换成布尔值
  23. memset———内存填充
  24. memcpy———内存复制
  25. memmove———内存复制
  26. memcmp———内存比较
  27. memscan———在内存中找指定的字符
  28. strstr———在一个以NULL 结尾的字符串中找到第一个子串
  29. strnstr———在一个限定长度字符串中找到第一个子串
  30. memchr———找到内存中的字符
  31. memchr_inv———找到内存中的不匹配字符

文章来源http://blog.sina.com.cn/s/blog_b2aa4e080102xw25.html

linux内核里的字符串转换 ,链表操作常用函数(转)的更多相关文章

  1. C语言字符,字符串,字节操作常用函数

    strlen 这个函数是在 string.h 的头文件中定义的 它的函数原型是 size_t strlen( const char ); size_t 是一个无符号整型,是这样定义的 typedef ...

  2. Linux 内核里的数据结构:位图(bitmap)

    注: 本文由 LCTT 原创翻译,Linux中国 荣誉推出 Linux 内核中的位数组和位操作 除了不同的基于链式和树的数据结构以外,Linux 内核也为位数组(或称为位图(bitmap))提供了 A ...

  3. Linux 内核里的“智能指针”【转】

    转自:http://blog.jobbole.com/88279/ 众所周知,C/C++语言本身并不支持垃圾回收机制,虽然语言本身具有极高的灵活性,但是当遇到大型的项目时,繁琐的内存管理往往让人痛苦异 ...

  4. [翻译]Linux 内核里的数据结构 —— 基数树

    目录 Linux 内核里的数据结构 -- 基数树 基数树 Radix tree Linux内核基数树API 链接 Linux 内核里的数据结构 -- 基数树 基数树 Radix tree 正如你所知道 ...

  5. linux c/c++ IP字符串转换成可比较大小的数字

    由www.169it.com搜集整理 IP字符串转换成可比较大小的数字,具体代码如下所示: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 #include "stdio. ...

  6. go语言之进阶篇字符串操作常用函数介绍

    下面这些函数来自于strings包,这里介绍一些我平常经常用到的函数,更详细的请参考官方的文档. 一.字符串操作常用函数介绍 1.Contains func Contains(s, substr st ...

  7. php中文件操作常用函数有哪些

    php中文件操作常用函数有哪些 一.总结 一句话总结:读写文件函数 判断文件或者目录是否存在函数 创建目录函数 file_exists() mkdir() file_get_content() fil ...

  8. Linux内核里的DebugFS

    DebugFS,顾名思义,是一种用于内核调试的虚拟文件系统,内核开发者通过debugfs和用户空间交换数据.类似的虚拟文件系统还有procfs和sysfs等,这几种虚拟文件系统都并不实际存储在硬盘上, ...

  9. Linux 内核里的数据结构:双向链表

    原文:https://blog.csdn.net/qq_33487044/article/details/78827260 双向链表 Linux 内核自己实现了双向链表,可以在 include/lin ...

随机推荐

  1. submit插件安装的问题与集成了插件的submit

    写在最前面,方法有二种.一种是在线安装,这种办法我尝试过,受网速和软件卡顿的问题,进行不顺利.第二种就是我下面介绍的这种,手动安装. 最精华的在后面,可以直接跳转到最后.我找了很久的,最新版的汉化,而 ...

  2. 《HTTP权威指南》2-URL

    前言 在一个城市中,所有的东西都有一个标准化的名字,以帮助人们寻找城市中的各种资源,如宁波火车站地铁站,在因特网这座大城市中,URL就是其标准化名称,它指向每一条电子信息,告诉你它们位于何处,以及如何 ...

  3. ASP.NET Core - Razor 页面介绍

    简介 随着ASP.NET Core 2 即将来临,最热门的新事物是Razor页面.在之前的一篇文章中,我们简要介绍了ASP.NET Core Razor 页面. Razor页面是ASP.NET Cor ...

  4. kaldi的TIMIT实例三

    ============================================================================ MMI + SGMM2 Training &a ...

  5. 暴走Python之运算符与条件语句

    本文原创作者:LoneliNess,本文属i春秋原创奖励计划,未经许可禁止转载   本文来源:i春秋学院   i春秋(ichunqiu.com)网络安全平台能提供专业的网络安全技术.网络渗透技术.网络 ...

  6. Java 11 究竟比 8 快了多少?

    阅读本文大概需要 1.2 分钟. 作者:h4cd 来源:开源中国社区 开源规划调度引擎 OptaPlanner 官网发布了一个 Java 11 GC 性能基准测试报告. 当前使用量最大的 Java 版 ...

  7. 吴恩达机器学习笔记23-神经网络:表述--非线性假设(Non-linear Hypotheses)

    我们之前学的,无论是线性回归还是逻辑回归都有这样一个缺点,即:当特征太多时,计算的负荷会非常大.下面是一个例子: 当我们使用

  8. 使用githubpages主题NexT的语法

    使用githubpages主题NexT的语法 NexT 前言 不知道为啥?网站总是不出现? 添加「标签」页面 title: 标签测试文章 tags: - Testing - Another Tag - ...

  9. hashMap,hashTable,concurrentHashMap区别

    HashTable 底层数组+链表实现,无论key还是value都不能为null,线程安全,实现线程安全的方式是在修改数据时锁住整个HashTable,效率低,ConcurrentHashMap做了相 ...

  10. Ubantu linux中使用PyCharm之---破解PyCharm,实现永久免费试用

    打开 http://idea.lanyus.com/ 这个网址,可以直接复制到浏览器打开 获取注册码 K71U8DBPNE-eyJsaWNlbnNlSWQiOiJLNzFVOERCUE5FIiwibG ...