function

long int strtol (const char* str, char** endptr, int base); —— Convert string to long integer

long long int strtoll (const char* str, char** endptr, int base); —— Convert string to long long integer

unsigned long int strtoul (const char* str, char** endptr, int base); —— Convert string to unsigned long integer

unsigned long long int strtoull (const char* str, char** endptr, int base); —— Convert string to unsigned long long integer

Parses the C-string str interpreting its content as an integral number of the specified base, which is returned as a long int / long long int / unsigned long int / unsigned long long int value. If endptr is not a null pointer, the function also sets the value of endptr to point to the first character after the number.

The function first discards as many whitespace characters as necessary
until the first non-whitespace character is found. Then, starting from
this character, takes as many characters as possible that are valid
following a syntax that depends on the base parameter, and
interprets them as a numerical value. Finally, a pointer to the first
character following the integer representation in str is stored in the object pointed by endptr.

If the value of base is zero, the syntax expected is similar to that of integer constants, which is formed by a succession of:

  • An optional sign character (+ or -)
  • An optional prefix indicating octal or hexadecimal base ("0" or "0x"/"0X" respectively)
  • A sequence of decimal digits (if no base prefix was specified) or
    either octal or hexadecimal digits if a specific prefix is present

If the base value is between 2 and 36, the format expected
for the integral number is a succession of any of the valid digits
and/or letters needed to represent integers of the specified radix
(starting from '0' and up to 'z'/'Z' for radix 36). The sequence may optionally be preceded by a sign (either + or -) and, if base is 16, an optional "0x" or "0X" prefix.

If the first sequence of non-whitespace characters in str is not a valid integral number as defined above, or if no such sequence exists because either str is empty or it contains only whitespace characters, no conversion is performed.

For locales other than the "C" locale, additional subject sequence forms may be accepted.

Parameters

str
C-string beginning with the representation of an integral number.
endptr
Reference to an object of type char*, whose value is set by the function to the next character in str after the numerical value.
This parameter can also be a null pointer, in which case it is not used.
base
Numerical base (radix) that determines the valid characters and their interpretation.
If this is 0, the base used is determined by the format in the sequence (see above).

Return Value

On success, the function returns the converted integral number as a long int / long long int / unsigned long int / unsigned long long int value.
If no valid conversion could be performed, a zero value is returned (0L / 0LL / 0UL / 0ULL).
If the value read is out of the range of representable values by a long int / long long int / unsigned long int / unsigned long long int, the function returnsLONG_MAX orLONG_MIN  /LLONG_MAX orLLONG_MIN / ULONG_MAX /ULLONG_MAX (defined in<climits>), and errno is set to ERANGE.

examples

 /* strtol example */
#include <stdio.h> /* printf */
#include <stdlib.h> /* strtol */ int main ()
{
char szNumbers[] = "2001 60c0c0 -1101110100110100100000 0x6fffff";
char * pEnd;
long int li1, li2, li3, li4;
li1 = strtol (szNumbers,&pEnd,);
li2 = strtol (pEnd,&pEnd,);
li3 = strtol (pEnd,&pEnd,);
li4 = strtol (pEnd,NULL,);
printf ("The decimal equivalents are: %ld, %ld, %ld and %ld.\n", li1, li2, li3, li4);
return ;
}

运行结果:

The decimal equivalents are: 2001, 6340800, -3624224 and 7340031
 /* strtoll example */
#include <stdio.h> /* printf, NULL */
#include <stdlib.h> /* strtoll */ int main ()
{
char szNumbers[] = "1856892505 17b00a12b -01100011010110000010001101100 0x6fffff";
char* pEnd;
long long int lli1, lli2, lli3, lli4;
lli1 = strtoll (szNumbers, &pEnd, );
lli2 = strtoll (pEnd, &pEnd, );
lli3 = strtoll (pEnd, &pEnd, );
lli4 = strtoll (pEnd, NULL, );
printf ("The decimal equivalents are: %lld, %lld, %lld and %lld.\n", lli1, lli2, lli3, lli4);
return ;
}

运行结果:

The decimal equivalents are: 1856892505, 6358606123, -208340076 and 7340031
 /* strtoul example */
#include <stdio.h> /* printf, NULL */
#include <stdlib.h> /* strtoul */ int main ()
{
char buffer [];
unsigned long ul;
printf ("Enter an unsigned number: ");
fgets (buffer, , stdin);
ul = strtoul (buffer, NULL, );
printf ("Value entered: %lu. Its double: %lu\n",ul,ul*);
return ;
}

