PHP不使用内置函数实现字符串转整型的方法示例

开发技术 作者: 2024-08-17 20:20:01
一般php字符串类型的数字如果想转成整型的数字,我们都是采用系统内置的API去做转换,但下面这篇文章主要给大家介绍了关于PHP不使用内置函数实现字符串转整型的方法示例,文中介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。

介绍

PHP字符串类型的数字如果想转成整型的数字,一般我们都是采用系统内置的API去做转换,但如果规定就不让我们去用系统内置的API转换,而是让自己去实现一个函数转换该怎么办?这里我们看下如何去实现。

系统内置 API 方式

//(一)
$num = (int)$num;
//输出:
//int(345432123)

//(二)
$num = intval($num);
//输出:
//int(345432123)

采用 ASCII 码方式

下面我们利用 ascii 码的方式去做转换,因为每个字符都对应一个 ascii 码,当对这个字符做加减乘除的时候,实际上就是对 ascii 码做加减乘除操作,也就是整型操作,最终会返回一个整型数字.

-图片转自网络-

通过上图可以看到字符 '0' ~ '9' 的 ascii 码是 48~57 我们在转换的时候就是用每一个字符减去 '0' 例如: '1' - '0' = 1、'2' - '0' = 2 返回值就是一个Int类型,下面具体看代码实现.

for($i=0;$i<$len;$i++){
$int *= 10;
$num = $strInt{$i} - '0';
$int += $num;
}

return $int;
}

$num = '345432123';
var_dump(convertInt($num)); //输出: int(345432123)

在 Redis 里面也有提供一个字符串转整型的函数,也是通过ascii码方式去做的,实现的比较完善严谨,具体可以参考下

string2ll 函数

#include #include

/* Convert a string into a long long. Returns 1 if the string could be parsed

  • into a (non-overflowing) long long,0 otherwise. The value will be set to
  • the parsed value when appropriate. /
    int string2ll(const char
    s,size_t slen,long long value) {
    const char
    p = s;
    size_t plen = 0;
    int negative = 0;
    unsigned long long v;

if (plen == slen)
return 0;

/ Special case: first and only digit is 0. /
if (slen == 1 && p[0] == '0') {
if (value != NULL) *value = 0;
return 1;
}

if (p[0] == '-') {
negative = 1;
p++; plen++;

/ Abort on only a negative sign. /
if (plen == slen)
return 0;
}

/ First digit should be 1-9,otherwise the string should just be 0. /
if (p[0] >= '1' && p[0] <= '9') {
v = p[0]-'0';
p++; plen++;
} else if (p[0] == '0' && slen == 1) {
*value = 0;
return 1;
} else {
return 0;
}

while (plen < slen && p[0] >= '0' && p[0] <= '9') {
if (v > (ULLONG_MAX / 10)) / Overflow. /
return 0;
v *= 10;

if (v > (ULLONG_MAX - (p[0]-'0'))) / Overflow. /
return 0;
v += p[0]-'0';

p++; plen++;
}

/ Return if not all bytes were used. /
if (plen < slen)
return 0;

if (negative) {
if (v > ((unsigned long long)(-(LLONG_MIN+1))+1)) / Overflow. /
return 0;
if (value != NULL) value = -v;
} else {
if (v > LLONG_MAX) /
Overflow. /
return 0;
if (value != NULL)
value = v;
}
return 1;
}

//-------- 执行 ---------
int main(){
long long num;
string2ll("345432123",strlen("345432123"),&num);
printf("%d\n",num); //输出 345432123
retunr 0;
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对编程之家的支持。

原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_63973.html