通过C的指针,我们可以遍历一个很长的字符串。我们针对这个字符串可以按照字符串里面的终止符做切分。
首先我们来看下面的一段代码:
#include <stdio.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
const char *t = (char *)"hello\0wkkkorld\0heheheheeh\0";
int main() {
int length = 23;
char *p = t;
printf("length : %d\n", length);
size_t f = strnlen(t,10);
printf("f:%d\n",f);
p += f+1;
size_t g = strnlen(p,10);
printf("g:%d\n",g);
}
这段代码的输出为:
length : 23
f:5
g:8
下面来简要说一下这个过程:
首先,一开始我们初始化了一个字符串指针t
const char *t = (char *)"hello\0wkkkorld\0heheheheeh\0";
这个t就是指向这个字符串的起始地址。
然后,定义了一个指针p指向t指向的地址。此时,p也是指向这个字符串的起始地址。
strnlen函数解析
strlen会便利给定的字符串,在遇到第一个’\0’的时候结束,并返回这个字符串长度的大小。
那上面的例子来说,`strnlen(t,10);``返回的是5,也就是说在第一个字符串里面,找到第一个结束符的时候的字符串是5.
此时我们可以认为第一个字符串的大小是t[5]。
后面的10意思是在给定10个字符的长度内,寻找第一个子串的长度。
继续, p += f+1。执行到这条指令的时候,前面知道了f是5,此时p调整偏移到5+1的位置,也就是w上。
从w开始,使用strnlen。此时相当于忽略了hello\0了。那么这个时候开始就是wkkkorld,也就是字符串的长度为8.
有什么作用?
结合这个函数的特性,我们可以在已经知道一个字符串的长度的前提下,把里面每一个通过\0切分的字符串都找出来。
最佳实践
我们通过readelf可以从一个ko文件里面的.modinfosection给读出来。
读出来的.modinfo这个section的Elf_Data类型的sec->d_buf其实就是一个以\0为分割符的字符串。
通过strnlen,我们可以遍历其中的每一个字符串,找出“vermagic=”开头的字符串,从而可以找到这个ko的vermagic
876

被折叠的 条评论
为什么被折叠?



