PHP经典面试题(基础型)附答案_php入门面试题含答案
PHP经典面试题(基础型)附答案由刀豆文库小编整理,希望给你工作、学习、生活带来方便,猜你可能喜欢“php入门面试题含答案”。
PHP经典面试题(基础型I)附答案
求职与招聘 往往少不了面试与笔试,作为一个php程序员、多多少少都会有类似的经历„„以下是本人收集并整理的PHP面试题目,希望对同行们有所帮助,找到一份合适的php开发工作!(共三节)
以下是面试的题目
(一),下一篇: PHP经典面试题(基础型II)已经赋予答案:
1、用PHP打印出前一天的时间格式是2009-02-10 22:21:21(2分)echo date('Y-m-d H:i:s', strtotime('-1 day'));或者
$yesterday = time()-(24 * 60 * 60);echo 'today:'.date('Y-m-d H:i:s').“n”;echo 'yesterday:'.date('Y-m-d H:i:s', $yesterday).“n”;
2、echo(),print(),print_r()的区别(3分)echo是PHP语句, print和print_r是函数,语句没有返回值,函数可以有返回值(即便没有用)print只能打印出简单类型变量的值(如int,string)print_r可以打印出复杂类型变量的值(如数组,对象)echo--输出一个或者多个字符串
3、能够使HTML和PHP分离开使用的模板(1分)smarty,Heyes Template Cla等
5、使用哪些工具进行版本控制?(1分)CVS和SVN,SVN号称下一代CVS,功能强大,不过CVS是老牌,市占率很高.我一直用SVN,题目是问用什么工具呃,这个可能需要这么回答:CVS Server on Apache作服务端,WinCVS作客户端;Subversion on Apache/DAV 做服务端,TortoiseSVN做客户端,或者Subclipse做客户端.6、如何实现字符串翻转?(3分)strrev()或者
$str = “abcdefg”;
function strrevv($str){ $len=strlen($str);$newstr = '';for($i=$len;$i>=0;$i--){ $newstr.= $str{$i};} return $newstr;} $showstr = strrevv($str);echo $showstr.“”;
7、优化MYSQL数据库的方法。(4分,多写多得)(1).选取最适用的字段属性,应该尽量把字段设置为NOT NULL,这样在将来执行查询的时候,数据库不用去比较NULL值。
(2).使用连接(JOIN)来代替子查询(Sub-Queries)(3).使用联合(UNION)来代替手动创建的临时表(4).尽量少使用 LIKE 关键字和通配符(5).使用事务和外键
或者
(1).数据库设计方面,这是DBA和Architect的责任,设计结构良好的数据库,必要的时候,去正规化(英文是这个:denormalize,中文翻译成啥我不知道),允许部分数据冗余,避免JOIN操作,以提高查询效率
(2).系统架构设计方面,表散列,把海量数据散列到几个不同的表里面.快慢表,快表只留最新数据,慢表是历史存档.集群,主服务器Read & write,从服务器read only,或者N台服务器,各机器互为Master(3).(1)和(2)超越PHP Programmer的要求了,会更好,不会没关系.检查有没有少加索引(4).写高效的SQL语句,看看有没有写低效的SQL语句,比如生成笛卡尔积的全连接啊,大量的Group By和order by,没有limit等等.必要的时候,把数据库逻辑封装到DBMS端的存储过程里面.缓存查询结果,explain每一个sql语句
(5).所得皆必须,只从数据库取必需的数据,比如查询某篇文章的评论数,select count(*)...where article_id = 就可以了,不要先select *...where article_id = 然后msql_num_rows.只传送必须的SQL语句,比如修改文章的时候,如果用户只修改了标题,那就update...set title = where article_id = 不要set content =(大文本)(6).必要的时候用不同的存储引擎.比如InnoDB可以减少死锁.HEAP可以提高一个数量级的查询速度
8、PHP的意思(送1分)Hypertext Preproceor
9、MYSQL取得当前时间的函数是?,格式化日期的函数是(2分)now(), DATE_FORMAT(date,format)
10、实现中文字串截取无乱码的方法。(3分)mb_substr()
11、您是否用过版本控制软件? 如果有您用的版本控制软件的名字是?(1分)TortoiseSVN-1.2.6 svn-1.2.3
12、您是否用过模板引擎? 如果有您用的模板引擎的名字是?(1分)smarty
13、请简单阐述您最得意的开发之作(4分)这个自己想,因为你不再是菜鸟,每个人都有不同的思路,思路也会随之自己的知识而改变„„
14、对于大流量的网站,您采用什么样的方法来解决访问量问题?(4分)首先,确认服务器硬件是否足够支持当前的流量 其次,优化数据库访问。第三,禁止外部的盗链。第四,控制大文件的下载。第五,使用不同主机分流主要流量 第六,使用流量分析统计软件。
---
15、用PHP写出显示客户端IP与服务器IP的代码1分)//显示客户端I function get_client_ip(){# if(getenv('HTTP_CLIENT_IP')){ $client_ip = getenv('HTTP_CLIENT_IP');} elseif(getenv('HTTP_X_FORWARDED_FOR')){ $client_ip = getenv('HTTP_X_FORWARDED_FOR');} elseif(getenv('REMOTE_ADDR')){ $client_ip = getenv('REMOTE_ADDR');} else { $client_ip = $HTTP_SERVER_VAR['REMOTE_ADDR'];} return $client_ip;} //服务器IP function get_server_ip(){ if(iet($_SERVER)){ if($_SERVER['SERVER_ADDR'])$huoqu_ip=$_SERVER['SERVER_ADDR'];else $huoqu_ip=$_SERVER['LOCAL_ADDR'];} else { $huoqu_ip=getenv('SERVER_ADDR');} return $huoqu_ip;}
16、语句include和require的区别是什么?为避免多次包含同一文件,可用(?)语句代替它们?(2分)require()和include()除了怎样处理失败之外在各方面都完全一样。include()产生一个警告而require()则导致一个致命错误。
换句话说,如果你想在丢失文件时停止处理页面,用require()。include()就不是这样,脚本会继续运行。
require()无论如何都会包含文件,而include()可以有选择地包含.www.daodoc.comn =& NewADOConnection('mysql');$cnn-> Connect($db_hostspec, $db_username, $db_paword, $db_database);$cnn-> SetFetchMode(ADODB_FETCH_ASSOC);if(!$cnn)meage(“无法连接数据库 $db_database”);$sql = “SELECT * FROM `category` WHERE 1;$rst =& $cnn-> Execute($sql);if(!$rst)die($cnn-> ErrorMsg());$arr_categroy = $rst-> GetArray(); $row): ?> ”>