内容简介:首先,我要申明这样的面试题,其实很没意思。 不过作为一个有趣的知识点,我今天就说说这个小问题吧。我们知道64位的整数的表值范围是-9223372036854775808 到 9223372036854775807.在64位系统上PHP内部是使用有符号的64位整形来表示IS_LONG, 分别有俩个常量来表示这俩个值, 分别是PHP_INT_MIN和PHP_INT_MAX.
刚刚吃饭的时候想说今天再写点啥? 突然想起来前几天有人在微博上评论我的一个 PHP 的面试题:
首先,我要申明这样的面试题,其实很没意思。 不过作为一个有趣的知识点,我今天就说说这个小问题吧。
我们知道64位的整数的表值范围是-9223372036854775808 到 9223372036854775807.
在64位系统上PHP内部是使用有符号的64位整形来表示IS_LONG, 分别有俩个常量来表示这俩个值, 分别是PHP_INT_MIN和PHP_INT_MAX.
在64位平台上,PHP_INT_MIN就等于-9223372036854775808,那题目的意思是啥呢? 我们输出下看看:
var_dump(PHP_INT_MAX); var_dump(-9223372036854775808);
输出:
int(9223372036854775807) float(-9.2233720368548E+18)
那是什么造成了这个问题呢?
在PHP编译器处理输入文件输入的时候,对于负数字面量它的处理方式是:
-{LNUM}
=> '-' expr { $$ = zend_ast_create(ZEND_AST_UNARY_MINUS, $2); }
=> UNARY_MINUS: 0 - expr
也就是,首先把负号后面的数字作为一个整形接受进来,然后在把它求负。
于是这就造成了这个问题, 开头我们说了64位的最大正表值是9223372036854775807,那当PHP处理-9223372036854775808的时候, 9223372036854775808超出了64位整形的最大正表值范围,PHP没有办法用一个有符号64位整形存储它,于是只能把它自动转成了DOUBLE类型。 于是接下来....
那PHP_INT_MAX又是怎么回事呢? 其实PHP_INT_MIN的定义不是一个常数,而是一个表达式,类似:
#define PHP_INT_MIN -9223372036854775807 - 1
于是就不会触发这个限制,就能正常表达PHP_INT_MIN啦。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入浅出强化学习:原理入门
郭宪、方勇纯 / 电子工业出版社 / 2018-1 / 79
《深入浅出强化学习:原理入门》用通俗易懂的语言深入浅出地介绍了强化学习的基本原理,覆盖了传统的强化学习基本方法和当前炙手可热的深度强化学习方法。开篇从最基本的马尔科夫决策过程入手,将强化学习问题纳入到严谨的数学框架中,接着阐述了解决此类问题最基本的方法——动态规划方法,并从中总结出解决强化学习问题的基本思路:交互迭代策略评估和策略改善。基于这个思路,分别介绍了基于值函数的强化学习方法和基于直接策略......一起来看看 《深入浅出强化学习:原理入门》 这本书的介绍吧!