《PHP實例:PHP不使用內置函數實現字符串轉整型的方法示例》要點:
本文介紹了PHP實例:PHP不使用內置函數實現字符串轉整型的方法示例,希望對您有用。如果有疑問,可以聯系我們。
PHP教程介紹
PHP教程php字符串類型的數字如果想轉成整型的數字,一般我們都是采用系統內置的API去做轉換,但如果規定就不讓我們去用系統內置的API轉換,而是讓自己去實現一個函數轉換該怎么辦?這里我們看下如何去實現.
PHP教程系統內置 API 方式
PHP教程
$num = '345432123';
//(一)
$num = (int)$num;
//輸出:
//int(345432123)
//(二)
$num = intval($num);
//輸出:
//int(345432123)
PHP教程采用 ASCII 碼方式
PHP教程下面我們利用 ascii 碼的方式去做轉換,因為每個字符都對應一個 ascii 碼,當對這個字符做加減乘除的時候,實際上就是對 ascii 碼做加減乘除操作,也就是整型操作,最終會返回一個整型數字.
PHP教程
-圖片轉自網絡-
PHP教程通過上圖可以看到字符 '0' ~ '9' 的 ascii 碼是 48~57 我們在轉換的時候就是用每一個字符減去 '0' 例如: '1' - '0' = 1、'2' - '0' = 2 返回值就是一個Int類型,下面具體看代碼實現.
PHP教程
function convertInt($strInt = ''){
$len = strlen($strInt);
$int = 0;
for($i=0;$i<$len;$i++){
$int *= 10;
$num = $strInt{$i} - '0';
$int += $num;
}
return $int;
}
$num = '345432123';
var_dump(convertInt($num)); //輸出: int(345432123)
PHP教程在 Redis 里面也有提供一個字符串轉整型的函數,也是通過ascii碼方式去做的,實現的比較完善嚴謹,具體可以參考下
PHP教程string2ll 函數
PHP教程
#include <stdio.h>
#include <limits.h>
#include <string.h>
/* 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;
}
PHP教程總結
PHP教程以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如有疑問大家可以留言交流,謝謝大家對維易PHP的支持.
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/548.html