初级PHP程序员笔试题(给某搜索引擎公司出的).doc_第1页
初级PHP程序员笔试题(给某搜索引擎公司出的).doc_第2页
初级PHP程序员笔试题(给某搜索引擎公司出的).doc_第3页
初级PHP程序员笔试题(给某搜索引擎公司出的).doc_第4页
初级PHP程序员笔试题(给某搜索引擎公司出的).doc_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

初级PHP程序员笔试题答题时间:60 90分钟一、基础及程序题(建议使用你擅长的语言:C/C+、PHP、Java)1.写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。(提示:不能使用系统已有函数,另外请仔细回忆以前学习过的基础知识)2.实现一个字符串截取的函数,类似于substr,必须能够截取中文这种多字节编码。假设每个中文也是一个字符,普通的数字、符号、字母也是一个字符。(提示:GB编码的中文字符高位范围是 0x81-0xFE )3.写一个遍历指定目录下所有子目录和子文件的函数(提示:可以使用递归的方法)4.写出匹配邮箱地址和URL的两个正则表达式。类似下面的:邮箱地址:user_URL地址:/user_profile.php?uid=100 (提示:使用标准的正则表达式,就是PHP中preg_* 类的正则处理函数能够解析的正则)二、数据库技术题1.写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)2.说出你所知道的三种以上开源数据库的名称(提示:想想目前国外流行的开源数据库)3.MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?4.说出MySQL 4.0和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框架名称(不区分大小写)6.写出15个以上你所知道的常用的Linux命令和它的功能7.使用过Vim编辑器吗?如果使用过,如何在vim里切分多个可视化窗口,包括横排和纵排。(本题选作)8.说说Linux下的find命令和grep命令的区别(本题选作)9.请描述出七层网络模型的名称,由下到上(可以使用中文描述)10.说说下面这些这些协议的全称和中文解释(提示:都是工作在应用层)SMTP、POP3、HTTP、FTP、DNS11.使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?(本题选作)12.请大致的说说Session的工作原理。(提示:与Cookie有相应的关系)13.说说你所了解的搜索引擎包含那些技术?(本题选作)四、项目及设计题1.一个Web开发团队开发中,大致说说你所了解的所有成员的分工合作情况2.说说你做过的最得意的项目或者个人开发作品(可以是个人作品,也可以是合作项目)3.假设给你5台服务器,请大致的描述一下,如何使用你所熟悉的开源软件,搭建一个日PV 300万左右的中型网站PHP程序员笔试题 (参考答案)五、基础及程序题(建议使用你擅长的语言:C/C+、PHP、Java)5.写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。(提示:不能使用系统已有函数,另外请仔细回忆以前学习过的基础知识)/冒泡排序(数组排序)function bubble_sort($array)$count = count($array);if ($count = 0) return false;for($i=0; $i$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 = $array0;$left_arr = array();$right_arr = array();for ($i=1; $icount($array); $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);6.实现一个字符串截取的函数,类似于substr,必须能够截取中文这种多字节编码。假设每个中文也是一个字符,普通的数字、符号、字母也是一个字符。(提示:GB编码的中文字符高位范围是 0x81-0xFE )/* 截取字符串子串 (1)(GBK)* param string $str 原始字符串* param int $len 需要截取字符串的长度* return string 返回截取到的字符串*/function GBSubstr($str, $len)$count = 0;for($i=0; $istrlen($str); $i+)if($count = $len) break;if(preg_match(/x80-xff/, substr($str, $i, 1) +$i;+$count; return substr($str, 0, $i);/* 截取字符串子串函数(2)(GB)* * param string $src 源字符串* param int $start 开始截取的位置* param int $length 需要截取字符串的长度* return string 返回截取的字符串*/function GBSubstr2($src, $start=0, $length=0)$suffix=;$len = strlen($src);if ( $len = $length ) return $src; $cut_length = 0;for( $idx = 0; $idx$length; $idx+) $char_value = ord($src$idx); if ( $char_value 0x80 | ( $char_value & 0x40 ) )$cut_length+;else$cut_length = $cut_length + 3; $curstr = substr($src, 0, $cut_length) ;preg_match(/(x00-x7f|.3)*/, $curstr, $result);return $result0;/* 中文字符串截取(3)(支持GB2312/GBK/UTF-8/BIG5)* param string $str 要截取的字串* param int $start 截取起始位置* param int $length 截取长度* param string $charset 字符串的字符集,包括有 utf-8|gb2312|gbk|big5 编码* param bool $suffix 是否加尾缀* return string 返回接续字符串的结果*/function CSubstr($str, $start=0, $length, $charset=gbk, $suffix=false)if(function_exists(mb_substr)return mb_substr($str, $start, $length, $charset);$reutf-8 = /x01-x7f|xc2-xdfx80-xbf|xe0-xefx80-xbf2|xf0-xffx80-xbf3/;$regb2312 = /x01-x7f|xb0-xf7xa0-xfe/;$regbk = /x01-x7f|x81-xfex40-xfe/;$rebig5 = /x01-x7f|x81-xfe(x40-x7e|xa1-xfe)/;preg_match_all($re$charset, $str, $match);$slice = join(, array_slice($match0, $start, $length);if($suffix) return $slice .;return $slice;7.写一个遍历指定目录下所有子目录和子文件的函数(提示:可以使用递归的方法)/* 递归的遍历一个指定目录*/function dir_all ( $path ) $handler = opendir($path); while (false!=($tmp = readdir($handler) if(is_dir( $path/$tmp ) if ($tmp=. | $tmp=.) continue; echo $tmp.n; dir_all ($path/$tmp); else echo $tmp .n; 8.写出匹配邮箱地址和URL的两个正则表达式。类似下面的:邮箱地址:user_URL地址:/user_profile.php?uid=100 (提示:使用标准的正则表达式,就是PHP中preg_* 类的正则处理函数能够解析的正则)邮箱:/w+(-+.w+)*w+(-.w+)*.w+(-.w+)*/URL:/http:/w+.w+S*/六、数据库技术题6.写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)MyISAM、InnoDB、BDB(Berkeley DB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB 等等十几个引擎7.说出你所知道的三种以上开源数据库的名称(提示:想想目前国外流行的开源数据库)MySQL、SQLite、BDB(Berkeley DB)、PostgreSQL、Firebird8.MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?Varchar是变长,节省存储空间,char是固定长度。查找效率要char型快,因为varchar是非定长,必须先查找长度,然后进行数据的提取,比char定长类型多了一个步骤,所以效率低一些9.说出MySQL 4.0和MySQL 4.1版本的最主要的两个区别。如果你使用过MySQL 5,请说说MySQL 5跟MySQL 4的主要区别。(后半题选作)MySQL 4.1 主要是比MySQL 4.0多了子查询和字符编码的支持两个特点。MySQL5增加的功能比MySQL4要更多,包括存储过程、视图、事务等等10.MySQL数据库基本的三个优化法则是什么,除了增加硬件和带宽?(提示:从服务配置、应用、开发角度考虑)(1)系统服务优化,把MySQL的key_buffer、cache_buffer、query_cache等增加容量(2)给所有经常查询的字段增加适当的索引(3)优化SQL语句,减少Ditinct、Group、Join等等语句的操作七、综合技术题14.请使用JavaScript写出三种产生一个Image 标签的方法(提示:从方法、对象、HTML角度考虑)(1)var img = new Image();(2)var img = document.createElementById(“image”)(3)img.innerHTML = “”15.请使用CSS样式,描述两种方法在当前列中只显示一个div对象(1)(2)16.请描述出两点以上XHTML和HTML最显著的区别(1)XHTML必须强制指定文档类型DocType,HTML不需要(2)XHTML所有标签必须闭合,HTML比较随意17.出五种以上你使用过的PHP的扩展的名称(提示:常用的PHP扩展)MB_Sring、Iconv、Curl、GD、SHM、libxml、socket、MySQL、PDO 等等18.了解MVC模式吗?请写出三种以上目前PHP流行的MVC框架名称(不区分大小写)FleaPHP、Zend Framework、CakePHP、Symfony、Plite、php.MVC、PHP on Trax、Smutty 等等19.写出10个以上你所知道的常用的Linux命令和它的功能Ls 列目录Cp 复制Rm 删除Mkdir 建立目录Cd 切换目录Ps 查看进程Top 查看机器使用情况20.使用过Vim编辑器吗?如果使用过,如何在vim里切分多个可视化窗口,包括横排和纵排。(本题选作)横:split(sp)纵:vsplit(vsp)21.说说Linux下的find命令和grep命令的区别(本题选作)Find:按照文件名查找Grep:按照文件内容查找22.请描述出OSI七层网络模型的名称,由下到上(可以使用中文描述)物理层、数据链路层、网络层、传输层、会话层、表示层、应用层23.说说下面这些这些协议的全称和中文解释(提示:都是工作在应用层)SMTP、POP3、HTTP、FTP、DNSSMTP (Simple Mail Transfer Protocol) 简单邮件传输协议POP3 (Post Office Protocol 3) 邮局协议第3版HTTP (Hypertext Transfer Protocol) 超文本传输协议FTP (File Transfer Protocol)文件传输协议DNS (Domain Name

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论