本文目录一览:
- 1、php获取结果集的几个方法
- 2、php 函数运行完了 不就释放了吗,还要等脚本结束
- 3、关于php中释放资源mysql_free_result函数,释放资源是什么意思,是不是把mysql_query结果集中的值清空?
- 4、Thinkphp 是否需要手动释放结果集?
- 5、PHP管理内存函数 memory_get_usage()使用介绍
php获取结果集的几个方法
php获取查询结果集有4个函数方法,此处对它们进行综合比较。
● mysql_result():优点在于使用方便;而缺点在于功能少,一次调用只能获取结果数据集中的一行记录,对较大型的数据库效率较低。
● mysql_fetch_row():优点在于执行效率在4种方法中最高;不足在于只能用数字作为属性索引来获得属性值,在使用时非常容易出现混淆。
● mysql_fetch_array():执行效率同样很高,同mysql_fetch_row()相差无几,并且可以用属性名方式直接获取得属性值,因此,在实际应用中最常用。
● mysql_fetch_object():采用了面向对象的思想,在设计思路上更为先进,如果读者习惯于面向对象的思路来写程序,则会很自然的选择它。其次,该方法的优点还体现在,对于结构较为复杂的数据结果,在逻辑上显得更为清晰。
php 函数运行完了 不就释放了吗,还要等脚本结束
首先说下,题主这个问题不是函数释放的问题
问题在于 require_once
第一次:在get_config内 第一次 引入 conf.php 赋值给 $conf , 此时 $conf 得到期望 数组 ,没有任何问题。
(注:此时已经在本次运行环境中引入了conf.php)
第二次:在get_config内再次尝试引入 conf.php 此时 require_once 会检测到运行环境中已经引入了该文件,此时返回值为 true 对 true 进行取值 肯定是 null
题主正确的做法是把 require_once 放入全局GLOBALS内,在 get_config 内引入全局变量即可。
修改后的代码:
a.php
$GLOBALS['conf'] = require_once 'conf.php';
function get_config($key, $default = null){
return isset($GLOBALS['conf'][$key])
? $GLOBALS['conf'][$key]
: $default;
}
var_dump(get_Config('name'));
var_dump(get_Config('age'));
--- 共有 1 条评论 ---
hphper(注:此时已经在本次运行环境中引入了conf.php) 这句话,这个引入是在函数里引入,函数执行完了后在这个运行环境里有引入吗,如果在这个运行文件里有引入,那么我直接打印 conf.php里的$config应该有值,但是没有 也就是说在全局里并没有引入 那么就只在函数里引入了,为什么第一次的函数执行 会对第二次的执行有影响呢 (3年前)
评论(1)| 引用此答案| 举报 (2014-06-14 13:12)
梁上有木梁上有木 3年前
题主这个config的格式不需要把引入的文件赋值,只需要require_once就可以了
a.php
1 function get_config($key){
2 require_once 'conf.php';
3 return $conf[$key];
4 }
5 echo get_Config('name');
6
7 echo get_Config('age');
conf.php
1 $config=array(
2 'name'='hk',
3 'age'='22'
5 );
评论(0)| 引用此答案| 举报 (2014-06-14 15:34)
hphperhphper 3年前
引用来自“梁上有木”的评论
题主这个config的格式不需要把引入的文件赋值,只需要require_once就可以了
a.php
1 function get_config($key){
2 require_once 'conf.php';
3 return $conf[$key];
4 }
5 echo get_Config('name');
6
7 echo get_Config('age');
conf.php
1 $config=array(
2 'name'='hk',
3 'age'='22'
5 );
function get_config($key){
require_once 'conf.php';
return $conf[$key];
}
里$conf是啥,
是a.php里的 $config吧
就算是
第二次调用 也是不行的
评论(0)| 引用此答案| 举报 (2014-06-14 16:46)
TuesdayTuesday 3年前
终于明白为什么php 的排名日落千丈了.
--- 共有 1 条评论 ---
hphper是我这样的小白 多了是吗? (3年前)
评论(1)| 引用此答案| 举报 (2014-06-14 18:43)
南湖船老大南湖船老大 3年前
各种乱入,各种小白啊,贵圈太乱了。。。
都是想当然地写代码。。。require_once 你赋值干嘛。。。而且你这种写法很粗糙,也很dirty,你造吗?
推荐写法:
$config = call_user_func(function() {
return include 'config.php';
});
--- 共有 3 条评论 ---
南湖船老大回复 @hphper : 变量可能被污染,用匿名函数和闭包就避免了这种情况 (3年前)
hphper为什么粗糙,dirty了,怎么判断粗糙不粗糙呢 (3年前)
hphper哦,看来进步空间还很大啊 (3年前)
评论(3)| 引用此答案| 举报 (2014-06-14 19:46)
hphperhphper 3年前
引用来自“D哥”的评论
首先说下,题主这个问题不是函数释放的问题
问题在于 require_once
第一次:在get_config内 第一次 引入 conf.php 赋值给 $conf , 此时 $conf 得到期望 数组 ,没有任何问题。
(注:此时已经在本次运行环境中引入了conf.php)
第二次:在get_config内再次尝试引入 conf.php 此时 require_once 会检测到运行环境中已经引入了该文件,此时返回值为 true 对 true 进行取值 肯定是 null
题主正确的做法是把 require_once 放入全局GLOBALS内,在 get_config 内引入全局变量即可。
修改后的代码:
a.php
$GLOBALS['conf'] = require_once 'conf.php';
function get_config($key, $default = null){
return isset($GLOBALS['conf'][$key])
? $GLOBALS['conf'][$key]
: $default;
}
var_dump(get_Config('name'));
var_dump(get_Config('age'));
谢谢!,我在函数里用静态变量也可以,您这也是一种方法
我仍不理解的是:第二次 执行时,既然它已经检测到 已经引入了该文件,那我直接用conf.php 里的 $config为啥也不行啊
我最不明白的是 函数里的 require_once 对正在执行这个函数的文件的影响,下次再require_once的时候 为啥受上一次函数的影响
关于php中释放资源mysql_free_result函数,释放资源是什么意思,是不是把mysql_query结果集中的值清空?
mysql查询结果句柄会消耗内存。为了节约内存,在使用完毕后可以手动释放。不过一般情况下不需要这么做,程序结束会自动释放的。
这里的$pageCount变量存在。因为释放mysql句柄$res和$pageCount无关。
以下方法可以释放$pageCount:
unset($pageCount);
望采纳,谢谢支持!
Thinkphp 是否需要手动释放结果集?
不需要手动释放,当执行完这个页面的脚本后,$res这个变量会自动销毁,数据库连接会在语句执行完成后断开。
例如,在任一控制器的任一方法内写入下列代码
if(I("get.a")){
$a = I("get.a");
dump($a);
}else{
dump($a);
}
第一次打开这个页面时加上a=1的参数,会输出1,然后把参数去掉,会输出空或未定义的变量。
PHP管理内存函数 memory_get_usage()使用介绍
下面是PHP
memory_get_usage()使用示例:
复制代码
代码如下:
echo
memory_get_usage(),
'br
/';
//143952
$tmp
=
str_repeat('',
4000);
echo
memory_get_usage(),
'br
/';
//232048
unset($tmp);
echo
memory_get_usage();
//143952
上面的程序后面的注释代表了它们的输出(单位为
byte(s)),也就是当时
PHP
脚本使用的内存(不含
memory_get_usage()
函数本身占用的内存)
由上面的例子可以看出,要想减少内存的占用,可以使用
PHP
unset()
函数把不再需要使用的变量删除。类似的还有:PHP
mysql_free_result()
函数,可以清空不再需要的查询数据库得到的结果集,这样也能得到更多可用内存。
PHP
memory_get_usage()还可以有个参数,$real_usage,其值为布尔值。默认为
FALSE,表示得到的内存使用量不包括该函数(PHP
内存管理器)占用的内存;当设置为
TRUE
时,得到的内存为包括该函数(PHP
内存管理器)占用的内存。
所以在实际编程中,可以用PHP
memory_get_usage()比较各个方法占用内存的高低,来选择使用哪种占用内存小的方法。
常用的检测:
用microtime函数就可以分析程序执行时间
memory_get_usage可以分析内存占用空间
SQL的效率可以使用打开慢查询查看日志分析
SQL
找到有瓶颈的使用EXPLAIN
来分析