作者:mobiledu2502911637 | 来源:互联网 | 2013-06-21 11:58
1.请对POSIX风格和兼容Perl风格两种正则表达式的主要函数进行类比说明
ereg preg_match/ereg_replace preg_replace
ereg preg_match较之ereg_replace preg_replace速度要慢
ereg_replace preg_replace支持POSIX风格不支持的语法,如非贪婪匹配,断言,
条件子模式等。
POSIX风格和Perl兼容风格的正则表达式写法各有特点,不是完全一致。BRE/ERE
2.请说明在php.ini中safe_mode开启之后对于PHP系统函数的影响
启用了PHP的安全模式后:
有一些函数会被屏蔽,如dl() 、shell_exec()等。
一些函数在执行时会检查被操作的文件或者目录与正在执行的脚本是否有相同的UID, 在safe_mode_gid设置的情况下会放宽到检查GID
safe_mode_include_dir设置的目录及其子目录(目录必须在 include_path 中或者用完整路径来包含)包含文件时越过 UID/GID 检查。
指定的限制实际上是一个前缀,而非一个目录名。这也就是说“safe_mode_include_dir = /dir/incl”将允许访问“/dir/include”和“/dir/incls”,如果它们存在的话。如果希望将访问控制在一个指定的目录,那么请在结尾加上一个斜线,例如:“safe_mode_include_dir = /dir/incl/”。
有些函数只能在safe_mode_exec_dir设置的目录下执行操作如exec()、system()、passthru()、popen()
有些函数不在起作用如set_time_limit()、max_execution_time
3.PHP5中魔术方法函数有哪几个,请举例说明各自的用法
__sleep 在serialize()序列化对象之前会调用这个函数
__wakeup 在unserialize()解序列化之前调用这个函数
__toString 当将对象转化为字串的时候调用这个函数
__construct 构造函数,实例化一个对象的时候调用
__destruct 析构函数,当对象实力被释放的时候调用
__call, 当调用类中没有的方法时会调用此函数
__get, 当访问一个类中没有的属性时调用
__set, 当设置一个类中没有的属性的值时调用
__isset, 调用外部的isset函数检查类是否有某个属性时调用
__unset , 删除类的某个属性时调用
__set_state, 使用var_export导出对象的属性和值时调用
__clone 复制某个类的实例时调用
__autoload 当使用一个类而这个类还未被加载时会被自定调用
4.请写出让,并说明如何在命令行下运行PHP脚本(写出两种方式)同时向PHP脚本传递参数?
php –f 脚本的路径 执行时的参数
在PHP的脚本中第一行加上#!/usr/bin/php,并将脚本权限设置为可执行
./脚本名称 –参数
5.PHP的垃圾收集机制是怎样的
好像是采用引用计数吧,当一个变量被初始化或者赋值给另一个变量时引用计数会加1,当变量或者被赋值的变量被销毁或者被侦测到无用时引用计数会减一,当垃圾收集的进程运行时会释放掉引用计数为0的那些变量会被从内存中释放(垃圾回收期间程序会被中断)。当脚本执行完成时所有资源都会被释放。
6.使对象可以像数组一样进行foreach循环,要求属性必须是私有。
(Iterator模式的PHP5实现,写一类实现Iterator接口)
7.请写一段PHP代码,确保多个进程同时写入同一个文件成功
8. 用PHP实现一个双向队列
9. 使用正则表达式提取一段标识语言(html或xml)代码段中指定标签的指定属性值(需考虑属性值对不规则的情况,如大小写不敏感,属性名值与等号间有空格等)。此处假设需提取test标签的attr属性值,请自行构建包含该标签的串
10.请使用socket相关函数(非curl)实现如下功能:构造一个post请求,发送到指定http server的指定端口的指定请求路径(如http://www.example.com:8080/test)。请求中包含以下变量:
用户名(username):温柔一刀
密码(pwd):&123=321&321=123&
个人简介(intro):Hello world!
且该http server需要以下COOKIE来进行简单的用户动作跟踪:
cur_query:you&me
last_tm:…(上次请求的unix时间戳,定为当前请求时间前10分钟)
cur_tm:…(当前请求的unix时间戳)
设置超时为10秒,发出请求后,将http server的响应内容输出。
复制内容到剪贴板 代码:Function encode($data, $sep = ‘&’){
while (list($k,$v) = each($data)) {
$encoded .= ($encoded ? “$sep” : “”);
$encoded .= rawurlencode($k).”=”.rawurlencode($v);
}
Return $encoded;
}
Function post($url, $post, $COOKIE){
$url = parse_url($url);
$post = encode($data, ‘&’);
$COOKIE = encode($COOKIEArray, ‘;’);
$fp = fsockopen($url['host'], $url['port'] ? $url['port'] : 80, $errno, $errstr, 10);
if (!$fp) return “Failed to open socket to $url[host]“;
fputs($fp, sprintf(“POST %s%s%s HTTP/1.0\n”, $url['path'], $url['query'] ? “?” : “”, $url['query']));
fputs($fp, “Host: $url[host]\n”);
fputs($fp, “Content-type: application/x-www-form-urlencoded\n”);
fputs($fp, “Content-length: ” . strlen($encoded) . “\n”);
fputs($fp, “COOKIE: $COOKIE\n\n”);
fputs($fp, “Connection: close\n\n”);
fputs($fp, “$post \n”);
while (!feof($fp)) {
echo fgets($fp, 128);
}
fclose($fp);
}
$url = ‘http://www.example.com:8080/test’;
$encoded = username=温柔一刀& pwd=
$post = array(
‘username’=> ‘温柔一刀’,
‘pwd => ‘&123=321&321=123&’,
‘intro => ‘Hello world!’
);
$COOKIE = array(
‘cur_query’ => ‘you&me,
‘last_tm’ => time() – 600,
‘cur_tm ‘=> time()
);
Post($url, $post, $COOKIE);
11.你用什么方法检查PHP脚本的执行效率(通常是脚本执行时间)和数据库SQL的效率(通常是数据库Query时间),并定位和分析脚本执行和数据库查询的瓶颈所在?
1.脚本执行时间,启用xdebug,使用WinCacheGrind分析。
2.数据库查询,mysql使用EXPLAIN分析查询,启用slow query log记录慢查询。