首页 » 网站建设 » phplog函数技巧_数学相关函数在PHP中的应用简介

phplog函数技巧_数学相关函数在PHP中的应用简介

访客 2024-11-02 0

扫一扫用手机浏览

文章目录 [+]

var_dump(abs(-12)); // int(12)var_dump(abs("-12.22")); // float(12.22)var_dump(ceil(2)); // float(2)var_dump(ceil(2.1)); // float(3)var_dump(ceil(2.9)); // float(3)var_dump(ceil(-2.9)); // float(-2)var_dump(floor(2)); // float(2)var_dump(floor(2.1)); // float(2)var_dump(floor(2.9)); // float(2)var_dump(floor(-2.9)); // float(-3)

abs() 是获取数据的绝对值。
ceil() 用于舍弃小数位,并返回向上的一个整数,比如我们测试代码中的 2.1 利用 ceil() 之后返回的结果是 3 。
而 -2.9 返回的结果则是 2 。
实在也便是返回的是舍弃小数后并且不小于这个给天命据的一个整数。

floor() 的浸染和 ceil() 是反过来的,返回的是舍弃浮点数点后小于给天命据的一个整数。

phplog函数技巧_数学相关函数在PHP中的应用简介 phplog函数技巧_数学相关函数在PHP中的应用简介 网站建设

var_dump(fmod(5.7, 1.3)); // float(0.5)var_dump(fmod(6, 3)); // float(0)var_dump(pow(2,5)); // int(32)var_dump(sqrt(9)); // float(3)var_dump(sqrt(10)); // float(3.1622776601684)

fmod() 返回的是取模之后的余数,它是带小数的,如果直策应用 % 取模的话,只会返回整数。
大家可以试下 5.7%1.3 的结果是什么。

phplog函数技巧_数学相关函数在PHP中的应用简介 phplog函数技巧_数学相关函数在PHP中的应用简介 网站建设
(图片来自网络侵删)

pow() 也是比较常用的乘方函数,第二个参数便是第一个参数的几次方。
sqrt() 则是二次根函数,9 开方后的结果便是 3 。

除了 sqrt() 之外,还有几个二次方根常量是系统为我们定义好的。

var_dump(M_SQRT2); // sqrt(2) float(1.4142135623731)var_dump(M_SQRT3); // sqrt(3) float(1.7320508075689)var_dump(M_SQRT1_2); // 1/sqrt(2) float(0.70710678118655)

它们对应的效果实在便是注释中写明的调用 sqrt() 函数的效果。
比如 M_SQRT2 就相称于是 2 的二次方根 sqrt(2) 的效果。

var_dump(max(10, 20, 39, 25)); // int(39)var_dump(min(5, 3, 1, 9, 8)); // int(1)var_dump(max([10, 20, 39, 25])); // int(39)var_dump(min([5, 3, 1, 9, 8])); // int(1)

max() 函数用于返回指定参数中最大的那个数,min() 函数用于返回指定参数中最小的那个数。
这两个函数的参数都是不固定长度的,也便是你传多少个参数都可以的。
它也可以直接吸收一个数组作为参数,并返回数组中最大的那个元素。
这两个函数可以合营指定一个变量的最大最小值范围。
比如我们的分页:

max(1, min(100, $page));

它的意思是通报过来确当前页只能是 1 - 100 范围内的,如果超过 100 了,则返回 100 ,如果小于 1 了,则返回 1 。
可能第一次打仗到这两个函数的同学看到这个会比较晕,仔细揣摩一下哦!

var_dump(is_finite(M_PI)); // bool(true)var_dump(is_infinite(M_PI)); // bool(false)var_dump(is_finite(M_EULER)); // bool(true)

is_finite() 和 is_infinite() 用于判断数据是否是无理数,is_finite() 在利用的时候如果数据是无理数的话,它返回的是 ture 。
而 is_infinite() 则相反,无理数时返回的是 false ,有理数时返回的是 true 。

圆周率干系

在上文中,我们看到了一个常量 M_PI 。
它代表的便是 3.14…… 那个圆周率的数值。

var_dump(M_PI); // float(3.1415926535898)var_dump(pi()); // float(3.1415926535898)

