PHP 面试题二
1、抓取远程图片到本地,你会用什么函数?
fsockopen, A
2、用最少的代码写一个求3值最大值的函数.
- function get_max($a,$b,$c) {
- return ($a > $b ? $a : $b) > $c ? ($a > $b ? $a : $b) : $c;
- }
4、javascript能否定义二维数组,如果不能你如何解决?
- javascript不支持二维数组定义,可以用arr[] = new array()来解决
5、假设a.html和b.html在同一个文件夹下面,用javascript实现当打开a.html五秒钟后,自动跳转到b.html。
- function test(){
- window.location = "b.html";
- window.close();
- }
setTimeout( "test()",5000 ); //5秒钟后自动执行test()
8、写一个函数,能够遍历一个文件夹下的所有文件和子文件夹。
- <?php
- function my_dir($dir){
- $files=array();
- //注意这里要加一个@,不然会有warning错误提示
- if(@$handle=opendir($dir)){
- while(($file=readdir($handle))!==false){
- //排除根目录;
- if($file!=".." && $file!="."){
- //如果是子文件夹,就进行递归 ;不是就将文件的名字存入数组;
- if(is_dir($dir."/".$file)){
- $files[$file]=my_dir($dir."/".$file);
- }else{
- $files[]=$file;
- }
- }
- }
- closedir($handle);
- return $files;
- }
- }
- //以下是测试
- $array=my_dir('C:/test');
- var_dump($array);
9、把 John 新增到 users 阵列?
- $users[] = 'join';
array_push($users, 'john');
10、在PHP中error_reporting这个函数有什么作用?
- error_reporting() 设置 PHP 的报错级别并返回当前级别。
16、写一个函数,尽可能高效的,从一个标准 url 里取出文件的扩展名
例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php
- <?php
- function getExt($url){
- $arr = parse_url($url); // 解析url为数组
- $file = basename($arr['path']); // $arr['path'] = "/abc/de/fg.php";
- $ext = explode(".",$file); // $file = "fg.php"; explode拆分字符串,返回一个数组
- return $ext[1];
- }
17、使用五种以上方式获取一个文件的扩展名;要求:dir/upload.image.jpg,找出 .jpg 或者 jpg ,
必须使用PHP自带的处理函数进行处理,方法不能明显重复,可以封装成函数,比如 get_ext1($file_name), get_ext2($file_name)
- // 方法1:
function get_ext1($file_name){- return strrchr($file_name, '.');
- }
- // 方法2:
- function get_ext2($file_name){
- return substr($file_name, strrpos($file_name, '.'));
- }
- // 方法3:
- function get_ext3($file_name){
- return array_pop(explode('.', $file_name));
- }
- // 方法4:
- function get_ext4($file_name){
- $p = pathinfo($file_name);
- return $p['extension'];
- }
- // 方法5:
- function get_ext5($file_name){
- return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), '.')));
}
- 18、以下代码的输出结果是?
- $str1 = null;
$str2 = false;
echo $str1 == $str2 ? '相等' : '不相等'; // 相等
- $str3 = ' ';
- $str4 = ;
- echo $str3 == $str4 ? '相等' : '不相等'; // 相等
- $str5 = ;
- $str6 = ’′;
- echo $str5 === $str6 ? '相等' : '不相等'; // 不相等
19、MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?
- Varchar是变长,节省存储空间,char是固定长度。
- 查找效率: char类型快,因为varchar是非定长,必须先查找长度,然后进行数据的提取,比char定长类型多了一个步骤,所以效率低一些
20、PHP 数组排序
- sort() - 以升序对数组排序
- rsort() - 以降序对数组排序
- asort() - 根据值,以升序对关联数组进行排序
- ksort() - 根据键,以升序对关联数组进行排序
- arsort() - 根据值,以降序对关联数组进行排序
- krsort() - 根据键,以降序对关联数组进行排序
21、一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号
- 方法1:
- function King($n,$m) {
- $res=;
- for($i=; $i<=$n; $i++) {
- $res=($res+$m)%$i;
- }
- return $res+;
- }
- $leader = King(,);
- echo $leader;
- //方法2,定义函数
- function getKing($monkeys , $m , $current = ){
- $number = count($monkeys);
- $num = ;
- if(count($monkeys) == ){
- echo '<font color="red">编号为'.$monkeys[].'的猴子成为猴王了!</font>';
- return;
- }else{
- while($num++ < $m){
- $current++;
- $current = $current%$number;
- }
- echo "编号为".$monkeys[$current]."的猴子被踢掉了...<br/>";
- array_splice($monkeys , $current , );
- getKing($monkeys, $m , $current);
- }
- }
- $n=; //总共猴子数目
- $m = ; //数到第几只的那只猴子被踢出去
- $monkeys = range(,$n); //将猴子编号放入数组中
- getKing($monkeys , $m); //调用函数
28、使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?
- Memcahce是把所有的数据保存在内存当中,采用hash表的方式,每条数据又key和value组成,每个key是独一无二的,当要访问某个值的时候先按照找到值,然后返回结果。
- Memcahce采用LRU算法来逐渐把过期数据清除掉。
21、16.请描述出两点以上XHTML和HTML最显著的区别
(1)XHTML必须强制指定文档类型DocType,HTML不需要
(2)XHTML所有标签必须闭合,HTML比较随意
22、写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。
- //冒泡排序(数组排序)
function bubbleSort($arr){
// 统计所有元素
$len = count($arr);
for($i = 0; $i < $len; $i++) {
for($k = $i+1; $k < $len; $k++) {
if($arr[$i] > $arr[$k]) {
$t = $arr[$k];
$arr[$k] = $arr[$i];
$arr[$i] = $t;
}
}
}
return $arr;
}
23、写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)
- MyISAM、InnoDB、BDB(Berkeley DB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB 等等十几个引擎
24、求两个日期的差数,例如2007-2-5 ~ 2007-3-6 的日期差数
- 方法1:
- function get_days($date1, $date2) {
- $time1 = strtotime($date1);
- $time2 = strtotime($date2);
- return ($time2-$time1)/;
- }
- echo get_days(’--′, ’--′);
- 方法2:
- $temp = explode('-', '2007-2-5');
- $time1 = mktime(, , , $temp[], $temp[], $temp[]);
- $temp = explode('-', '2007-3-6');
- $time2 = mktime(, , , $temp[], $temp[], $temp[]);
- echo ($time2-$time1)/;
- 方法3:
- echo abs(strtotime("2007-2-1")-strtotime("2007-3-1"))/// 计算时间差
25、请写一个函数,实现以下功能:字符串“open_door” 转换成 “OpenDoor”、”make_by_id” 转换成 ”MakeById”。
- // 方法一
- function str_explode($str){
- $str_arr=explode("_", $str);
- $str_implode=implode(" ",$str_arr);
- $str_implode=implode("",explode("",ucwords($str_implode)));
- return $str_implode;
- }
- $strexplode = str_explode("make_by_id");
- print_r($strexplode);
- // 方法二
- $str = "make_by_id!";
- $expStr = explode("_", $str);
- for($i=0;$i<count($expStr);$i++){
- echo ucwords($expStr[$i]);
- }
- // 方法三
- echo str_replace(' ', '', ucwords(str_replace('_', ' ', 'open_door')));// 替换掉_后,首字母大写,替换掉空格
26、一个表中的Id有多个记录,把所有这个id的记录查出来,并显示共有多少条记录数,用SQL语句及视图、
存储过程分别实现。
DELIMITER //
create procedure proc_countNum(in columnId int,out rowsNo int)
begin
select count(*) into rowsNo from member where member_id=columnId;
end
call proc_countNum(1,@no);
select @no;
方法:视图:
create view v_countNum as select member_id,count(*) as countNum from member group by
member_id
select countNum from v_countNum where member_id=1
27、js中网页前进和后退的代码
- 前进: history.forward();=history.go();
- 后退: history.back();=history.go(-);
28、下列代码输出什么?
echo count(null); // 0
echo count(' '); // 1
echo count(false); // 1
echo count('abc'); // 1
- count — 计算数组中的单元数目或对象中的属性个数
- int count ( mixed$var [, int $mode ] ), 如果 var 不是数组类型或者实现了 Countable 接口的对象,将返回1,有一个例外,如果 var 是 NULL 则结果是 。
- 对于对象,如果安装了 SPL,可以通过实现 Countable 接口来调用 count()。该接口只有一个方法 count(),此方法返回 count() 函数的返回值。
32. php class中static,public,private,protected的区别?
- static 静态,类名可以访问
- public 表示全局,类内部外部子类都可以访问;
- private 表示私有的,只有本类内部可以使用;
- protected 表示受保护的,只有本类或子类或父类中可以访问;
33. HTTP协议中GET、POST和HEAD的区别?
- HEAD: 只请求页面的首部。
- GET: 请求指定的页面信息,并返回实体主体。
- POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。
- ()HTTP 定义了与服务器交互的不同方法,最基本的方法是 GET 和 POST。事实上 GET 适用于多数请求,而保留 POST 仅用于更新站点。
- ()在FORM提交的时候,如果不指定Method,则默认为GET请 求,Form中提交的数据将会附加在url之后,以?分开与url分开。字母数字字符原样发送,但空格转换为“+“号,其它符号转换为%XX,其中XX为 该符号以16进制表示的ASCII(或ISO Latin-)值。GET请求请提交的数据放置在HTTP请求协议头中,而POST提交的数据则放在实体数据中;
- GET方式提交的数据最多只能有1024字节,而POST则没有此限制。
- ()GET 这个是浏览器用语向服务器请求最常用的方法。POST这个方法也是用来传送数据的,但是与GET不同的是,使用POST的时候,数据不是附在URI后面传 递的,而是要做为独立的行来传递,此时还必须要发送一个Content_length标题,以标明数据长度,随后一个空白行,然后就是实际传送的数据。网 页的表单通常是用POST来传送的
PHP 面试题二的更多相关文章
- 数据库基础SQL知识面试题二
数据库基础SQL知识面试题二 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.选课系统SQL语法练习 course数据库中有以下四张表: •students表(学生表): si ...
- C/C++常考面试题(二)
网上看到的面经,说是dynamic_cast的实现,和RTTI的相关,这才发现原来对这个概念这么模糊,所以作了这个总结. C/C++常考面试题(二) RTTI(Runtime Type Informa ...
- php面试题二--解决网站大流量高并发方案(从url到硬盘来解决高并发方案总结)
php面试题二--解决网站大流量高并发方案(从url到硬盘来解决高并发方案总结) 一.总结 从外到内解决网站大流量高并发问题---从提交一个url开始(从用户按下搜索栏回车键开始) url最开始会到d ...
- php开发面试题---2、php常用面试题二(表单提交方式中的get和post有什么区别)
php开发面试题---2.php常用面试题二(表单提交方式中的get和post有什么区别) 一.总结 一句话总结: 数据位置:get参数在url里面,post在主体里面 数据大小:get几kb,pos ...
- C++经典面试题(二)
近期看一些面试题,认为假设自己被问到了,并不能非常利落的回答出来. 一是从来没有这个意识,二是没有认真的梳理下. 以下对这些题做出分析,哈!个人能力有限,当中难免有疏漏,欢迎大家补充咯. 11.引用与 ...
- JAVA面试题二
JAVA 综合面试题 2007-08-12 目录 Java面试题整理 9 Java面向对象 9 1. super()与this()的区别? 9 2. 作用域public,protected,priva ...
- Java面试题(二)
系统整理了一下有关Java的面试题,包括基础篇,javaweb篇,框架篇,数据库篇,多线程篇,并发篇,算法篇等等,陆续更新中.其他方面如前端后端等等的面试题也在整理中,都会有的. 注:文末有福利! 1 ...
- Java常考面试题(二)
序言 昨天刚开始的”每日5题面试“这类文章,感觉还不错,把一些平常看似懂了的东西,弄清楚了.就像什么是虚拟机?这个问题,看起来知道,但是要说出个所以然来,又懵逼了,经常回过头来看看做过的面试题,试着用 ...
- C# 面试题 二
1.进程和线程的区别 进程是系统进行资源分配和调度的单位:线程是CPU调度和分派的单位,一个进程可以有多个线程,这些线程共享这个进程的资源. 2.成员变量和成员函数前加static的作用 它们被称为常 ...
- python面试题(二)
最近参加了几场招聘,发现好多人的一些基础知识不是很扎实,做的题很多都是错误的,因此找了一些我们公司面试过程中的一些最基本的面试题供大家参考,希望各位都能找到一个好的工作.今天给大家先分享的是关于Pyt ...
随机推荐
- Codeforces 451D
题目链接 D. Count Good Substrings time limit per test 2 seconds memory limit per test 256 megabytes inpu ...
- 推荐一个 Laravel admin 后台管理插件
如何优雅的写代码,我想是每位程序员的心声.自从15年初第一次接触 Laravel 4.2 开始,我就迷上使用 Laravel 框架了.我一直都想找个时间好好写写有关 Laravel 的使用文章,由浅入 ...
- Python 使用BeautifulSoup模块抽取数据
- Liferay Model Hints
这篇文章主要介绍如何通过model hint 来修改liferay builder service生成数据库表中默认字段的长度. 1.什么是Model Hints? 它是对liferay builde ...
- 阿里工程师开发了一款免费工具,提升Kubernetes应用开发效率
对于使用了Kubernetes作为应用运行环境的开发者而言,在同一个集群中我们可以使用命名空间(Namespace)快速创建多套隔离环境,在相同命名空间下,服务间使用Service的内部DNS域名进行 ...
- addEventListener-第三个参数 useCapture
转载自:http://www.cftea.com/c/2008/10/MQ0U26KP565GNM5Q.aspaddEventListener-开始 addEventListener-事件流 addE ...
- 【python小随笔】进程池 multiprocessing.Pool的简单实现与踩过的坑
#导入进程模块 import multiprocessing #创建进程池 坑:一定要在循环外面创建进程池,不然会一直创建 pool = multiprocessing.Pool(30) for Si ...
- 解决“google快照无法打开”的简单而有效的方法~
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/yangle20081982/article/details/25892553 解决&q ...
- 2018-9-2-WPF-开发自动开机启动程序
title author date CreateTime categories WPF 开发自动开机启动程序 lindexi 2018-09-02 15:10:52 +0800 2018-9-2 14 ...
- JDK 8 中包列表及介绍
了解了Java 8中所有包的作用,对Java 8有了一个整体的了解,另外也是提高了自身的阅读能力.本文列出了Java 8中所有的包,并且对每一个包的功能做了简要的说明,希望对你有所帮助. ------ ...