php字符串转变整数,关于优化:在PHP中将字符串转换为整数的最快方法

这篇博客讨论了在PHP中将字符串转换为整数的最快方法,通过基准测试比较了`(int)`、`intval()`和`0 + $var`等方法的性能。结果显示,`(int)`运算符通常最快,但在处理非数字字符串时可能导致意外结果,如将'hello'转换为0。文章还提到了类型转换中的一些潜在陷阱和最佳实践。
摘要由CSDN通过智能技术生成

使用php,将这样的字符串转换为整数最快的方法是什么:"123"?

为什么那个方法最快?如果它得到意外的输入,如"hello"或数组,会发生什么?

比尔:这不是家庭作业,我只是好奇而已。:)

为什么"最快"是相关的?

好吧,如果它不伤害(可读性),为什么不以最有效的方式做事情呢?

如果它不影响速度,为什么不以最易读的方式做事情呢?

@安迪,看看下面的基准测试。(int)和intval()之间的差异可以超过400%!

速度最重要,因为速度对用户体验至关重要。当你有很多的操作在进行时,你想让他们快点!

在这种情况下,我也会说速度与可读性的问题是无关的,因为问题是在优化下标记的。在优化下标记的问题中想要速度的原因是不言而喻的。

我刚刚设置了一个快速基准测试:

Function             time to run 1 million iterations

--------------------------------------------

(int)"123":                0.55029

intval("123"):              1.0115  (183%)

(int)"0":                  0.42461

intval("0"):                0.95683 (225%)

(int) int:                  0.1502

intval(int):                0.65716 (438%)

(int) array("a","b"):      0.91264

intval(array("a","b")):    1.47681 (162%)

(int)"hello":              0.42208

intval("hello"):            0.93678 (222%)

平均来说,调用intval()的速度要慢两倍半,如果您的输入已经是一个整数,则差异最大。

不过,我想知道原因。

更新:我再次运行测试,这次是强制执行(0 + $var)。

| INPUT ($x)      |  (int) $x  |intval($x) |  0 + $x   |

|-----------------|------------|-----------|-----------|

|"123"           |   0.51541  |  0.96924  |  0.33828  |

|"0"             |   0.42723  |  0.97418  |  0.31353  |

| 123             |   0.15011  |  0.61690  |  0.15452  |

| array("a","b") |   0.8893   |  1.45109  |  err!     |

|"hello"         |   0.42618  |  0.88803  |  0.1691   |

|-----------------|------------|-----------|-----------|

附录:我刚刚遇到了一个稍微出乎意料的行为,在选择这些方法时你应该注意到:

$x ="11";

(int) $x;      // int(11)

intval($x);    // int(11)

$x + 0;        // int(11)

$x ="0x11";

(int) $x;      // int(0)

intval($x);    // int(0)

$x + 0;        // int(17) !

$x ="011";

(int) $x;      // int(11)

intval($x);    // int(11)

$x + 0;        // int(11) (not 9)

使用php 5.3.1测试

这可能与以下事实有关:intval()调用函数调用,而cast直接在解释器的表达式计算器中处理。这也可能是合作更快的原因。

使用PHP鲜为人知的一元加号运算符可以进一步简化强制示例。$x+ 0 -> +x

@奥兹,太棒了。谢谢你的小费!+"15" == 15

@nickf反对100%的……什么?你说EDOCX1[1]是最慢的,但你没有给出简单的明确的答案,因为根据手术要求,什么是最快的。

@由于约翰在第一个代码中只测试了两个案例,即(int)和intval,并且在每对代码中,给出了intval的百分比,所以基本案例必须是(int)。但你有一个很好的观点,那就是如果他这么明确地说的话,那就更清楚了,特别是在他后来又加了第三个案例之后!

…加上的表显示了第三种情况的0+$x(或者根据注释简单地说是+$x)比原来的两种情况更快,假设值是time to run 1 million iterations,根据原来的表。

是否有任何更改会导致更新的PHP版本?

我个人认为演员是最漂亮的。

$iSomeVar = (int) $sSomeOtherVar;

如果发送类似"hello"的字符串,它将被强制转换为整数0。对于"22岁"这样的字符串,它将被强制转换为整数22。它无法解析为数字的任何内容都将变为0。

如果你真的需要速度,我想这里的其他建议是正确的,假设强迫是最快的。

有趣的是,数组被强制转换为1。算了吧。

@尼克不是这样的-它也可以被铸造成0。它将它的布尔值(真假)强制转换为整数-"假"=0,"真"=1。如果数组为100%空,则为假;如果数组包含任何数据,则为真,即使它只是空字符串或空值。如果将空数组强制转换为整数,它将变为0。(是的,我知道这很古老!)

运行测试。

string coerce:          7.42296099663

string cast:            8.05654597282

string fail coerce:     7.14159703255

string fail cast:       7.87444186211

这是一个测试,每个场景运行10000000次。-)

合同为0 +"123"。

铸件为(integer)"123"