可以看到,直接打印的话,M_PI 只是精确到小数点后 13 位,但通过 is_finite() 判断的话,它返回的是无理数,也便是无限不循环小数的。
其余,通过 pi() 这个函数,也可以得到圆周率的数值。
此外,还有一堆和派有关的常量。

var_dump(M_PI_2); // pi()/2 float(1.5707963267949)var_dump(M_PI_4); // pi()/4 float(0.78539816339745)var_dump(M_1_PI); // 1/pi() float(0.31830988618379)var_dump(M_2_PI); // 2/pi() float(0.63661977236758)var_dump(M_SQRTPI); // sqrt(pi()) float(1.7724538509055)var_dump(M_2_SQRTPI); // 2/sqrt(pi) float(1.1283791670955)var_dump(M_LNPI); // log_e(pi()) float(1.1447298858494)

它们所代表的含义在注释中也已经解释了。
比如 M_PI_2 所代表的意思便是 派 除以 2 之后的结果。

对数

虽说常用的一些对数我们已经烂熟于心了,但一些不常用或者运算后天生的对数手算是非常麻烦的,不用担心,PHP 也已经为我们准备好了对数的打算函数。

var_dump(log(32)); // float(3.4657359027997)var_dump(log(32, 2)); // 5

默认情形下,log() 函数因此 10 为底的对数打算,我们可以直接给它指定第二个参数为底数。

var_dump(log10(1000)); // float(3)var_dump(log1p(31)); // float(3.4657359027997)var_dump(exp(12)); // float(162753.791419)

log10() 很明显便是直接以 10 为底的对数运算。
而 log1p() 返回的则是 log(1+number) 的结果,也便是给对数默认加了 1 。
exp() 函数是打算 e 的指数,测试代码中计算的便是 e12 的值。

var_dump(M_E); // e float(2.718281828459)var_dump(M_LOG2E); // log_2 e float(1.442695040889)var_dump(M_LOG10E); // log_10 e float(0.43429448190325)var_dump(M_LN2); // log_e 2 float(0.69314718055995)var_dump(M_LN10); // log_e 10 float(2.302585092994)

同样,对数也有很多常量,详细的阐明也都在注释中,大家可以自己看一下。

随机数

随机数的功能恐怕是 Math 扩展中最为常用的。

var_dump(getrandmax()); // int(2147483647)

getrandmax() 函数用于返回随机数所能产生的最大值。
结合下面的 rand() 函数再来看这个函数的浸染。

var_dump(rand()); var_dump(rand(5, 15));

如果我们不指定 rand() 函数的参数,也便是不指定它的范围的话,那么 rand() 函数天生的值便是从 0 到 getrandmax() 范围内的任意随机数。
如果我们为 rand() 函数指定了范围,那么只会天生指定例模内的随机数。

var_dump(mt_getrandmax()); // int(2147483647)var_dump(mt_rand()); var_dump(mt_rand(5, 15));

mt_ 开头的这三个随机数干系的函数在利用上和普通的 rand() 没有什么差异。
不过现在更推举利用 mt_rand() 来天生随机数。
它产生随机数的均匀速率比 rand() 快四倍,这是官方文档中说的,而且,mt_rand() 在文档中也说了是非正式用来更换 rand() 函数的。
反正不管怎么样,既然官方文档都这么说了,那么我们还是只管即便多利用 mt_rand() 吧。

其余,现在天生随机数不须要预先准备随机数种子了,也便是不须要利用 srand() 或 mt_srand() 这两个函数了。
可能在一些框架中会见到它们的身影哦,这里我就不做演示了。

三角函数

三角函数估计是大家中学期间的噩梦。
其实在程序开拓中,除了特定的一些领域之外,利用它们的机会还真的不多。
就像我就从来都没有利用过,以是这里便是大略地演示一下。

var_dump(hypot(3,4)); // float(5)var_dump(hypot(5,12)); // float(13)

首先是一个打算三角形斜边的函数 hypot() 。
这里测试我们用得是最经典的两个 勾股数 ,相信这个结果又勾起了大家中学时的美好回顾吧。

