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 型

示例:

  1. char buf[]=""
  2. unsigned int rate;
  3. kstrtouint(buf,,&rate);
  4.  
  5. //buf:输入字符串,0:自动识别,也可以是10(10进制)或16(16进制),rate:存放转换后的整形值.
  6. //当没有错误时返回值是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. Openvswitch手册(6): QoS

    这一节我们看QoS,Qos的设置往往是和flow中的policy一起使用的 Open vSwitch QoS capabilities 1 Interface rate limiting 2 Port ...

  2. 2018年3月24日上海MVP线下技术交流活动简报

    2018年3月24日下午,几位上海MVP自发组织了一次线下的技术交流会,主要由MVP胡浩牵头,我(陈晴阳).刘鑫.朱兴亮和胡浩各自做了一次主题演讲,具体主题是: 陈晴阳:<这还是我认识的Visu ...

  3. [转载]你所不了解的DevOps

    DevOps开发运维训练营 一旦建立了创新的文化,即使那些并非科学家或者工程师的人——诗人.演员.记者——也能以团体的形式,接受科学文化的意义.他们信奉创新文化的概念.他们以促进这种文化的方式投票.他 ...

  4. Django项目配置日志

    LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'formatters': { 'verbose': { 'format': ...

  5. Java 虚拟机的垃圾回收

    背景 垃圾收集(Garbage Collection,GC),GC的历史比Java久远,1960年诞生于MIT的Lisp是第一门真正使用内存动态分配和垃圾收集技术的语言. 对于Java来说,运行时区域 ...

  6. 【jdbc】连接数据库从浅入深

    一.回想 还记得以前自学的时候,刚接触到数据库,讲解的连接数据库的最基本的理论知识和方法,现在温习一下基础知识并总结如下! 1.JDBC连接数据库的基本流程 加载JDBC驱动程序 —> 提供JD ...

  7. jquery click嵌套 事件重复注册 多次执行的问题解决

    jquery click事件中嵌套click会重复注册内部的click事件,导致重复执行. 比如 $(...).click(function(){   $(...).click(function(){ ...

  8. 关于 Kubernetes 中的 Volume 与 GlusterFS 分布式存储

    容器中持久化的文件生命周期是短暂的,如果容器中程序崩溃宕机,kubelet 就会重新启动,容器中的文件将会丢失,所以对于有状态的应用容器中持久化存储是至关重要的一个环节:另外很多时候一个 Pod 中可 ...

  9. Android布局:宽度适应的横向跟随,防止挤掉重要视图

    不知道这样的布局该怎么描述,标题也是乱取的..直接上图吧 最近遇到了这样要求的布局: 1.上图中的“标题”长度不定,“状态”标签可能有多个并紧跟在标题右边,“属性”一直居右显示: 2.当“标题”过长, ...

  10. [NewLife.XCode]增量累加

    NewLife.XCode是一个有10多年历史的开源数据中间件,支持nfx/netstandard,由新生命团队(2002~2019)开发完成并维护至今,以下简称XCode. 整个系列教程会大量结合示 ...