我觉得合作有点快。哦,在PHP中尝试0 + array('123')是一个致命的错误。您可能希望代码检查所提供值的类型。

我的测试代码如下。

function test_string_coerce($s) {

return 0 + $s;

}

function test_string_cast($s) {

return (integer)$s;

}

$iter = 10000000;

print"-- running each text $iter times.

";

// string co-erce

$string_coerce = new Timer;

$string_coerce->Start();

print"String Coerce test

";

for( $i = 0; $i < $iter ; $i++ ) {

test_string_coerce('123');

}

$string_coerce->Stop();

// string cast

$string_cast = new Timer;

$string_cast->Start();

print"String Cast test

";

for( $i = 0; $i < $iter ; $i++ ) {

test_string_cast('123');

}

$string_cast->Stop();

// string co-erce fail.

$string_coerce_fail = new Timer;

$string_coerce_fail->Start();

print"String Coerce fail test

";

for( $i = 0; $i < $iter ; $i++ ) {

test_string_coerce('hello');

}

$string_coerce_fail->Stop();

// string cast fail

$string_cast_fail = new Timer;

$string_cast_fail->Start();

print"String Cast fail test

";

for( $i = 0; $i < $iter ; $i++ ) {

test_string_cast('hello');

}

$string_cast_fail->Stop();

// -----------------

print"

";

print"string coerce:         ".$string_coerce->Elapsed()."

";

print"string cast:           ".$string_cast->Elapsed()."

";

print"string fail coerce:    ".$string_coerce_fail->Elapsed()."

";

print"string fail cast:      ".$string_cast_fail->Elapsed()."

";

class Timer {

var $ticking = null;

var $started_at = false;

var $elapsed = 0;

function Timer() {

$this->ticking = null;

}

function Start() {

$this->ticking = true;

$this->started_at = microtime(TRUE);

}

function Stop() {

if( $this->ticking )

$this->elapsed = microtime(TRUE) - $this->started_at;

$this->ticking = false;

}

function Elapsed() {

switch( $this->ticking ) {

case true: return"Still Running";

case false: return $this->elapsed;

case null: return"Not Started";

}

}

}

我在这个测试中添加了settype,并使用php 7运行它。Cast稍微领先一点,性能大大提高:字符串强制:1.9255340099335字符串强制:1.5142338275909字符串设置类型:4.149735212326字符串失败强制:1.234656095048字符串失败强制:1.3967711925507字符串失败设置类型:4.149735212326

使用float可以简单地将长字符串转换为整数

$float = (float)$num;

或者,如果您希望整数不是浮动的val,则使用

$float = (int)$num;

为Ex.

(int)  "1212.3"   = 1212

(float)"1212.3"   = 1212.3

呵呵?如果你想要一个int,为什么不使用(int)?如果字符串包含一个整数,那么(float)将返回一个非常类似于整数的值(尽管它的内部类型可能是float类型),这可能是真的,但是如果规范要返回一个整数值,为什么要这样做呢?假设传入字符串是"1.3"?你得不到整数。另外,为了将来阅读代码的人,你应该说出你的意思。如果你的意思是"它应该是一个整数",那么说(int),而不是(float)。

从任何字符串中提取的整数

$in='电话:123-12-33';

preg_match_all('!\d+!', $in, $matches);

$out =  (int)implode('', $matches[0]);

//$out='1231233';

你是最好的,最好的!我花了几个小时将一些var从json数据字符串转换为整数,只有您的方法有帮助!谢谢您!

$int = settype("100","integer"); //convert the numeric string to int

我相信一些参考或证据是正确的!

如果语句有效,$int在这里实际上是一个布尔值,但是它不会,因为settype()的第一个参数是通过引用传递的,所以必须是var。

运行了一个基准,结果是获得真正整数的最快方法(使用所有可用的方法)是

$foo = (int)+"12.345";

只是使用

$foo = +"12.345";

返回浮点值。

这比简单的(int)"12.345"快吗?快多少百分比?

更多特别基准结果:

$ time php -r 'for ($x = 0;$x < 999999999; $x++){$i = (integer)"-11";}'

real    2m10.397s

user    2m10.220s

sys     0m0.025s

$ time php -r 'for ($x = 0;$x < 999999999; $x++){$i +="-11";}'

real    2m1.724s

user    2m1.635s

sys     0m0.009s

$ time php -r 'for ($x = 0;$x < 999999999; $x++){$i = +"-11";}'

real    1m21.000s

user    1m20.964s

sys     0m0.007s

最好在每个循环中编写被测试语句10倍,这样时间就不会被循环开销所支配。如{ $i = +"-11"; $i = +"-11"; $i= +"-11"; $i= +"-11"; ... }。直接使用文本值"-11"也是有风险的,除非您确信该语言在编译时不会完成某些工作。对于像php这样的动态语言,也许可以,但是我提到如果用其他语言测试公式,将来会参考它。在测试循环之前设置一个变量$x ="-11",然后使用它更安全。所以内部代码是$i =+$x。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值