蜜蜂职场文库 > 面试技巧 >

php常见面试题及答案

时间: 小龙 面试技巧

  PHP面试者在面试前的准备很重要,以下是小编帮你们整理的php常见面试题及答案,一起来学习啦。

  php常见面试题及答案(一)

  1、表单提交get和post有何区别?

  答:get的方式是把数据在地址栏中发送,get传送的数据量较小,不能大于2KB。post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KB,IIS5中为100KB。

  2、用PHP打印出前一天的时间格式是2006-5-10 22:21:21

  echo date("Y-m-d H:i:s",time()-(3600*24));或echo date("Y-m-d H:i:s",strtotime("-1 day"));

  3、php中include和require的区别?

  这两种结构除了在如何处理失败之外完全一样。include() 产生一个警告而 require() 则导致一个致命错误。换句话说,如果你想在遇到丢失文件时停止处理页面就用 require()。include() 就不是这样,脚本会继续运行。

  4、echo(),print(),print_r()的区别

  echo可以接多个参数,print只能接一个参数,它们都是PHP的语言结构,print_r是递规打印,用来打印数组或对象

  5、能够使HTML和PHP分离开使用的模板smarty,phplib,SmartTemplate 6你如何理解MVC模式?

  首先说一下框架,框架:就是别人把一些底层,常用操作.比如数据操作(增,删,改,查)写好.你来直接用.其它的功能要自己来做。

  MVC:设计模式,M模型,V显示,C控制.现在许多框架都是基于MVC来做的把逻辑和显示分开.比如你要换页面,只需要改V里面的东西并不需要再去变动程序(详细的东西可以上网上查一下)

  6、apache+mysql+php实现最大负载的方法

  1) 问的太笼统,生成静态html页面,squid反向代理,apache,mysql的负载均衡。

  2) 可以采取数据缓存的方法,我们通常在统计数据的时候,需要在原始数据的基础上经过计算等一系列操作,才会得到最终的结果,如果每做一个查询都需要这样一系列操作,当数据量大时,势必会带来很多问题。可以建立一个结果表,写一个脚本,用crontab定时触发脚本去原始表取数据,计算,写入到结果表,前端查询从结果表取数据,这也是比较常用的一种做法。

  3) 采用分布式,多个apache,多个mysql,其实就是dns负载均衡,dns根据当前用户解析几个ip的ping值,将用户转移到某一台最快的服务器,或者平均分配。

  4 )money不是问题的话,可以考虑F5硬件负载均衡!

  5)可以使用Microsoft Windows Server系统的负载均衡设置

  php常见面试题及答案(二)

  1、如何实现PHP、JSP交互?

  PHP提供了支持JAVA的类库文件,或者通过HTTP协议来交互数据

  2、使用哪些工具进行版本控制?

  VSS,CVS,SVN

  3、如何实现字符串翻转?

  不考虑中英文混合,不是最优算法,不用php库函数翻转字符串:

  function str_to_reverse( $str ){

  for($length=0;$str[$length]!=null;$length++){;}

  $strlength = $length-1;

  unset($length);

  for($start=0,$end=$strlength;$start<$end;$start++,$end--){

  $temp = $str[$start];

  $str[$start] = $str[$end];

  $str[$end] = $temp;

  }

  unset($temp,$start,$end,$strlength);

  return $str;

  }

  4、优化MYSQL数据库的方法。

  1) 将where中用的比较频繁的字段建立索引,联合索引。

  2) 保证单表数据不超过200W,适时分割表。

  3) 避免使用长连接。

  4) 修改my.cnf里面的各项参数,比如最大连接数,查询缓存等。根据你的服务器内存来最大化调节那些配置参数。

  5) 针对需求,使用正确的表引擎,是myisam或是innodb。

  5.用PHP写出显示客户端IP与服务器IP的代码:

  echo $_SERVER['REMOTE_ADDR'] //客户端ip

  echo $_SERVER['SERVER_ADDR'] //服务器端ip

  php常见面试题及答案(三)

  1、用PHP打印出前一天的时间格式是2006-5-10 22:21:21

  2、echo(),print(),print_r()的区别

  3、能够使HTML和PHP分离开使用的模板

  4、如何实现PHP、JSP交互?

  5、使用哪些工具进行版本控制?

  6、如何实现字符串翻转?

  7、优化MYSQL数据库的方法。

  8、谈谈事务处理

  9、apache+mysql+php实现最大负载的方法

  10、实现中文字串截取无乱码的方法。

  答案:

  1.echo date('Y-m-d H:i:s', strtotime('-1 day'));

  2.echo是语言结构,无返回值;print功能和echo基本相同,不同的是print是函数,有返回值;print_r是递归打印,用于输出数组对象

  3.so much,其实PHP本身就是一种模版引擎,我用过的是smarty,常见的还有PHPLib,FastTemplate,Savant这里有个模板引擎列表

  4. 题目有点含糊不清,SOAP,XML_RPC,Socket ,CURL都可以实现这些,如果是考PHP和Java的整合,PHP内置了这种机制(如果考PHP和.NET的整合,也可以这么回答),例如$foo = new Java('java.lang.System');

  5.CVS 和SVN,SVN号称下一代CVS,功能强大,不过CVS是老牌,市占率很高.我一直用SVN,题目是问用什么工具,呃,这个可能需要这么回答:CVS Server on Apache作服务端,WinCVS作客户端;Subversion on Apache/DAV 做服务端,TortoiseSVN做客户端,或者Subclipse做客户端.

  6.用strrev函数呗,不准用PHP内置的就自己写:

  strrev($str)

  {

  $len=strlen($str);

  $newstr = '';

  for($i=$len;$i>=0;$i--)

  {

  $newstr .= $str{$i};

  }

  return $newstr;

  }

  7.高考政治题,把你知道的知识点都写上吧.我的答案:

  (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.如同是个编程语言都会有答应Hello World的例子一样,是本数据库的教材都会讲A给B的账户转账50美元的例子,回答这个就好了.不过据我所知,用MySQL的企业,很少用MySQL来实现事务处理.何况现在Oracle收购了InnoDB的公司.

  9.参见第七题的答案,那个地方搞好了这个问题就迎刃而解了.

  10.哈哈哈,我猜出题的人是不是被substr的中文处理问题烦恼很久了,是不是还用了网上流传的用正则匹配

49859