- 论坛徽章:
- 0
|
特性7,动态创建函数
<?php
// lambda函数
$newfunc = create_function('$a,$b', 'return "$a + $b = " . $a + $b;'); // 创建了一个匿名函数
print "\nNew anonymous function: $newfunc\n";
print $newfunc(2, 4);
print "\n";
// 效果类似于
function test($a,$b){
return "$a + $b = " . $a + $b;
}
print test(2, 4);
?>
特性8、自动加载对象
可以定义一个 __autoload 函数,它会在试图使用尚未被定义的类时自动调用。
<?php
// ClassA.php, 这段代码写在ClassA.php
class A {
function __construct() {
print 'yeah!';
}
}
?>
<?php
function __autoload($className) {
require_once $className . '.php';
}
// 这段代码写在b.php
new A(); // 程序运行到这里的时候,A类未定义,将自动调用__autoload()函数
?>
特性9、__get和__set代替所有对属性变量数组的访问
<?php
class Setter{
public $n;
private $x = array("a" => 1, "b" => 2, "c" => 3);
private function __get($nm) {
echo "Getting [$nm]\n";
if (isset($this->x[$nm])) {
$r = $this->x[$nm];
print "Returning: $r\n";
return $r;
} else {
echo "Nothing!\n";
}
}
private function __set($nm, $val) {
echo "Setting [$nm] to $val\n";
if (isset($this->x[$nm])) {
$this->x[$nm] = $val;
echo "OK!\n";
} else {
echo "Not OK!\n";
}
}
private function __isset($nm) {
echo "Checking if $nm is set\n";
return isset($this->x[$nm]);
}
private function __unset($nm) {
echo "Unsetting $nm\n";
unset($this->x[$nm]);
}
}
$foo = new Setter();
$foo->n = 1;
$foo->a = 100;
$foo->a++;
$foo->z++;
var_dump(isset($foo->a)); //true
unset($foo->a);
var_dump(isset($foo->a)); //false
// this doesn't pass through the __isset() method
// because 'n' is a public property
var_dump(isset($foo->n));
var_dump($foo);
?>
特性10、自定义未定义的方法
你调用未定义方法时,方法名和方法接收的参数将会传给__call方法
<?php
class Caller {
private $x = array(1, 2, 3);
private function __call($m, $a) {
print "Method $m called:\n";
print_r($a);
return $this->x;
}
}
$foo = new Caller();
$a = $foo->test(1, "2", 3.4, true);
print_r($a);
?>
特性11、自定义错误、异常处理
设置使用自定义错误或异常处理函数后,当发生错误或异常时将调用自定义的处理函数代替系统错误处理函数。
<?php
set_error_handler('error_handler'); // 设置错误时调用的自定义处理错误函数,设置自定义异常处理函数为set_exception_handler()
print $a/0; // 这里逻辑错了,调用error_handler()报错
function error_handler($errno, $message, $filename, $line) {
if ($errno & (E_ALL ^ E_NOTICE)) {
$types = array(
1 => 'error',
2 => 'warning',
4 => 'parse error',
8 => 'notice',
16 => 'core error',
32 => 'core warning',
64 => 'compile error',
128 => 'compile warning',
256 => 'user error',
512 => 'user warning',
1024 => 'user notice',
2048 => 'strict warning'
);
print "\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n";
print $types[$errno] .': '. $message .' in '. $filename .' on line '. $line .'.';
print "\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n";
exit;
}
}
?>
特性12、高可配置性
可修改范围为
PHP_INI_USER 的 配置选项可在用户的PHP脚本或Windows注册表中设置
PHP_INI_PERDIR 的 配置选项可在 php.ini, .htaccess 或 httpd.conf 中设置
PHP_INI_SYSTEM 的 配置选项可在 php.ini or httpd.conf 中设置
PHP_INI_ALL 的 配置选项可在各处设置
我们要熟悉在php.ini中修改php的配置,还会经常在php脚本中修改脚本中可修改的配置项。
可以使用 ini_set()函数或专门修改运行时配置的函数来改变可修改范围为PHP_INI_ALL
<?php
// 修改php的配置参数
ini_set('session.save_path', 'D:/temp'); // 修改配置让脚本把session文件保存到D:/temp目录
?>
特性13、代码中执行php脚本
<?php
$s = '$a = "xxxxxxxxxx"; if($a) { print $a;}';
eval($s);
[ 本帖最后由 lib 于 2008-10-18 23:36 编辑 ] |
|