php语言 百分网手机站

初级PHP程序员笔试题

时间:2020-10-04 10:12:26 php语言 我要投稿

2017年初级PHP程序员笔试题

  即将面临毕业的准毕业生们是不是在为工作发愁了?下面是百分网小编精心为大家整理的2017年初级PHP程序员笔试题,希望对大家有帮助,更多内容请关注应届毕业生网!

2017年初级PHP程序员笔试题

  一、基础及程序题(建议使用你擅长的语言:C/C++、PHP、Java)

  1.写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。(提示:不能使用系统已有函数,另外请仔细回忆以前学习过的

  基础知识)

  2.实现一个字符串截取的函数,类似于substr,必须能够截取中文这种多字节编码。假设每个中文也是一个字符,普通的数字、符号、字母也是一个字

  符。(提示:GB编码的中文字符高位范围是 x81-xFE )

  3.写一个遍历指定目录下所有子目录和子文件的函数(提示:可以使用递归的方法)

  4.写出匹配邮箱地址和URL的两个正则表达式。类似下面的:

  邮箱地址:user_name.first@example.com.cn /

  URL地址:http://www.example.com.cn/user_profile.php?uid=1

  (提示:使用标准的正则表达式,就是PHP中preg_* 类的正则处理函数能够解析的正则)

  二、数据库技术题

  1.写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)

  2.说出你所知道的三种以上开源数据库的名称(提示:想想目前国外流行的开源数据库)

  3.MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?

  4.说出MySQL 4.和MySQL 4.1版本的最主要的两个区别。如果你使用过MySQL 5,请说说MySQL 5跟MySQL 4的主要区别。(后半题选作)

  5.MySQL数据库基本的三个优化法则是什么?(提示:从服务配置、应用、开发角度考虑)

  三、综合技术题

  1.请使用JavaScript写出三种产生一个Image 标签的方法(提示:从方法、对象、HTML角度考虑)

  2.请使用CSS样式,描述两种方法在当前列中只显示一个div对象

  3.请描述出两点以上XHTML和HTML最显著的区别

  4.出五种以上你使用过的PHP的扩展的名称(提示:常用的PHP扩展)

  5.了解MVC模式吗?请写出三种以上目前PHP流行的MVC框架名称(不区分大小写)ThinkPHP QeePHP YiiPHP

  6.写出15个以上你所知道的常用的Linux命令和它的功能

  7.使用过Vim编辑器吗?如果使用过,如何在vim里切分多个可视化窗口,包括横排和纵排。(本题选作)

  8.说说Linux下的find命令和grep命令的区别(本题选作)

  9.请描述出七层网络模型的名称,由下到上(可以使用中文描述)

  1.说说下面这些这些协议的全称和中文解释(提示:都是工作在应用层)SMTP、POP3、HTTP、FTP、DNS

  11.使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?(本题选作)

  12.请大致的说说Session的工作原理。(提示:与Cookie有相应的关系)

  13.说说你所了解的搜索引擎包含那些技术?(本题选作)

  四、项目及设计题

  1.一个Web开发团队开发中,大致说说你所了解的所有成员的分工合作情况

  2.说说你做过的最得意的项目或者个人开发作品(可以是个人作品,也可以是合作项目)

  3.假设给你5台服务器,请大致的描述一下,如何使用你所熟悉的开源软件,搭建一个日PV 3万左右的中型网站

  PHP程序员笔试题 (参考答案)

  五、基础及程序题(建议使用你擅长的语言:C/C++、PHP、Java)

  5.写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。(提示:不能使用系统已有函数,另外请仔细回忆以前学习过的

  基础知识)

  //冒泡排序(数组排序)

  function bubble_sort($array)

  {

  $count = count($array);

  if ($count <= ) return false;

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

  for($j=$count-1; $j>$i; $j--){

  if ($array[$j] < $array[$j-1]){

  $tmp = $array[$j];

  $array[$j] = $array[$j-1];

  $array[$j-1] = $tmp;

  }

  }

  }

  return $array;

  }

  //快速排序(数组排序)

  function quicksort($array) {

  if (count($array) <= 1) return $array;

  $key = $array[];

  $left_arr = array();

  $right_arr = array();

  for ($i=1; $i

  if ($array[$i] <= $key)

  $left_arr[] = $array[$i];

  else

  $right_arr[] = $array[$i];

  }

  $left_arr = quicksort($left_arr);

  $right_arr = quicksort($right_arr);

  return array_merge($left_arr, array($key), $right_arr);

  }