运行结果:

Enter an unsigned number: 30003
Value entered: 30003. Its double: 60006
 /* strtoull example */
#include <stdio.h> /* printf, NULL */
#include <stdlib.h> /* strtoull */ int main ()
{
char szNumbers[] = "250068492 7b06af00 1100011011110101010001100000 0x6fffff";
char * pEnd;
unsigned long long int ulli1, ulli2, ulli3, ulli4;
ulli1 = strtoull (szNumbers, &pEnd, );
ulli2 = strtoull (pEnd, &pEnd, );
ulli3 = strtoull (pEnd, &pEnd, );
ulli4 = strtoull (pEnd, NULL, );
printf ("The decimal equivalents are: %llu, %llu, %llu and %llu.\n", ulli1, ulli2, ulli3, ulli4);
return ;
}

运行结果:

The decimal equivalents are: 250068492, 2064035584, 208622688 and 7340031.

封装

     bool stringToI32(const std::string &str, int32_t  &val)
{
long temp_val = ;
bool isOK = stringToL(str, temp_val);
val = temp_val;
return isOK && (temp_val >= -0x7fffffff && temp_val <= 0x7fffffff/*32bit整形的有效范围*/);
} bool stringToU32(const std::string &str, uint32_t &val)
{
unsigned long temp_val = ;
bool isOK = stringToUL(str, temp_val);
val = temp_val;
return isOK && (temp_val <= 0xffffffff/*32bit无符号整形的有效范围*/);
} bool stringToI64(const std::string &str, int64_t &val)
{
long long temp_val = ;
bool isOK = stringToLL(str, temp_val);
val = temp_val;
return isOK && (temp_val >= -0x7fffffffffffffff && temp_val <= 0x7fffffffffffffff/*64bit整形的有效范围*/);
} bool stringToU64(const std::string &str, uint64_t &val)
{
unsigned long long temp_val = ;
bool isOK = stringToULL(str, temp_val);
val = temp_val;
return isOK && (temp_val <= 0xffffffffffffffff/*64bit无符号整形的有效范围*/);
} bool stringToL(const std::string &str, long &val)
{
bool isOK = false;
const char *nptr = str.c_str();
char *endptr = NULL;
errno = ;
val = strtol(nptr, &endptr, );
//error ocur
if ((errno == ERANGE && (val == LONG_MAX || val == LONG_MIN))
|| (errno != && val == ))
{ }
//no digit find
else if (endptr == nptr)
{ }
else if (*endptr != '\0')
{
// printf("Further characters after number: %s\n", endptr);
}
else
{
isOK = true;
} return isOK;
} bool stringToLL(const std::string &str, long long &val)
{
bool isOK = false;
const char *nptr = str.c_str();
char *endptr = NULL;
errno = ;
val = strtoll(nptr, &endptr, );
//error ocur
if ((errno == ERANGE && (val == LLONG_MAX || val == LLONG_MIN))
|| (errno != && val == ))
{ }
//no digit find
else if (endptr == nptr)
{ }
else if (*endptr != '\0')
{
// printf("Further characters after number: %s\n", endptr);
}
else
{
isOK = true;
} return isOK;
} bool stringToUL(const std::string &str, unsigned long &val)
{
bool isOK = false;
const char *nptr = str.c_str();
char *endptr = NULL;
errno = ;
val = strtoul(nptr, &endptr, );
//error ocur
if ((errno == ERANGE && (val == ULONG_MAX))
|| (errno != && val == ))
{ }
//no digit find
else if (endptr == nptr)
{ }
else if (*endptr != '\0')
{
// printf("Further characters after number: %s\n", endptr);
}
else
{
isOK = true;
} return isOK;
} bool stringToULL(const std::string &str, unsigned long long &val)
{
bool isOK = false;
const char *nptr = str.c_str();
char *endptr = NULL;
errno = ;
val = strtoull(nptr, &endptr, );
//error ocur
if ((errno == ERANGE && (val == ULLONG_MAX))
|| (errno != && val == ))
{ }
//no digit find
else if (endptr == nptr)
{ }
else if (*endptr != '\0')
{
// printf("Further characters after number: %s\n", endptr);
}
else
{
isOK = true;
} return isOK;
}

本文参考自:

http://www.cplusplus.com/reference/cstdlib/strtol/

http://www.cplusplus.com/reference/cstdlib/strtoll/

http://www.cplusplus.com/reference/cstdlib/strtoul/

http://www.cplusplus.com/reference/cstdlib/strtoull/

