精选新浪php面试题附答案

  中国人才网小编:新浪主要用的是PHP。静态化:尽可能的将页面生成.shtml文件。.shtml文件里还包括服务器端包含技术

  缓存:数据库缓存、PHP缓存、MEMCACHE、CACHE SERVER等。所以小编整理了这篇精选的新浪php面试题,还有附答案,小伙伴好好参考一下吧!

       面试题:

  1. echo count(“abc”); 输出什么?

  答:”1″

  count — 计算数组中的单元数目或对象中的属性个数

  int count ( mixed $var [, int $mode ] ), 如果 var 不是数组类型或者实现了 Countable 接口的对象,将返回 1,有一个例外,如果 var 是 NULL 则结果是 0。

  对于对象,如果安装了 SPL,可以通过实现 Countable 接口来调用 count()。该接口只有一个方法 count(),此方法返回 count() 函数的返回值。

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

  答:$_SERVER[‘SERVER_ADDR’] 服务器

  $_SERVER[‘REMOTE_ADDR’]客户端

  1

  function getOnlineIP(){

  2

  if (getenv('HTTP_CLIENT_IP')) return getenv('HTTP_CLIENT_IP');

  3

  if (getenv('HTTP_X_FORWARDED_FOR')) return getenv('HTTP_X_FORWARDED_FOR');

  4

  if ($_SERVER["REMOTE_ADDR"]) return $_SERVER["REMOTE_ADDR"];

  5

  if (!empty($HTTP_SERVER_VARS['REMOTE_ADDR']))

  6

  return $HTTP_SERVER_VARS['REMOTE_ADDR'];

  7

  }

  3. error_reporting(2047)什么作用?

  答:PHP 显示所有错误 E_ALL

  4. echo,print()和print_r()有什么区别?

  答:echo是一个语言结构,没有返回值。

  print是一个函数,返回int类型的值。[只能打印int string]

  print_r()是一个函数,返回bool类型值,按结构输出变量的值。打印关于变量的易于理解的信息[数组、对象等]

  5. 打开php.ini中的Safe_mode,会影响哪些函数?至少说出6个。

  答:a:用户输入输出函数(fopen() file() require(),只能用于调用这些函数有相同脚本的拥有者)

  b:创建新文件(限制用户只在该用户拥有目录下创建文件)

  c:用户调用popen() systen() exec()等脚本,只有脚本处在safe_mode_exec_dir配置指令指定的目 录中才可能

  d:加强HTTP认证,认证脚本拥有者的UID的划入认证领域范围内,此外启用安全模式下,不会设置PHP_AUTH

  e:mysql服务器所用的用户名必须与调用mysql_connect()的文件的拥有者用户名相同

  f:受影响的函数变量以及配置命令达到40个

  6. 写个函数来解决多线程同时读写一个文件的问题。

  答:flock($hander,LOCK_EX); 这个可是内置函数啊,

  这个尚待解决

  7. 请写一个函数验证电子邮件的格式是否正确(要求使用正则)

  答:preg_match(‘/^[\w\-\.]+@[\w\-]+(\.\w+)+$/’, $email);

  8. 考SQL语句的题,题太长了,实在不好回忆了。

  答:去理解别人的回忆是件很困难的事情

  9. MySQL数据库,一天一万条以上的增量,怎么优化?

  答:我们曾做过短信SP的东西,有个短信发送的日志表,每天增量也很大,处理的方法是按月进行分表,因为是日志表,主要操作是insert操作,所以每月初自动生成新的数据表,数据插入到对应月份

  的那张数据表。[比如表明前缀是cdb_smslog 后面加200910 及时cdb_smslog_200910]

  其他优化方式暂时想不起来,对于myISAM, 考虑容量的话,也有优化的方案

  10. 写出一种排序算法(要写出代码),并说出优化它的方法。

  答:

  01

  //冒泡排序

  02

  function maopao($arr) {

  03

  $count = count($arr);

  04

  for($i=0; $i<$count-1; ++$i) {

  05

  for($j=0; $j<$count-$i-1; ++$j) {

  06

  if($arr[$j] > $arr[$j+1]) {

  07

  $temp = $arr[$j];

  08

  $arr[$j] = $arr[$j+1];

  09

  $arr[$j+1] = $temp;

  10

  }

  11

  }

  12

  }

  13

  return $arr;

  14

  }

  15

  //顺序排序

  16

  function shunxu($arr) {

  17

  $count = count($arr);

  18

  for($i=0; $i<$count-1; ++$i) {

  19

  $p = $i;

  20

  for($j=$i+1; $j<$count; ++$j) {

  21

  $p = $arr[$p] > $arr[$j] ? $j : $p;

  22

  }

  23

  if($p != $i) {

  24

  $tvalue = $arr[$i];

  25

  $arr[$i] = $arr[$p];

  26

  $arr[$p] = $tvalue;

  27

  }

  28

  }

  29

  return $arr;

  30

  }

  ps:有人说加个监控,计算数组交换的频度[这对冒泡], 比如冒泡的第一次操作频度为0,则无需操作,直接返回,因为已经是排好序的数组

  11. 写个函数用来对二维数组排序。

  答:

  01

  function array_sort_by_any_row($array_name, $row_id, $order_type){

  02

  $array_temp=array();

  03

  foreach($array_name as $key=>$value){

  04

  $array_temp[$key]=$value[$row_id];

  05

  }

  06

  if($order_type==="ASC"){ //顺序

  07

  asort($array_temp);

  08

  } else {

  09

  arsort($array_temp);

  10

  }

  11

  $result_array=array();

  12

  foreach($array_temp as $key=>$value){

  13

  $result_array[$key]=$array_name[$key];

  14

  }

  15

  return $result_array;

  16

  }

  17

  $arr = array(array('num'=>5, 'value'=>6),

  18

  array('num'=>2, 'value'=>39),

  19

  array('num'=>36, 'value'=>29)

  20

  );

  21

  $sortarr = array_sort_by_any_row($arr, 'num', 'DESC');

  22

  print_r($sortarr);

  12. 写5个不同的自己的函数,来截取一个全路径的文件的扩展名,允许封装php库中已有的函数。

  答:

  01

  $path = str_replace('\\', '/',__FILE__);

  02

  echo $path.'
';

  03

  function extname1($path) {

  04

  return strrchr($path, '.');

  05

  }

  06

  function extname2($path) {

  07

  $position = strrpos($path, '.');

  08

  return substr($path, $position);

  09

  }

  10

  function extname3($path) {

  11

  $arr = explode('.', $path);

  12

  return $arr[count($arr) - 1];

  13

  }

  14

  function extname4($path) {

  15

  preg_match_all('/[\w\/\:\-]+\.([\w]+)$/', $path, $out);

  16

  return $out[1][0];

  17

  }

  18

  function extname5($path) {

  19

  return preg_replace('/^[^\.]+\.([\w]+)$/', '${1}', basename($path));

  20

  }

  21

  print_r(extname5($path));

  13. 一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。

  答:

  yuesefu环问题,PPC有很多针对这个问题的处理,我的就不上啦

  view sourceprint?

  1

  function yuesefu($n,$m) {

  2

  $r=0;

  3

  for($i=2; $i<=$n; $i++) {

  4

  $r=($r+$m)%$i;

  5

  }

  6

  return $r+1;

  7

  }

  8

  print_r(yuesefu(3,3));

本文已影响6827
上一篇:2014年网易游戏运营管理培训生笔试题目参考 下一篇:关于Javascript之AJAX的基础知识笔试题目

相关文章推荐

|||||