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. 如何解决sqlmapapi重启后,任务全部丢失的问题

    sqlmapapi的server每次启动时都会创建一个新的数据库,这样之前的扫描记录都会全部丢失 使用python sqlmapapi.py -s可以看大IPC database的位置,这个各个操作系 ...

  2. iOS:多线程同步加锁的简单介绍

    多线程同步加锁主要方式有3种:NSLock(普通锁).NSCondition(状态锁).synchronized同步代码块 还有少用的NSRecursiveLock(递归锁).NSConditionL ...

  3. XSD-学习总结

    1.代码详细分析 <?xml version="1.0"?> <xs:schema xmlns:xs="http://www.w3.org/2001/X ...

  4. dedecms会员注册注入漏洞

    一.首先访问“/data/admin/ver.txt”页面获取系统最后升级时间,(判断是否是dede的cms 以及看看是否和这个漏洞相对应)二.然后访问“/member/ajax_membergrou ...

  5. .NET Fframework

    .NET框架示意图: 该框架是微软推出的完全面向对象的软件开发与运行平台.其有两个主要 组将:CLR:公共语言运行库(Common Language Runtime,简称CLR)和.NET Frame ...

  6. 破解MyEclipse2015 stable3.0

    整个破解过程最好断网: 1.安装好MyEclipse2015 stable3后,打开设置好工作目录后,退出.2.将plugins文件夹中的文件拷贝到myeclipse安装目录的plugins文件夹下, ...

  7. 使用MyEclipse 2014构建Maven项目的两种方法

    前提: MyEclipse已配置Maven,具体步骤见http://blog.csdn.net/haishu_zheng/article/details/51492491 方法一: 1 File--& ...

  8. cglib Demo

    转载自:http://huihai.iteye.com/blog/858524 http://www.cnblogs.com/shijiaqi1066/p/3429691.html

  9. jenkins+testNG

    1.项目的pom.xml要配置插件,同时指定testng.xml文件的位置.就被这个卡了好久 <properties> <maven-surefire-plugin.version& ...

  10. redis学习笔记——RDB、AOF和复制时对过期键的处理

    AOF.RDB和复制功能对过期键的处理 生成RDB文件 在执行SAVE命令或者BGSAVE命令创建一个新的RDB文件时,程序会对数据库中的键进行检查,已过期的键不会被保存到新创建的RDB文件中.举个例 ...