① 一次php内存溢出的解决及思考
这个报错在php报错司空见惯,就是memory_limti值超出了限制导致的报孝简老错,简单粗暴不负责任就是改php.ini设置,或者稍微好点就是init_set("memory_limit","2048M"),但是这两种都是治标不治本,没有从根本上解决这个报错,如果数据20万通过改memory_limit可以稍微控制,但是50万,100万咧这样巧升就是无限的咐轿扩大这个值导致服务器随时出现问题。
② php 的位运算总结
php的位运算很少会用到,但是用处很大,
在有些算法中会用到,在权限管理中也会经常用到,
对于理解计算机的世界也会有一定的帮助,所以得把这些重要但不常用的东西总结一下记录一下。
提到位运算,避不开的是二进制。
因为位运算是直接在内存做操作和运算,相较与直接拿两个变量做运算符肯定是更快的。
很多地方把二进制这玩意说得很晦涩,现在来以最简单的方式来总结一下,当然只算 int 范围内的数算了,超过了这个范畴程序员还不如拿这时间去学点别的。
说完以上总结,再来解释下什么是二进制,网上大把,
但只要记住,int范围内的数也就是我们大部分需要用到的数,都可以用二进制来表示。
我们生活中用到的计数方式为十进制,由个数位满10进1,
然后再开始重新计算,等十位满9再加一时,百位加一,十位归零。
二进制则只有两个数字来表示就是0和1,满2进1。
由32个位组成,虽然只有32个位但已满足了我们正常的需求了
比如说1转换为2进制原码,由于1是正数所以符号位为0,
原码反码补码都一个样。
1的原码:00000000 00000000 00000000 00000001
因手懒,太多0太丑用+拼接,Ɔ* 8'代表8个0
2的原码:0* 8 0* 8 0* 8 0* 6 + 1 0,既然是二进制,
满2就得进1,最低位归0,向前加一。
再来解释下负数的原码反码和补码,就开始讲php的位运算了。
二进制复习完毕。下面开始讲讲php的位运算。
php一共有六种位运算,一种一种来讲。
可以这么理解,两个数的补码放在一起比较每个位(一共32个位),
可以得出另外一个数,这个数字的组成由比较的两位数字生成,
如果两个数的每个位数上的数字都等于1的话,
那得到的那个数的补码的同位为1,否则为0。
听着绕口,其实很简单,觉得还是比官网上的更容易让新手看懂
下面举例子:
首先来求-1和7的补码。7的原码就是补码。
两个补码都有了下面开始运算:
按照上面的说法, 每个位都有一样则 $a 的同等位则为1,刚好-1的补码和7的补码前面都不一样,就最后三位一样,所以刚好求得的 $a 的补码的最后三位是1而其他的都是0 ,刚好这个补码为正数,正好就是7。
其实就是和按位与相反,只要有1个为1,那就为1,如果都不为1,那就为0。
$a = -1|7 ;得出来的 $a 补码为32个1,但此时不能说 $a 就是-1,因为这只是补码,要转成原码再转成十进制数,补码-1,然后再翻转,再转出来,得到的其实也还是-1。
就是将这个数的补码全部翻转过来,包括符号位,0变1,1变0
取反的结果一定是整数变负数负数变正数,取正数的反时,
记得一定要从补码一步步转到原码再转成十进制数才是答案。
两个数的补码比较,同等位上的两数比较
,不一样时,则答案的补码的同位则为1,否则为0。
往左移符号位被挤走右边0补充,往右移动,符号位不动,
高位以符号位补充。二进制世界里往左移动其实是相当于乘以了2,
右移相当于除以了2。
不吹牛逼的说,这应该是互联网上最容易理解的php位运算的解释和二进制的解释了。
原文链接: php的位运算总结-PHP
③ 求助:PHP内存溢出问题Fatal error:Out of memory
程序源指扒雹昌里面开始的时候加入:ini_set('memory_limit', '1024M');
或者你也可逗态以更改php.ini里面的配置.
默认内存是128m.
④ 位运算有溢出吗如何解决
当然有,0x80<<1就溢出了,溢出的值在程序状态字的最高位CY里面
⑤ php利用高阶函数消除递归,解决递归栈溢出问题
微信小程序推送服务通知需要收集足够的formid,使用过程中发现如果formid大量失效,在使用递归宏纳从redis从获取可用formid的时候会导致栈握拆溢出问题,下面方法是蔽皮没使用php的高阶函数来消除递归,完美解决问题,记录之:
<?php
class A
{
public static function factorial($n, $accumulator = 1) {
if ($n == 0) {
return $accumulator;
}
return function() use($n, $accumulator) {
return self::factorial($n - 1, $accumulator * $n);
};
}
public static function trampoline($params) {
$result = call_user_func_array('self::factorial', $params);
while (is_callable($result)) {
$result = $result();
}
return $result;
}
public static function run()
{
var_mp(self::trampoline(array(500)));
}
}
A::run();
⑥ PHP 如何在64位系统让32位的整型左移溢出
可以在64bit系统上把补码处理一下
×手上没装64bit的php所以用java的64bit的long模拟
publicclassTest{
publicstaticvoidmain(String[]args){
inta=83661<<15;
System.out.println("32bit:"+a);
longn=83661L<<15;
System.out.println("64bit:"+n);
if(n>0x7fffffffL){
n--;n=~n;n&=0x7fffffffL;n=-n;
}
System.out.println("64bit处理后:"+n);
}
}
32bit:-1553563648
64bit:2741403648
64bit处理后:-1553563648
如不想移植以上的,PHP还可以直接把数值pack()打包成32bit有符号,再按32bit有符号unpack()一次也能得到需要的负数,不过感觉这样效率不如以上直接计算快..
⑦ php 执行mysql中查询时内存溢出怎么办
使用mysql_unbuffered_query(), 可以避免内存的立即占用, 如果返回的结果存放到array中也是完全没有问题的, 也不会出现php查询mysql数据量过大时导致内存溢出问题.
这种情况一般会在单表数据表数据库比较大的时候出现,建议在使用的过程中限制单次读取数据条数,或者对数据表进行分表
⑧ phpExcel 输出Excel 内存溢出
phpExcel 输出Excel 内存溢出可以通过代码来设置不同的缓存方式,已达到降低内存消耗的目的。
工具:office Excel
步骤:
1、将单元格数据序列化后保存在内存中。
代码如下:
PHPExcel_CachedObjectStorageFactory::cache_in_memory_serialized;
2、将单元格序列化后再进行Gzip压缩,然后保存在内存中。
代码如下:
PHPExcel_CachedObjectStorageFactory::cache_in_memory_gzip;
3、缓存在临时的磁盘文件中,速度可能会慢一些。需要耐心等待一会儿。
代码如下:
PHPExcel_CachedObjectStorageFactory::cache_to_discISAM;
4、保存在php://temp。
代码如下:
PHPExcel_CachedObjectStorageFactory::cache_to_phpTemp;
5、保存在memcache中。
代码如下:
PHPExcel_CachedObjectStorageFactory::cache_to_memcache;
6、设置完成即可达到降低内存消耗的目的。
⑨ php内存溢出问题,求教大神!
你看看你的程序里面有没有用基基谈到递归,或者有没有死循环。
另外解决此类问题的主要思想就是分而治之
我觉得是foreach的机制的问题
foreach($arr as $key=>$value){}这里面的$value是每次循环是把数组中元素的值赋值给$value
而foreach($arr as $key=>&$value){}这里的$value是引用赋值。
两者有什么区别呢?带引用的$value可以$value='aaa';直接改变元素的值;还有一个重要的,就是最后一次循环之后$value的值还会保留;
你这里是foreach($obj as $value){}对象默认是搏碰引用传值;所以循环过后要unset($obj);
php里还有一个函数clearstatcache(true)清楚文件状态缓存,虽然受影响的函数没有simplexml_load_file(),不过还是可以试试;
还有mysql系列的函数很多也不是很稳定,有时候不知道会出什么问题;建议用PDO;
深锋尺感php里面的坑太多了,稍不注意就跳进去了。
⑩ php位运算
PHP只有编译的时候能在make configure参数里面设置嫌并整型是32 还是64bit。
win的64bit版的php也是32bit整型,和linux不同。
linux下64bit版的PHP就是64bit整型,只有这种特铅者明殊情况。
64bit整型需要多对位运算环节中的
每次超32bit情况进行溢出舍去的处理。。处理后的槐告算法是可以32/64通用的