http://blog.csdn.net/ywy2090/article/details/64918801

strtol / strtoll / strtoul / strtoull的更多相关文章

  1. strtol,strtoll,strtoul, strtoull字符串转化成数字

      今天看kafka,有一个参数选项中有: 'S'   seq=strtoull(optarg,NULL,10); do_seq=1; 之后查找了下 strtoull 函数的功能,了解如下: ---- ...

  2. 函数atof,atoi,atol,strtod,strtol,strtoul 描述

    函数atof,atoi,atol,strtod,strtol,strtoul atof(将字串转换成浮点型数) 相关函数 atoi,atol,strtod,strtol,strtoul表头文件 #in ...

  3. atof,atoi,atol,strtod,strtol,strtoul

    字符串处理函数 atof 将字串转换成浮点型数 atoi 字符串转换成整型数 atol 函数名: atol 功 能: 把字符串转换成长整型数 用 法: long atol(const char *np ...

  4. strtoull函数的使用,及相关信息汇总

    kafka中涉及到序列化,有一个参数是在发送消息实体前边以一个序列号打头, seq = strtoull((prdcfgval+1), NULL, 10); do_seq = 1; 其中(prdcfg ...

  5. C和C++字符串处理整理

    在刷leetcode题目的过程中,发现自己对于c和c++字符串的处理并不是很拿手,处理起来比较费劲,而且,算法题似乎很中意字符串的处理,有很多题目都涉及到它.字符串处理比较基础,但是很重要,因此,整理 ...

  6. 调试 & 常数优化:我有特别的 debug 技巧

    rxz 的调试技巧(https://www.zhihu.com/question/60719584/answer/179363450): #define DEBUG printf("Pass ...

  7. 浅析C语言中strtol()函数与strtoul()函数的用法

    转自:http://www.jb51.net/article/71463.htm C语言strtol()函数:将字符串转换成long(长整型数) 头文件: ? 1 #include <stdli ...

  8. 字符串转换atof atoi atol gcvt strtod strtol strto ul toascii tolower toupper

    atof(将字符串转换成浮点型数) 相关函数 atoi,atol,strtod,strtol,strtoul 表头文件 #include <stdlib.h> 定义函数 double at ...

  9. C++字符串转整形、浮点型stof()、atoi()、strtol()等

    头文件:#include<stdlib.h>string str;stof:float val=stof(str);atoi:int val=atoi(str);atol:long val ...

随机推荐

  1. redis_常用命令

    一.启动redis客户端 cmd   cd D:\Project\redis-2.8.17   redis-cli.exe     二.常用命令   参考文档:http://redisdoc.com/ ...

  2. linux Socket send与recv函数详解

    转自:http://www.cnblogs.com/blankqdb/archive/2012/08/30/2663859.html linux send与recv函数详解   1 #include ...

  3. 手机APP上中下三层

    代码如下: <template> <div class="container" id="app"> <header> < ...

  4. redigo简单理解

    package main import ( "fmt" "github.com/gomodule/redigo/redis") func main() { // ...

  5. C++静态库与动态库详解

    1 库的概念? 库是写好的现有的,成熟的,可以复用的代码.现实中每个程序都要依赖很多基础的底层库. 2 动态库与静态库的概念? 先回顾一下编译过程: 2.1 静态库 静态库在链接阶段,会将汇编生成的目 ...

  6. Kali之Metasploit Framework环境配置

    运行Metasploit Framework 依照Kali Linux网络服务策略,Kali没有自动启动的网络服务,包括数据库服务在内.所以为了让Metasploit以支持数据库的方式运行有些必要的步 ...

  7. scrapy-splash抓取动态数据例子一

    目前,为了加速页面的加载速度,页面的很多部分都是用JS生成的,而对于用scrapy爬虫来说就是一个很大的问题,因为scrapy没有JS engine,所以爬取的都是静态页面,对于JS生成的动态页面都无 ...

  8. Cat安装

    1,windows7+jdk1.7(1.7,1.6都可以,1.8不行)+maven3.3.3 2,到github上下载cat源码 https://github.com/dianping/cat 例如下 ...

  9. escape(s, t)函数的实现

    https://item.taobao.com/item.htm? spm=686.1000925.0.0.9TTLHO&id=535006878999 <span style=&quo ...

  10. 算法笔记_089:蓝桥杯练习 7-2求arccos值(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 利用标准库中的cos(x)和fabs(x)函数实现arccos(x)函数,x取值范围是[-1, 1],返回值为[0, PI].要求结果准确 ...