C++官网参考链接:https://cplusplus.com/reference/cstdlib/atol/
函数
<cstdlib>
atol
long int atol ( const char * str );
将字符串转换为long整数
解析C字符串str,将其内容解释为一个整数,该整数作为long int类型的值返回。
函数首先丢弃尽可能多的空白字符(如在isspace中返回true的字符)直到找到第一个非空字符。然后,从这个字符开始,取一个可选的初始加号或减号,后面跟着尽可能多的以10为基数的数字,并将它们解释为一个数值。
字符串可以在构成整数的字符之后包含其他字符,这些字符将被忽略,并且对该函数的行为没有影响。
如果第一个非空字符序列str不是一个有效的整数,或者如果没有这样的序列存在,因为str是空的或者它只包含空白字符,则不执行转换,并返回0。
形参
str
包含整数表示形式的C字符串。
返回值
如果成功,该函数将转换后的整数值作为long int值返回。
如果不能执行有效的转换,则返回0值。
如果转换的值超出了long int的可表示值的范围,就会导致未定义的行为。如果可能,请参阅strtol以获得更健壮的跨平台替代方案。
用例
/* atol example */
#include <stdio.h> /* printf, fgets */
#include <stdlib.h> /* atol */
int main ()
{
long int li;
char buffer[256];
printf ("Enter a long number: ");
fgets (buffer, 256, stdin);
li = atol(buffer);
printf ("The value entered is %ld. Its double is %ld.\n",li,li*2);
return 0;
}
输出:
数据竞争
访问由str指向的数组。
异常(C++)
无抛出保证:此函数从不抛出异常。
如果str不指向有效的C字符串,或者转换后的值超出了long int所代表的值范围,则会导致未定义行为。