您好,欢迎访问三七文档
当前位置:首页 > 办公文档 > 模板/表格 > 2016年PHP最新笔试题(带答案)
PHP笔试题_答案一、基础及程序题(建议使用你擅长的语言:PHP、Java)1.写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。(提示:不能使用系统已有函数,另外请仔细回忆以前学习过的基础知识)//冒泡排序(数组排序)functionbubble_sort($array){$count=count($array);if($count=)returnfalse;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;}//快速排序(数组排序)functionquicksort($array){if(count($array)=1)return$array;$key=$array[];$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);returnarray_merge($left_arr,array($key),$right_arr);}2.实现一个字符串截取的函数,类似于substr,必须能够截取中文这种多字节编码。假设每个中文也是一个字符,普通的数字、符号、字母也是一个字符。(提示:GB编码的中文字符高位范围是x81-xFE)functionGBSubstr($str,$len){$count=;for($i=;$istrlen($str);$i++){if($count==$len)break;if(preg_match(/[/x8-/xff]/,substr($str,$i,1)))++$i;++$count;}returnsubstr($str,,$i);}functionGBSubstr2($src,$start=,$length=){$suffix=;$len=strlen($src);if($len=$length)return$src;$cut_length=;for($idx=;$idx$length;$idx++){$char_value=ord($src[$idx]);if($char_valuex8||($char_value&x4))$cut_length++;else$cut_length=$cut_length+3;}$curstr=substr($src,,$cut_length);preg_match('/^([/x-/x7f]|.{3})*/',$curstr,$result);return$result[];}functionCSubstr($str,$start=,$length,$charset=gbk,$suffix=false){if(function_exists(mb_substr)){returnmb_substr($str,$start,$length,$charset);}$re['utf-8']=/[/x1-/x7f]|[/xc2-/xdf][/x8-/xbf]|[/xe-/xef][/x8-/xbf]{2}|[/xf-/xff][/x8-/xbf]{3}/;$re['gb2312']=/[/x1-/x7f]|[/xb-/xf7][/xa-/xfe]/;$re['gbk']=/[/x1-/x7f]|[/x81-/xfe][/x4-/xfe]/;$re['big5']=/[/x1-/x7f]|[/x81-/xfe]([/x4-/x7e]|/xa1-/xfe])/;preg_match_all($re[$charset],$str,$match);$slice=join(,array_slice($match[],$start,$length));if($suffix){return$slice.…;}return$slice;}3.写一个遍历指定目录下所有子目录和子文件的函数(提示:可以使用递归的方法)functiondir_all($path){$handler=opendir($path);while(false!==($tmp=readdir($handler))){if(is_dir($path/$tmp)){if($tmp==.|$tmp==..)continue;echo$tmp.br/n;dir_all($path/$tmp);}else{echo$tmp.br/n;}}}4.写出匹配邮箱地址和URL的两个正则表达式。类似下面的:邮箱地址:user_name.first@example.com.cnURL地址:=1(提示:使用标准的正则表达式,就是PHP中preg_*类的正则处理函数能够解析的正则)邮箱://w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*/URL:/^http:////[/w]+/.[/w]+[/S]*/二、数据库技术题1.写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)MyISAM、InnoDB、BDB(BerkeleyDB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB等等十几个引擎2.说出你所知道的三种以上开源数据库的名称(提示:想想目前国外流行的开源数据库)MySQL、SQLite、BDB(BerkeleyDB)、PostgreSQL、Firebird3.MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?Varchar是变长,节省存储空间,char是固定长度。查找效率要char型快,因为varchar是非定长,必须先查找长度,然后进行数据的提取,比char定长类型多了一个步骤,所以效率低一些4.说出MySQL4.和MySQL4.1版本的最主要的两个区别。如果你使用过MySQL5,请说说MySQL5跟MySQL4的主要区别。(后半题选作)MySQL4.1主要是比MySQL4.多了子查询和字符编码的支持两个特点。MySQL5增加的功能比MySQL4要更多,包括存储过程、视图、事务等等5.MySQL数据库基本的三个优化法则是什么,除了增加硬件和带宽?(提示:从服务配置、应用、开发角度考虑)(1)系统服务优化,把MySQL的key_buffer、cache_buffer、query_cache等增加容量(2)给所有经常查询的字段增加适当的索引(3)优化SQL语句,减少Ditinct、Group、Join等等语句的操作三、综合技术题1.请使用JavaScript写出三种产生一个Image标签的方法(提示:从方法、对象、HTML角度考虑)(1)varimg=newImage();(2)varimg=document.createElement_xById(“image”)(3)img.innerHTML=“imgsrc=”xxx.jpg”/”2.请使用CSS样式,描述两种方法在当前列中只显示一个div对象(1)divstyle=”width:19999px;”/div(2)divstyle=”clear:both;”/div3.请描述出两点以上XHTML和HTML最显著的区别(1)XHTML必须强制指定文档类型DocType,HTML不需要(2)XHTML所有标签必须闭合,HTML比较随意4.写出五种以上你使用过的PHP的扩展的名称(提示:常用的PHP扩展)MB_Sring、Iconv、Curl、GD、SHM、libxml、socket、MySQL、PDO等等5.了解MVC模式吗?请写出三种以上目前PHP流行的MVC框架名称(不区分大小写)FleaPHP、ZendFramework、CakePHP、Symfony、Plite、php.MVC、PHPonTrax、Smutty等等6.写出5个以上你所知道的常用的Linux命令和它的功能Ls列目录Cp复制Rm删除Mkdir建立目录Cd切换目录Ps查看进程Top查看机器使用情况7.使用过Vim编辑器吗?如果使用过,如何在vim里切分多个可视化窗口,包括横排和纵排。(本题选作)横:split(sp)纵:vsplit(vsp)8.说说Linux下的find命令和grep命令的区别(本题选作)Find:按照文件名查找Grep:按照文件内容查找9.请描述出OSI七层网络模型的名称,由下到上(可以使用中文描述)物理层、数据链路层、网络层、传输层、会话层、表示层、应用层10.说说下面这些这些协议的全称和中文解释(提示:都是工作在应用层)SMTP、POP3、HTTP、FTP、DNSSMTP(SimpleMailTransferProtocol)简单邮件传输协议POP3(PostOfficeProtocol3)邮局协议第3版HTTP(HypertextTransferProtocol)超文本传输协议FTP(FileTransferProtocol)文件传输协议DNS(DomainNameSystemandDomainNameServiceprotocol)域名系统(服务)协议11.使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?(本题选作)Memcahce是把所有的数据保存在内存当中,采用hash表的方式,每条数据又key和value组成,每个key是独一无二的,当要访问某个值的时候先按照找到值,然后返回结果。Memcahce采用LRU算法来逐渐把过期数据清除掉。12.请大致的说说Session的工作原理。(提示:与Cookie有相应的关系)传说中,Web应用程序中的Session和Application保存服务器端,而cookie保存在客户端。其实Session同时存在于客户端与服务器端。开发中如果你已经写了一个Session,打开火狐浏览器,清理cookie的时候你会找到一个session_id(java开发者会看到JSESSIONID)的cookie,删除他后Session将失效。如果你打开的是IE浏览器,清理cookie后Session依然存在,我不知道IE是怎么处理的,也许它只从磁盘里去清理。Session实现原理1、创建Session的时候,服务器将生成一个唯一的sessionid然后用它生成一个关闭浏览器就会失效的cookie。2、然后再将一个与这个sessionid关联的数据项加入散列表。例如这样一段代码:Session[UserName]=23;假设sessionid为123那么散列表中会追加一行sessionidusername123233、当浏览器端提交到服务器时,会通过sessionid=123去散列表中寻找属于该用户的Session信息。13.说说你所了解的搜索引擎包含那些技术?(本题选作)爬虫(采集)、切词(分词)、索引(存储)、查询以及其他相关技术
本文标题:2016年PHP最新笔试题(带答案)
链接地址:https://www.777doc.com/doc-5734023 .html