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[] = 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 = ;
echo $str3 == $str4 ? '相等' : '不相等'; // 相等 $str5 = ;
$str6 = ’′;
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=;
for($i=; $i<=$n; $i++) {
$res=($res+$m)%$i;
}
return $res+;
}
$leader = King(,);
echo $leader; //方法2,定义函数
function getKing($monkeys , $m , $current = ){
$number = count($monkeys);
$num = ;
if(count($monkeys) == ){
echo '<font color="red">编号为'.$monkeys[].'的猴子成为猴王了!</font>';
return;
}else{
while($num++ < $m){
$current++;
$current = $current%$number;
}
echo "编号为".$monkeys[$current]."的猴子被踢掉了...<br/>";
array_splice($monkeys , $current , );
getKing($monkeys, $m , $current);
}
}
$n=; //总共猴子数目
$m = ; //数到第几只的那只猴子被踢出去
$monkeys = range(,$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)/;
}
echo get_days(’--′, ’--′);
方法2:
$temp = explode('-', '2007-2-5');
$time1 = mktime(, , , $temp[], $temp[], $temp[]);
$temp = explode('-', '2007-3-6');
$time2 = mktime(, , , $temp[], $temp[], $temp[]);
echo ($time2-$time1)/;
方法3:
echo abs(strtotime("2007-2-1")-strtotime("2007-3-1"))/// 计算时间差
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(); 后退: history.back();=history.go(-);
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 则结果是 。
对于对象,如果安装了 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的新的从属实体。 ()HTTP 定义了与服务器交互的不同方法,最基本的方法是 GET 和 POST。事实上 GET 适用于多数请求,而保留 POST 仅用于更新站点。 ()在FORM提交的时候,如果不指定Method,则默认为GET请 求,Form中提交的数据将会附加在url之后,以?分开与url分开。字母数字字符原样发送,但空格转换为“+“号,其它符号转换为%XX,其中XX为 该符号以16进制表示的ASCII(或ISO Latin-)值。GET请求请提交的数据放置在HTTP请求协议头中,而POST提交的数据则放在实体数据中; GET方式提交的数据最多只能有1024字节,而POST则没有此限制。 ()GET 这个是浏览器用语向服务器请求最常用的方法。POST这个方法也是用来传送数据的,但是与GET不同的是,使用POST的时候,数据不是附在URI后面传 递的,而是要做为独立的行来传递,此时还必须要发送一个Content_length标题,以标明数据长度,随后一个空白行,然后就是实际传送的数据。网 页的表单通常是用POST来传送的
PHP 面试题二的更多相关文章
- 数据库基础SQL知识面试题二
数据库基础SQL知识面试题二 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.选课系统SQL语法练习 course数据库中有以下四张表: •students表(学生表): si ...
- C/C++常考面试题(二)
网上看到的面经,说是dynamic_cast的实现,和RTTI的相关,这才发现原来对这个概念这么模糊,所以作了这个总结. C/C++常考面试题(二) RTTI(Runtime Type Informa ...
- php面试题二--解决网站大流量高并发方案(从url到硬盘来解决高并发方案总结)
php面试题二--解决网站大流量高并发方案(从url到硬盘来解决高并发方案总结) 一.总结 从外到内解决网站大流量高并发问题---从提交一个url开始(从用户按下搜索栏回车键开始) url最开始会到d ...
- php开发面试题---2、php常用面试题二(表单提交方式中的get和post有什么区别)
php开发面试题---2.php常用面试题二(表单提交方式中的get和post有什么区别) 一.总结 一句话总结: 数据位置:get参数在url里面,post在主体里面 数据大小:get几kb,pos ...
- C++经典面试题(二)
近期看一些面试题,认为假设自己被问到了,并不能非常利落的回答出来. 一是从来没有这个意识,二是没有认真的梳理下. 以下对这些题做出分析,哈!个人能力有限,当中难免有疏漏,欢迎大家补充咯. 11.引用与 ...
- JAVA面试题二
JAVA 综合面试题 2007-08-12 目录 Java面试题整理 9 Java面向对象 9 1. super()与this()的区别? 9 2. 作用域public,protected,priva ...
- Java面试题(二)
系统整理了一下有关Java的面试题,包括基础篇,javaweb篇,框架篇,数据库篇,多线程篇,并发篇,算法篇等等,陆续更新中.其他方面如前端后端等等的面试题也在整理中,都会有的. 注:文末有福利! 1 ...
- Java常考面试题(二)
序言 昨天刚开始的”每日5题面试“这类文章,感觉还不错,把一些平常看似懂了的东西,弄清楚了.就像什么是虚拟机?这个问题,看起来知道,但是要说出个所以然来,又懵逼了,经常回过头来看看做过的面试题,试着用 ...
- C# 面试题 二
1.进程和线程的区别 进程是系统进行资源分配和调度的单位:线程是CPU调度和分派的单位,一个进程可以有多个线程,这些线程共享这个进程的资源. 2.成员变量和成员函数前加static的作用 它们被称为常 ...
- python面试题(二)
最近参加了几场招聘,发现好多人的一些基础知识不是很扎实,做的题很多都是错误的,因此找了一些我们公司面试过程中的一些最基本的面试题供大家参考,希望各位都能找到一个好的工作.今天给大家先分享的是关于Pyt ...
随机推荐
- Hadoop 无法启动的问题
最近乱搞把本来就快要挂了的hdfs又给弄坏了.问题如下, 应该是节点没有启动. [hadoop@namenode hadoop]$ hadoop dfsadmin -report Configured ...
- C#中Object转化为json对象
比如定义一个类: public class Lines { public string X1 { get; set; } public string X2 { get; set; } public s ...
- Excel按照某一列的重复数据设置隔行变颜色效果
问题:如图所示,想按照A列中的重复数据设置隔重复行变颜色的效果,能否通过条件格式命令实现. 方法1:(最佳答案) 条件格式公式:=MOD(SUMPRODUCT(--($A$1:$A1<>$ ...
- 忘记用了delete释放内存,如何防止内存溢出
C++的内存管理还是要自己来做的,自己要进行内存的申请和释放 程序直接kill掉,OS会回收的 但是面试要问到这个问题,其实是想问你别的 RAII,也称为“资源获取就是初始化”,是c++等编程语言常用 ...
- 【C/C++多线程编程之七】pthread信号量
多线程编程之信号量 Pthread是 POSIX threads 的简称.是POSIX的线程标准. 相互排斥量用来处理一个共享资源的同步訪问问题,当有多个共享资源时,就须要 ...
- 建立DbLink 时报ORA-01017/ORA-02063分析及解决
今天在11G的oracle数据库上创建DBlink连接10g的库时, 出现: ORA-01017: invalid username/password; logon denied ORA-02063: ...
- phpcms 允许英文目录有空格
大家都用过phpcm添加栏目吧,在添加栏目里面,有个选项是 英文目录,这里目录可以用作伪静态功能.这么英文不能有空格等特殊字符.但是如果页面中需要引用包含空格的字符呢,例如,关于我们页面,我要显示英文 ...
- oracle如何回收空间?
ALTER TABLE 名称 DEALLOCATE UNUSED [KEEP 4[M|K]] 1.当空间分配过大时,可以使用本命令 2.如果没有加KEEP,回收到水线 3.如果水线<MINEXT ...
- mysql的执行计划概念说明
explain中的列的说明 1. id列 id列的编号是 select 的序列号,有几个 select 就有几个id,并且id的顺序是按 select 出现的 顺序增长的. id列越大执行优先级越高, ...
- uml图的五种关系 标签: uml 2016-12-18 21:47 221人阅读 评论(25) 收藏
统一建模语言 Unified Modeling Language (UML)又称统一建模语言或标准建模语言,是始于1997年一个OMG标准,它是一个支持模型化和软件系统开发的图形化语言,为软件开发的所 ...