strtol / strtoll / strtoul / strtoull
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 /
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.unsigned long long int
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 is0
, 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 /
, the function returnsLONG_MAX orLONG_MIN /LLONG_MAX orLLONG_MIN / ULONG_MAX /ULLONG_MAX (defined in<climits>), and errno is set to ERANGE.long long int
/ unsigned long int
/ unsigned long long int
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的更多相关文章
- strtol,strtoll,strtoul, strtoull字符串转化成数字
今天看kafka,有一个参数选项中有: 'S' seq=strtoull(optarg,NULL,10); do_seq=1; 之后查找了下 strtoull 函数的功能,了解如下: ---- ...
- 函数atof,atoi,atol,strtod,strtol,strtoul 描述
函数atof,atoi,atol,strtod,strtol,strtoul atof(将字串转换成浮点型数) 相关函数 atoi,atol,strtod,strtol,strtoul表头文件 #in ...
- atof,atoi,atol,strtod,strtol,strtoul
字符串处理函数 atof 将字串转换成浮点型数 atoi 字符串转换成整型数 atol 函数名: atol 功 能: 把字符串转换成长整型数 用 法: long atol(const char *np ...
- strtoull函数的使用,及相关信息汇总
kafka中涉及到序列化,有一个参数是在发送消息实体前边以一个序列号打头, seq = strtoull((prdcfgval+1), NULL, 10); do_seq = 1; 其中(prdcfg ...
- C和C++字符串处理整理
在刷leetcode题目的过程中,发现自己对于c和c++字符串的处理并不是很拿手,处理起来比较费劲,而且,算法题似乎很中意字符串的处理,有很多题目都涉及到它.字符串处理比较基础,但是很重要,因此,整理 ...
- 调试 & 常数优化:我有特别的 debug 技巧
rxz 的调试技巧(https://www.zhihu.com/question/60719584/answer/179363450): #define DEBUG printf("Pass ...
- 浅析C语言中strtol()函数与strtoul()函数的用法
转自:http://www.jb51.net/article/71463.htm C语言strtol()函数:将字符串转换成long(长整型数) 头文件: ? 1 #include <stdli ...
- 字符串转换atof atoi atol gcvt strtod strtol strto ul toascii tolower toupper
atof(将字符串转换成浮点型数) 相关函数 atoi,atol,strtod,strtol,strtoul 表头文件 #include <stdlib.h> 定义函数 double at ...
- C++字符串转整形、浮点型stof()、atoi()、strtol()等
头文件:#include<stdlib.h>string str;stof:float val=stof(str);atoi:int val=atoi(str);atol:long val ...
随机推荐
- Microsoft office(2)多级标题的设置
在Microsoft office中要达到下面的标题结构: 1.首先将文字准备好: 2.将“绪论”,“无线...介绍”等章节标题分别选中 :段落-->大纲级别-->1级 3.同样的,“研究 ...
- mysql-operator 尝试与研究
安装指南 先下载到本地 git clone https://github.com/kubernetes/charts.git 安装helm 参考: http://www.cnblogs.com/eri ...
- [转]Getting started with SSIS - Part 10: Event Handling and Logging
本文转自:http://beyondrelational.com/modules/12/tutorials/24/tutorials/9686/getting-started-with-ssis-pa ...
- linux下使用C++ Json库
安装Json库 1.下载JsonCpphttp://sourceforge.net/projects/jsoncpp/files/ 2.下载sconshttp://sourceforge.net/pr ...
- javascript上传多张图片并预览
直接上代码 html代码 <div> <label>封面</label> <input type="file" id="cove ...
- JS 图片转Base64
JS 图片转Base64 有时候需要向HTML中插入一张图片,可苦于上线后找不到一个合适的网盘来存储这些图片,有没有一种办法能将图片转换成文字,然后直接插入HTML中呢,通过Base64编码就可以解决 ...
- 【算法导论C++代码】Strassen算法
简单方阵矩乘法 SQUARE-MATRIX-MULTIPLY(A,B) n = A.rows let C be a new n*n natrix to n to n cij = to n cij=ci ...
- 【Javascript】如何实现点的wave效果 && sinewave效果
参考资料: sinewave效果:http://www.oneapm.com/ci/docker.html?utm_source=BaiduPaid&utm_medium=cpc&ut ...
- SVN-两种存储方式的比较(BDB vs. FSFS)
Subversion 的版本库(repository),就是位于服务器端,统一管理和储存数据的地方.本文中,我们以 Linux 为例,介绍在服务器端配置和管理 Subversion 版本库的基本方法. ...
- Android布局属性集合
<!-- android:id —— 为控件指定相应的ID android:text —— 指定控件当中显示的文字,需要注意的是,这里尽量使用strings.xml文件当中的字符串 andro ...