PHP 面试题二
1、抓取远程图片到本地,你会用什么函数?
fsockopen, A
2、用最少的代码写一个求3值最大值的函数.
function get_max($a,$b,$c) { return ($a > $b ? $a : $b) > $c ? ($a > $b ? $a : $b) : $c; }
4、javascript能否定义二维数组,如果不能你如何解决?
javascript不支持二维数组定义,可以用arr[0] = new array()来解决
5、假设a.html和b.html在同一个文件夹下面,用javascript实现当打开a.html五秒钟后,自动跳转到b.html。
function test(){
window.location = "b.html";
window.close();
}
setTimeout( "test()",5000 ); //5秒钟后自动执行test()
8、写一个函数,能够遍历一个文件夹下的所有文件和子文件夹。
<?php function my_dir($dir){ $files=array(); //注意这里要加一个@,不然会有warning错误提示 if(@$handle=opendir($dir)){ while(($file=readdir($handle))!==false){ //排除根目录; if($file!=".." && $file!="."){ //如果是子文件夹,就进行递归 ;不是就将文件的名字存入数组; if(is_dir($dir."/".$file)){ $files[$file]=my_dir($dir."/".$file); }else{ $files[]=$file; } } } closedir($handle); return $files; } } //以下是测试 $array=my_dir('C:/test'); var_dump($array);
9、把 John 新增到 users 阵列?
$users[] = 'join';
array_push($users, 'john');
10、在PHP中error_reporting这个函数有什么作用?
error_reporting() 设置 PHP 的报错级别并返回当前级别。
16、写一个函数,尽可能高效的,从一个标准 url 里取出文件的扩展名
例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php
<?php
function getExt($url){
$arr = parse_url($url); // 解析url为数组
$file = basename($arr['path']); // $arr['path'] = "/abc/de/fg.php";
$ext = explode(".",$file); // $file = "fg.php"; explode拆分字符串,返回一个数组
return $ext[1];
}
17、使用五种以上方式获取一个文件的扩展名;要求:dir/upload.image.jpg,找出 .jpg 或者 jpg ,
必须使用PHP自带的处理函数进行处理,方法不能明显重复,可以封装成函数,比如 get_ext1($file_name), get_ext2($file_name)
// 方法1:
function get_ext1($file_name){ return strrchr($file_name, '.'); } // 方法2: function get_ext2($file_name){ return substr($file_name, strrpos($file_name, '.')); } // 方法3: function get_ext3($file_name){ return array_pop(explode('.', $file_name)); } // 方法4: function get_ext4($file_name){ $p = pathinfo($file_name); return $p['extension']; } // 方法5: function get_ext5($file_name){ return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), '.')));
}
18、以下代码的输出结果是?
$str1 = null;
$str2 = false;
echo $str1 == $str2 ? '相等' : '不相等'; // 相等
$str3 = ' '; $str4 = 0; echo $str3 == $str4 ? '相等' : '不相等'; // 相等 $str5 = 0; $str6 = ’0′; echo $str5 === $str6 ? '相等' : '不相等'; // 不相等
19、MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?
Varchar是变长,节省存储空间,char是固定长度。
查找效率: char类型快,因为varchar是非定长,必须先查找长度,然后进行数据的提取,比char定长类型多了一个步骤,所以效率低一些
20、PHP 数组排序
sort() - 以升序对数组排序 rsort() - 以降序对数组排序 asort() - 根据值,以升序对关联数组进行排序 ksort() - 根据键,以升序对关联数组进行排序 arsort() - 根据值,以降序对关联数组进行排序 krsort() - 根据键,以降序对关联数组进行排序
21、一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号
方法1: function King($n,$m) { $res=0; for($i=2; $i<=$n; $i++) { $res=($res+$m)%$i; } return $res+1; } $leader = King(13,34); echo $leader; //方法2,定义函数 function getKing($monkeys , $m , $current = 0){ $number = count($monkeys); $num = 1; if(count($monkeys) == 1){ echo '<font color="red">编号为'.$monkeys[0].'的猴子成为猴王了!</font>'; return; }else{ while($num++ < $m){ $current++; $current = $current%$number; } echo "编号为".$monkeys[$current]."的猴子被踢掉了...<br/>"; array_splice($monkeys , $current , 1); getKing($monkeys, $m , $current); } } $n=13; //总共猴子数目 $m = 34; //数到第几只的那只猴子被踢出去 $monkeys = range(1,$n); //将猴子编号放入数组中 getKing($monkeys , $m); //调用函数
28、使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?
Memcahce是把所有的数据保存在内存当中,采用hash表的方式,每条数据又key和value组成,每个key是独一无二的,当要访问某个值的时候先按照找到值,然后返回结果。
Memcahce采用LRU算法来逐渐把过期数据清除掉。
21、16.请描述出两点以上XHTML和HTML最显著的区别
(1)XHTML必须强制指定文档类型DocType,HTML不需要
(2)XHTML所有标签必须闭合,HTML比较随意
22、写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。
//冒泡排序(数组排序)
function bubbleSort($arr){
// 统计所有元素
$len = count($arr);
for($i = 0; $i < $len; $i++) {
for($k = $i+1; $k < $len; $k++) {
if($arr[$i] > $arr[$k]) {
$t = $arr[$k];
$arr[$k] = $arr[$i];
$arr[$i] = $t;
}
}
}
return $arr;
}
23、写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)
MyISAM、InnoDB、BDB(Berkeley DB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB 等等十几个引擎
24、求两个日期的差数,例如2007-2-5 ~ 2007-3-6 的日期差数
方法1: function get_days($date1, $date2) { $time1 = strtotime($date1); $time2 = strtotime($date2); return ($time2-$time1)/86400; } echo get_days(’2007-2-5′, ’2007-3-6′); 方法2: $temp = explode('-', '2007-2-5'); $time1 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]); $temp = explode('-', '2007-3-6'); $time2 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]); echo ($time2-$time1)/86400; 方法3: echo abs(strtotime("2007-2-1")-strtotime("2007-3-1"))/60/60/24 计算时间差
25、请写一个函数,实现以下功能:字符串“open_door” 转换成 “OpenDoor”、”make_by_id” 转换成 ”MakeById”。
// 方法一 function str_explode($str){ $str_arr=explode("_", $str); $str_implode=implode(" ",$str_arr); $str_implode=implode("",explode("",ucwords($str_implode))); return $str_implode; } $strexplode = str_explode("make_by_id"); print_r($strexplode);
// 方法二 $str = "make_by_id!"; $expStr = explode("_", $str); for($i=0;$i<count($expStr);$i++){ echo ucwords($expStr[$i]); }
// 方法三 echo str_replace(' ', '', ucwords(str_replace('_', ' ', 'open_door')));// 替换掉_后,首字母大写,替换掉空格
26、一个表中的Id有多个记录,把所有这个id的记录查出来,并显示共有多少条记录数,用SQL语句及视图、
存储过程分别实现。
DELIMITER //
create procedure proc_countNum(in columnId int,out rowsNo int)
begin
select count(*) into rowsNo from member where member_id=columnId;
end
call proc_countNum(1,@no);
select @no;
方法:视图:
create view v_countNum as select member_id,count(*) as countNum from member group by
member_id
select countNum from v_countNum where member_id=1
27、js中网页前进和后退的代码
前进: history.forward();=history.go(1); 后退: history.back();=history.go(-1);
28、下列代码输出什么?
echo count(null); // 0
echo count(' '); // 1
echo count(false); // 1
echo count('abc'); // 1
count — 计算数组中的单元数目或对象中的属性个数 int count ( mixed$var [, int $mode ] ), 如果 var 不是数组类型或者实现了 Countable 接口的对象,将返回1,有一个例外,如果 var 是 NULL 则结果是 0。 对于对象,如果安装了 SPL,可以通过实现 Countable 接口来调用 count()。该接口只有一个方法 count(),此方法返回 count() 函数的返回值。
32. php class中static,public,private,protected的区别?
static 静态,类名可以访问 public 表示全局,类内部外部子类都可以访问; private 表示私有的,只有本类内部可以使用; protected 表示受保护的,只有本类或子类或父类中可以访问;
33. HTTP协议中GET、POST和HEAD的区别?
HEAD: 只请求页面的首部。 GET: 请求指定的页面信息,并返回实体主体。 POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。 (1)HTTP 定义了与服务器交互的不同方法,最基本的方法是 GET 和 POST。事实上 GET 适用于多数请求,而保留 POST 仅用于更新站点。 (2)在FORM提交的时候,如果不指定Method,则默认为GET请 求,Form中提交的数据将会附加在url之后,以?分开与url分开。字母数字字符原样发送,但空格转换为“+“号,其它符号转换为%XX,其中XX为 该符号以16进制表示的ASCII(或ISO Latin-1)值。GET请求请提交的数据放置在HTTP请求协议头中,而POST提交的数据则放在实体数据中; GET方式提交的数据最多只能有1024字节,而POST则没有此限制。 (3)GET 这个是浏览器用语向服务器请求最常用的方法。POST这个方法也是用来传送数据的,但是与GET不同的是,使用POST的时候,数据不是附在URI后面传 递的,而是要做为独立的行来传递,此时还必须要发送一个Content_length标题,以标明数据长度,随后一个空白行,然后就是实际传送的数据。网 页的表单通常是用POST来传送的