今天看了一下网上关于这个函数的解释,根据文章大意记录一下
strtol 是将字符串转换为long int的一个函数
strtol(const char* nptr, char **endptr, int base)
nptr:待转换的str
endptr:返回非法字符串,默认为null
base: 转换基数
【以下来源】
strtol()函数检测到第一个非法字符时,立即停止检测,其后的所有字符都会被当作非法字符处理。合法字符串会被转换为long int, 作为函数的返回值。非法字符串,即从第一个非法字符的地址,被赋给*endptr。**endptr是个双重指针,即指针的指针。strtol()函数就是通过它改变*endptr的值,即把第一个非法字符的地址传给endptr。
多数情况下,endptr设置为NULL, 即不返回非法字符串。
下面看几个例子:
------------------------------------------------------
char buffer[20]="10379cend$3"; char *stop; printf("%d ",strtol(buffer, &stop, 2)); printf("%s ", stop); 输出结果: 2 379cend$3
-------------------------------------------------------
char buffer[20]="10379cend$3"; char *stop; printf("%d ",strtol(buffer, &stop, 8)); printf("%s ", stop); 输出结果: 543 9cend$3
-------------------------------------------------------- char buffer[20]="10379cend$3"; char *stop; printf("%d ",strtol(buffer, &stop, 10)); printf("%s ", stop); 输出结果: 10379 cend$3 ------------------------------------------------------- char buffer[20]="10379cend$3"; char *stop; printf("%d ",strtol(buffer, &stop, 16)); printf("%s ", stop); 输出结果: 17005006 nd$3
另外,如果base为0,且字符串不是以0x(或者0X)开头,则按十进制进行转化。如果base为0或者16,并且字符串以0x(或者0X)开头,那么,x(或者X)被忽略,字符串按16进制转化。如果base不等于0和16,并且字符串以0x(或者0X)开头,那么x被视为非法字符。
例如:
------------------------------------------------------- char buffer[20]="0x31da6c"; char *stop; printf("%d ",strtol(buffer, &stop, 0)); printf("%s ", stop); 输出结果(stop为空): 3267180 ------------------------------------------------------- char buffer[20]="0x31da6c"; char *stop; printf("%d ",strtol(buffer, &stop, 13)); printf("%s ", stop); 输出结果: 0 0x31da6c -------------------------------------------------------
最后,需要说明的是,对于nptr指向的字符串,其开头和结尾处的空格被忽视,字符串中间的空格被视为非法字符。
例如:
------------------------------------------------------- char buffer_1[20]="10379c"; char buffer_2[20]=" 10379c "; char buffer_3[20]=" 10 379c "; printf("%d ",strtol(buffer_1,NULL,0)); printf("%d ",strtol(buffer_2,NULL,0)); printf("%d ",strtol(buffer_3,NULL,0)); 输出结果为: 10379 10379 10