var_dump(sin(M_PI_2)); // float(1)var_dump(cos(M_PI_2)); // float(6.1232339957368E-17)var_dump(tan(M_PI_2)); // float(1.6331239353195E+16)var_dump(sin(deg2rad(90))); // float(1)var_dump(asin(sin(M_PI_2))); // float(1.5707963267949)var_dump(acos(cos(M_PI_2))); // float(1.5707963267949)var_dump(atan(tan(M_PI_2))); // float(1.5707963267949)var_dump(sinh(sin(M_PI_2))); // float(1.1752011936438)var_dump(cosh(cos(M_PI_2))); // float(1)var_dump(tanh(tan(M_PI_2))); //float(1)var_dump(asinh(sin(M_PI_2))); // float(0.88137358701954)var_dump(acosh(cos(M_PI_2))); // float(NAN)var_dump(atanh(tan(M_PI_2))); // float(NAN)

这一大片就不用多阐明了吧,说多了都是眼泪啊。
个中比较分外的是我们可以看到有一个 deg2rad() 方法,它是用来将角度转换成弧度的函数。
前面带 a 的都是对应三角函数的反函数,后面带 h 的都是对应三角函数的双曲函数,又带 a 又带 h 的便是反双曲函数了。

在末了两段测试代码中,我们的数据涌现了 NAN 这种情形。
相信不少同学也会在开拓的过程中故意无意地见过这个类型。
NAN 是一种非常分外的类型,它本意代表的是 非数字 这个观点。
但它又不属于任何一种标量类型,而且两个 NAN 也不是相等的,其余 json_encode() 的时候也是不能有 NAN 这种类型的。
相信做过金融或者统计剖析干系系统的朋友一定对这个 NAN 深有体会。

var_dump(atanh(tan(M_PI_2)) == atanh(tan(M_PI_2))); // bool(false)var_dump(atanh(tan(M_PI_2)) === atanh(tan(M_PI_2))); // bool(false)var_dump(NAN == NAN); // bool(false)var_dump(NAN === NAN); // bool(false)$v = json_encode([ 'test'=>NAN]);echo $v, PHP_EOL; // echo json_last_error_msg(); // Inf and NaN cannot be JSON encodedbool(true)

是不是很诡异的一种数据类型,须要判断一个打算结果是不是 NAN 类型,只能利用 is_nan() 这个函数。

var_dump(is_nan(atanh(tan(M_PI_2)))); // bool(true)var_dump(is_nan(NAN)); // bool(true)进制转换

末了便是进制转换方面的运算了。
说实话,在口试的时候有人问过我如何进行二进制和十进制的转换,实在便是期望我手写转换的代码。
但是哥们直接写得是这几个进制转换的函数,口试官当时那个一脸黑线....

var_dump(bindec("11")); // int(3)var_dump(bindec("110011")); // int(51)var_dump(hexdec("FF")); // int(255)var_dump(hexdec("A37334")); // int(10711860)var_dump(octdec('77')); // int(63)

bindec() 二进制转十进制,hexdec() 十六进制转十进制,octdec() 八进制转十进制。

var_dump(decbin(51)); // string(6) "110011"var_dump(dechex(255)); // string(2) "ff"var_dump(decoct(63)); // string(2) "77"

单词换下位置,把 dec 都放到前面来,就变成了十进制转换到相应进制的函数了。
这些都比较大略,末了,还有一个可以进行任意进制转换的函数。

var_dump(base_convert("A37334", 16, 10)); // string(8) "10711860"var_dump(base_convert("A37334", 16, 2)); // string(24) "101000110111001100110100"

base_convert() 的意思便是将第一个参数的内容,由 第二个参数 的进制转换到 第三个参数 的进制。
比如这段测试代码,我们便是将 A37334 从 16进制 转换到 10进制 和 2进制 。

总结

本日的内容很丰富吧,数学打算干系的函数实在还有一些,不过并不是太常用这里也就没有多写了。
数学是打算机的根本,也是理工科所有专业的根本,打算机编程措辞中为我们供应的这些函数大家还是要灵巧节制的,特殊是在某些口试的场景下会非常有用。

测试代码:

https://github.com/zhangyue0503/dev-blog/blob/master/php/202012/source/9.数学干系函数在PHP中的运用简介.php

参考文档:

https://www.php.net/manual/zh/book.math.php

标签:

相关文章

介绍ILE网站,引领互联网时代的新潮流

随着互联网技术的飞速发展,越来越多的企业和个人开始关注到互联网营销的重要性。在我国,ILE网站作为一家专注于互联网营销领域的平台,...

网站建设 2024-12-05 阅读0 评论0