php Allowed memory size of 8388608 bytes exhausted (tried to allocate 46080 bytes) in....
php.ini这个参数memory_limit引起的,因为对它的设置不够在所以引起了上在的问题,下面我们来看看几种解决方法
方法一,用程序来实现
在你的php代码中增加以下命令行即可
代码如下 | 复制代码 |
ini_set('memory_limit','128M'); |
这种需要你的服务器未禁止修改,一般的虚拟空间是不可以操作的。
方法二,利用.htaccess 来做,这种可行性超高。
在你的.htaccess里加入
代码如下 | 复制代码 |
php_value memory_limit 128M ; |
可以将128M改为任何你想设置的值 就可以了。
方法三,这要针对有服务器管理权限的朋友了,直接修改php.ini文件了。
找到“memory_limit”这一项,如果没有,你可以在文件的尾部自己增加这个参数。以下是一些设置范例
代码如下 | 复制代码 |
memory_limit = 128M ; |
可以将128M改为任何你想设置的值
重启apache就可以了。
这样我再运行那产品不没会出现前面讲到的Allowed memory size of 8388608 bytes exhausted (tried to allocate 46080 bytes) in....了,。
引用文件的方法有两种:require 及 include。两种方式提供不同的使用弹性。require 的使用方法如 require("MyRequireFile.php"); 。这个函数通常放在 PHP 程序的最前面,PHP 程序在执行前,就会先读入 require 所指定引入的文件,使它变成 PHP 程序网页的一部份。常用的函数,亦可以这个方法将它引入网页中。
include()与require()的功能也基本相同(包含),但在用法上也有一些不同,include()是有条件包含函数,而require()则是无条件包含函数。例如在下面代码中,如果变量$a为真,则将包含文件a.php:
代码如下 | 复制代码 |
if($a){ |
include 使用方法如 include("MyIncludeFile.php"); 。这个函数一般是放在流程控制的处理部分中。PHP 程序网页在读到 include 的文件时,才将它读进来。这种方式,可以把程序执行时的流程简单化。
而require()则和include()不同,不管$a取何值,下面的代码将把文件a.php包含进文件里:
代码如下 | 复制代码 |
if($a){ |
在错误处理方面,使用include语句,如果发生包含错误,程序将跳过include语句,虽然会显示错误信息但是程序还是会继续执行!但requre却会给你来个致命错误。
报错
用例子来说话,写两个php文件,名字为test1.php 和test2.php,注意相同的目录中,不要存在一个名字是test999.php的文件。
代码如下 | 复制代码 |
test.php test2.php |
浏览第一个文件,因为没有找到test999.php文件,我们看到了报错信息,同时,报错信息的下边显示了abc,你看到的可能是类似下边的情况:
Warning: include(test1aaa.php) [function.include]: failed to open stream: No such file or directory in D:WebSitetest.php on line 2
Warning: include() [function.include]: Failed opening ‘test1aaa.php’ for inclusion (include_path=’.;C:php5pear’) in D:WebSitetest.php on line 2
abc
浏览第二个文件,因为没有找到test999.php文件,我们看到了报错信息,但是,报错信息的下边没有显示abc,你看到的可能是类似下边的情况:
Warning: require(test1aaa.php) [function.require]: failed to open stream: No such file or directory in D:WebSitetest.php on line 2
Fatal error: require() [function.require]: Failed opening required ‘test1aaa.php’ (include_path=’.;C:php5pear’) in D:WebSitetest.php on line 2
我们介绍关于php中数组的操作,删除数组中指定值或判断数组中是否有值或清除空值操作,有需要的同学可以参考一下。首先我们来看看关于php如何操作数组中的空值的多种方法
implode(); 此函数可参考http://www.111cn.net/phper/29/2dc95be9381b4bb1753083c09fda1a36.htm
用implode()将数组输出为字符串,判断输出的字串是否为空。初看上去似乎是个不错的方法,可惜跟上一点一样,对于二维以上数组就不行了。举个例子:
代码如下 | 复制代码 |
$arr= array(array(),array(),array()); if(empty($str)) echo "空"; |
很明显$arr是个含有三个空数组的二维数组,应该也算是空的,可是输出的确是非空。判断失败。
三、count(); 可参考http://www.111cn.net/w3school/php/func_array_count.htm
代码如下 | 复制代码 |
$arr= array("","",""); |
四、in_array('', $arr)); 函数用法可参考http://www.111cn.net/phper/24/c5b81a8af14b1c0928eea343f59b454a.htm
代码如下 | 复制代码 |
$arr= array("d","s",""); echo in_array('', $arr); |
这个只能说明数组中有空的元素,不能证明数组是空的。很明显也不行。
五、empty(); 函数用法可参考http://www.111cn.net/so/php+empty()
这个cpyeh觉得跟前面几种方法差不多
代码如下 | 复制代码 |
$arr= array("","",""); |
结果还是非空
六、用strlen(),没内容的话好象长度都为1
结合上面实例我们写一个完整的删除数组空值的元素
代码如下 | 复制代码 |
function array_remove_key($array, $keys) |
代码如下 | 复制代码 |
include("cn.php"); //数据库连接类,这里不说了自己去找找吧。 $Db = new Db(); $sql ="select * from 表名 where isnew=1"; $query = $Db->query( $sql ); $rs = $Db->fetch( $query ,0); $i=10000; foreach( $rs as $v => $vv ) { if( substr($i,-1)==4 ) { $i++; } $sql ="update 表名 set txtiphone= '$i' where id=".$vv['id']; if( $Db->query( $sql ) ) { $i++; } } echo '批量更新完成'; |
关于substr()函数
语法
substr(string,start,length)
参数 | 描述 |
---|---|
string | 必需。规定要返回其中一部分的字符串。 |
start |
必需。规定在字符串的何处开始。
|
length |
可选。规定要返回的字符串长度。默认是直到字符串的结尾。
|
本站原创教程转载注明来源: http://www.111cn.net/phper/php.html
文章利用了大量的实现来介绍关于 单引号和双引号的用法与区别,有需要了解的同学可以仔细的参考一下本文章哦。在PHP中,通常一个字符串被定义在一对引号中
按照下面的方法操作:
代码如下 | 复制代码 |
$out = str_replace(array('rn', 'r', 'n'), '', $out);PHP 提供三种定义字符串的方法:单引号、双引号、本地文档(英文叫做 here document 或者 heredoc)。 |
单引号:
使用单引号是最高效的方法,因为 PHP 不会检查单引号字符串中的内置变量和转义序列,需要转义的字符只有反斜杠和单引号本身。
双引号:
会检查内置变量和转义序列,但不能识别转义的单引号。这也正说明了开始那段代码的错误之处,正确的做法是使用双引号来定义换行的转义序列:
代码如下 | 复制代码 |
$out = str_replace(array("rn", "r", "n"), '', $out); |
本地文档:
检查所有的内置变量和转义序列,双引号无需转义。例如:
代码如下 | 复制代码 |
echo <<<EOT this is a "here document" example. just for test. |
EOT;简单记录下,加深印象。
,如:
代码如下 | 复制代码 |
'I am a string in single quotes' |
PHP语法分析器是用成对的引号来判断一个字符串的。因此,所有字符串必须使用同一种单或者双
引号来定义开始和结束。例如,下面的字串定义是不合法的:
代码如下 | 复制代码 |
"I am not a valid string since I have unmatching quote marks' |
定义字符串时,只有一种引号被视为定义符,即单引号或双引号。于是,如果一个字符串由双引
号开始,那么只有双引号被分析器解析。这样,你就可以在双引号串中包含任何其他字符,甚至单引
号。下面的引号串都是合法的:
代码如下 | 复制代码 |
$s = "I am a 'single quote string' inside a double quote string"; 当PHP遇到与串的开头相对应的引号时,便认为已经到了字符串尾部,于是: "Why doesn't "this" work?" 实际上被PHP语法分析器分成三个部分: "Why doesn't "——包含一个单引号的双引号串 |
上面的这个例子企图在双引号串中包含双引号,而分析器在遇到第二个双引号时便认为字符串结
束了。要达到包含引号的目的,必须分析器在遇到串内普通引号的时候忽略它的原意,我们在引号的
前面加上一个反斜杠来告诉PHP:这个引号是字符串的一部分,正确的表示方法是这样:
代码如下 | 复制代码 |
"Why doesn't "that" work?" |
在英文字符串中一个常见的问题是撇号'的使用,因为它就是一个单引号,而在英文串中十分常见
(英文所有格)。你必须小心处理这些字符:
代码如下 | 复制代码 |
'You'd better escape your apostrophes' |
可以看到反斜杠在字符串中有他的特殊含义,当我们需要在字符串中包含反斜杠本身时,需要在
该符号前面多加一个反斜杠。例如:
代码如下 | 复制代码 |
$file = "c:windowssystem.ini"; |
另一种字符串定义方式,能够消除特殊字符的烦恼,而且便于引用较长的文本。该字符串定义方
法以<<<符号紧跟一个自定义字符串开头,最后一行以该自定义字符串结束,并且必须顶格。
二、字串的连接
字串可以使用字串连接符(.)来连接,如:
代码如下 | 复制代码 |
$first_name = 'Charlie'; |
常见的用途是建立大块的HTML字串代码,赋值号 (=) 连接符 (.) 可以被简写合并为 (.=) 符
号,如:
代码如下 | 复制代码 |
$html = '<table>'; |
三、在字串中使用变量
这个功能让你无须使用连接符号来粘和大量的简单字符串。PHP允许我们在双引号串中直接包含字
串变量,我们可以发现下面的两个字串的处理结果是相同的。
代码如下 | 复制代码 |
$full_name = $first_name . ' ' . $last_name; |
单引号串和双引号串在PHP中的处理是不相同的。双引号串中的内容可以被解释而且替换,而单引
号串中的内容总被认为是普通字符。例如:
代码如下 | 复制代码 |
$foo = 2; |
正如你所看到的,在单引号串中甚至反斜杠也失去了他的扩展含义(除了插入反斜杠\和插入单 引号')。所以,当你想在字串中进行变量代换和包含n(换行符)等转义序列时,你应该使用双引
号。单引号串可以用在其他任何地方,脚本中使用单引号串处理速度会更快些,因为PHP语法分析器对
单引号串的处理方式比较单纯,而双引号的处理由于串内部也需要解析,因此更复杂些,所以处理速
度略慢。
在字符串中引用复杂的变量组合时,可能会产生一些问题,下面的代码会正常工作:
代码如下 | 复制代码 |
echo "value = $foo"; |
而下面的代码却不能得到我们希望的结果:
代码如下 | 复制代码 |
echo "value = $a[$i][$j]"; //我们希望打印二维数组$a的某个元素。 |
为避免这些字串使用中的潜在问题,我们通常把复杂的变量从字串中分离开来,就像这样:
代码如下 | 复制代码 |
echo 'value = ' . $a[$i][$j]; |
还有一种办法是将复杂变量用花括号括起来,语法分析器就能正确辨认了:
代码如下 | 复制代码 |
echo "value = {$a[$i][$j]}" //打印二维数组$a的某个元素 |
这样,又出现新问题了。当我们想在字串中引用花括号字符本身时,就要记得使用转义符了:
代码如下 | 复制代码 |
$var = 3; |
三、斜杠和SQL语句
生成HTML代码或SQL查询语句是编写PHP程序时经常遇到而且是件有趣的事情。为什么这么说呢,
因为这涉及到生成另外一种类型的代码,你必须仔细地考虑和遵循这种代码所要求的编写语法和规
则。
我们来看这样一个例子,假如你想查询数据库中名字是“O'Keefe”的用户,通常SQL语句的形式
是这样的:
代码如下 | 复制代码 |
select * from users where last_name = 'O'Keefe' |
请注意SQL语句这个英文所有格(撇号)需使用反斜杠转义。PHP专门提供了一些函数来处理这样
的情况,函数AddSlashes($str)的用途就是自动在字串中对引号字符插入反斜杠转义符:
代码如下 | 复制代码 |
$last_name = "O'Keefe"; |
在这个例子中,你还要在last_name字串外面括上单引号(SQL语法要求),由于这里使用的是双
引号串,所以对这对单引号就无须使用转义了。下面的这个语句是使用单引号串的等价形式:
代码如下 | 复制代码 |
$sql = 'select * from users where last_name = '' . addslashes($last_name) . '''; |
任何时候你要在数据库中写入字串,你都必须确保里面的引号正确使用了转义符号,这是很多PHP
初学者常犯的错误。
四、双引号和HTML
与SQL语句不同,在标准HTML语言中双引号常被用来表示字串(现在很多浏览器具备较强的容错功
能,允许在HTML中用单引号甚至不用引号表示字符串),例如:
代码如下 | 复制代码 |
$html = '<a href="'.$url.'">'.$link.'</a>'; |
HTML语言不支持反斜杠转义,这一点在我们使用表单的hidden inputs来传输数据的时候就会有所
体会了。设置hidden inputs的值的最好办法,是使用htmlspecialchars()函数来编码。下面的语句可
以正常传输一个可能包含双引号的数据:
代码如下 | 复制代码 |
<input type=hidden name=var value="<?php echo htmlspecialchars($var) ?>"> |
一、引号定义字符串。要达到包含引号的目的, 必须分析器在遇到串内普通引号的时候忽略它的原意,我们在引号的 前面加上一个反斜杠来告诉PHP:这个引号是字符串的一部分,正确的表示方法是这样:单引号串可以用在其他任何地方,脚本中使用单引号串处理速度会更快些,因为PHP语法分析器对 单引号串的处理方式比较单纯,而双引号的处理由于串内部也需要解析,因此更复杂些,所以处理速 度略慢。
这个...双引号转义,单引号不转义
如:/r/n是换行,但是如果你用单引号写入文件,不会是换行,而是一个字符,如果用双引号写入文件,就是换行.
最后看看其它网站的说法
” ” 双引号里面的字段会经过编译器解释,然后再当作HTML代码输出。
‘ ‘ 单引号里面的不进行解释,直接输出。
从字面意思上就可以看出,单引号比双引号要快了。
例如:
代码如下 | 复制代码 |
$abc=’my name is tome’; echo $abc //结果是:my name is tom echo ‘$abc’ //结果是:$abc echo “$abc” //结果是:my name is tom |
特别在使用MYSQL语句的时候,双引号和单引号的用法让新手不知所措,在这里,举个例子,来进行说明。
假设查询条件中使用的是常量,例如:
代码如下 | 复制代码 |
select * from abc_table where user_name=’abc’; |
SQL语句可以写成:
代码如下 | 复制代码 |
SQLstr = “select * from abc_table where user _name= ‘abc’” ; |
假设查询条件中使用的是变量,例如:
代码如下 | 复制代码 |
$user_name = $_REQUEST['user_name']; //字符串变量 |
或
代码如下 | 复制代码 |
$user=array (”name”=> $_REQUEST['user_name‘,"age"=>$_REQUEST['age'];//数组变量 |
SQL语句就可以写成:
代码如下 | 复制代码 |
SQLstr = “select * from abc_table where user_name = ‘ ” . $user_name . ” ‘ “; SQLstr = “select * from abc_table where user_name = ‘ ” . $user["name"] . ” ‘ “; |
对比一下:
代码如下 | 复制代码 |
SQLstr=”select * from abc_table where user_name = ‘ abc ‘ ” ; SQLstr=”select * from abc_table where user_name =’ ” . $user _name . ” ‘ “; SQLstr=”select * from abc_table where user_name =’ ” . $user["name"] . ” ‘ “; |
SQLstr可以分解为以下3个部分:
代码如下 | 复制代码 |
1:”select * from table where user_name = ‘ ” //固定SQL语句 2:$user //变量 3:” ‘ ” 1,2,3部分字符串之间用”.” |
相关文章
- memory_limit是php.ini中的一个比较重要的参数了,它可以限制你php进行最大使用内存的情况,如果小了会导致运行时提示Fatal Error: Allowed memory size of xxxxxx bytes...2016-11-25
- 这篇文章主要给大家介绍了关于JS如何监听div的resize事件的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-04
Nginx反向代理proxy_cache_path directive is not allowed错误解决方法
这篇文章主要介绍了Nginx反向代理proxy_cache_path directive is not allowed错误解决方法,需要的朋友可以参考下...2016-01-27Fatal error: Out of memory (allocated 786432)提示解决办法
今天在运行phpmyadmin时页面突然出现了Fatal error: Out of memory (allocated 786432)提示,看英文的意思是说超过了指定内存大小了,下面我来介绍解决办法 错误提...2016-11-25解决php curl获取网页内容提示405 method not allowed状态码
在使用php curl获取网页内容有些网站提示405 method not allowed状态码了,这个问题我分析了出问题的网站是因为ipv6而导致了,所以我们只要简单的调整一下就可以解决这个...2016-11-25- 这篇文章主要介绍了优化mysql之key_buffer_size设置的相关资料,需要的朋友可以参考下...2016-06-12
关于Pytorch MaxUnpool2d中size操作方式
今天小编就为大家分享一篇关于Pytorch MaxUnpool2d中size操作方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-30- size()函数用来获取矩阵的行数和列数。接下来通过本文给大家介绍matlab中size()函数的用法,需要的朋友一起学习吧...2016-03-22
OnSize、OnSizing和OnGetMinMaxInfo区别分析
这篇文章主要介绍了OnSize、OnSizing和OnGetMinMaxInfo区别分析,需要的朋友可以参考下...2020-04-25php错误Fatal error: Out of memory (allocated 262144)
昨天网站用着用着就提示了Fatal error: Out of memory (allocated 262144),后来百度搜索了一些解决方法,下面我分享给各位朋友。 从上面的Out of memory (allocate...2016-11-25Pytorch GPU显存充足却显示out of memory的解决方式
今天小编就为大家分享一篇Pytorch GPU显存充足却显示out of memory的解决方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-27mysql优化的重要参数 key_buffer_size table_cache
MySQL服务器端的参数有很多,但是对于大多数初学者来说,众多的参数往往使得我们不知所措,但是哪些参数是需要我们调整的,哪些对服务器的性能影响最大呢...2016-06-12php Allowed memory size of 8388608 bytes exhausted (tried to allocate 46080 bytes) in....
今天在用一个php产品时出现了Allowed memory size of 8388608 bytes exhausted (tried to allocate 46080 bytes) in....提示信息,经过查核是因为此产品未考虑到用户内...2016-11-25- 很多朋友都会问mysql read_buffer_size 设置多少合适,其实这个都是根据自己的内存大小等来设置的...2016-05-20
- 今天我的新一台服务器安装了php环境但在在运行时提示Fatal Error: Allowed memory size of xxxxxx bytes exhausted了,是内存不足呀,下面我来介绍解决些问题的几种办法。...2016-11-25
Mysql 报Row size too large 65535 的原因及解决方法
这篇文章主要介绍了Mysql 报Row size too large 65535 的原因及解决方法 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下...2016-06-24Fatal error: Allowed memory size of 134217728 bytes exhauste
在运行dedecms是有些朋友会发现有些页面会提示Fatal error: Allowed memory size of 134217728 bytes exhauste错误了,下面我们一起来看看解决此问题办法。...2016-11-25Composer PHP Fatal error:Allowed memory size of
在使用composer update时遇到的,详细的错误消息Composer PHP Fatal error:Allowed memory size of 536870912 bytes exhausted了,下面来一起看问题解决办法 今天...2016-11-25- 这篇文章主要介绍了mysql tmp_table_size优化问题,很多朋友都会问tmp_table_size设置多大合适,其实既然你都搜索到这篇文章了,一般大于64M比较好,当然你也可以可以根据自己的机器内容配置增加,一般64位的系统能充分利用大内存...2016-06-12
SQL Server误设置max server memory的处理方法
这篇文章主要给大家介绍了关于SQL Server误设置max server memory的处理方法,文中通过示例代码介绍的非常详细,对大家学习或者使用SQL Server具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧下...2020-07-11