zoukankan      html  css  js  c++  java
  • 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[0] = 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 = 0;
    echo $str3 == $str4 ? '相等' : '不相等';     // 相等
    
    $str5 = 0;
    $str6 = ’0′;
    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=0; 
        for($i=2; $i<=$n; $i++) {
            $res=($res+$m)%$i; 
        }
        return $res+1; 
    } 
    $leader = King(13,34);
    echo $leader;
    
    //方法2,定义函数
    function getKing($monkeys , $m , $current = 0){
        $number = count($monkeys);
        $num = 1;
        if(count($monkeys) == 1){
          echo '<font color="red">编号为'.$monkeys[0].'的猴子成为猴王了!</font>';
          return;
        }else{
      while($num++ < $m){
        $current++;
        $current = $current%$number;
      }
      echo "编号为".$monkeys[$current]."的猴子被踢掉了...<br/>";
      array_splice($monkeys , $current , 1);
      getKing($monkeys, $m , $current);
      }
    }
    $n=13; //总共猴子数目
    $m = 34; //数到第几只的那只猴子被踢出去
    $monkeys = range(1,$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)/86400;
    }
    echo get_days(’2007-2-5′, ’2007-3-6′);
    方法2:
    $temp = explode('-', '2007-2-5');
    $time1 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]);
    $temp = explode('-', '2007-3-6');
    $time2 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]);
    echo ($time2-$time1)/86400;
    方法3:
    echo abs(strtotime("2007-2-1")-strtotime("2007-3-1"))/60/60/24 计算时间差

    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(1);
    
    后退: history.back();=history.go(-1); 

    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 则结果是 0。
    对于对象,如果安装了 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的新的从属实体。
    
    (1)HTTP 定义了与服务器交互的不同方法,最基本的方法是 GET 和 POST。事实上 GET 适用于多数请求,而保留 POST 仅用于更新站点。
    
    (2)在FORM提交的时候,如果不指定Method,则默认为GET请 求,Form中提交的数据将会附加在url之后,以?分开与url分开。字母数字字符原样发送,但空格转换为“+“号,其它符号转换为%XX,其中XX为 该符号以16进制表示的ASCII(或ISO Latin-1)值。GET请求请提交的数据放置在HTTP请求协议头中,而POST提交的数据则放在实体数据中;
    
    GET方式提交的数据最多只能有1024字节,而POST则没有此限制。
    
    (3)GET 这个是浏览器用语向服务器请求最常用的方法。POST这个方法也是用来传送数据的,但是与GET不同的是,使用POST的时候,数据不是附在URI后面传 递的,而是要做为独立的行来传递,此时还必须要发送一个Content_length标题,以标明数据长度,随后一个空白行,然后就是实际传送的数据。网 页的表单通常是用POST来传送的
  • 相关阅读:
    从xib初始化的UIView如何继承?
    no implicit conversion of nil into String
    @synchronized(self) 加锁引起的Crash
    iOS手工Crash解析
    iOS线程While-True死循环会发生什么
    2019年新年总结
    218. The Skyline Problem-Hard
    ReplayKit 启动录制按钮 RPSystemBroadcastPickerView 的使用
    S212-搜索+字典树-212. Word Search II-(Hard)
    mybatis批量生成
  • 原文地址:https://www.cnblogs.com/seven-ahz/p/7823201.html
Copyright © 2011-2022 走看看