邓_php_笔试!!!

函数总结:

----------------------------------------------------------------------

数组:

implode(',',$arr); //数组转字符串
explode(',',$arr); //字符串转数组

$arr = array(2,33,8,9,6,77);
  sort($arr);
  asort($arr);
  rsort($arr);

 count($arr);

字符串

strlen — 获取字符串长度

$str = '2,6,8,9,33,77';

  $len = strlen($str);  //获取字符串长度

  $str = substr($str,'3',-2);  //字符串截取

$subject = '000a111b222';
$search = array('a', 'b');
$replace = array('ccc', 'ddd');
$output = str_replace($search, $replace, $subject);

$output = str_replace(  原来字符串中的值 ,  替换后的值  ,   $str  );
echo $output;

 

$a="a'b'cd";
$b='qwe';
echo addslashes($a);    //ab\'cd

----------------------

strcasecmp  比较字符串大小

$var1 = "Hello";
$var2 = "hello";
if (strcasecmp($var1, $var2) == 0) {
    echo '$var1 is equal to $var2 in a case-insensitive string comparison';
}

----------------------------------------------------------------------

正则表达式

preg_match($pattern,$arr);

======================================================

笔试题

======================================================

 

<?php
header('Content-type:text/html;charset=utf-8');
1.定义一个常量 'NAME' ,值为'Linux';
define('NAME','Linux');
echo NAME;
// echo constant('NAME');

2.检查字符串的长度 和  3.检查数组的元素总数 分别用两个常用函数
$arr1 = 'abcdefg';
echo strlen($arr1);
$arr2 = array('a','b','c','d');
var_dump(count($arr2));

4.用PHP打印出前一天的时间 2016-9-10 22:21:12
echo date('Y-m-d h:i:s',time()-60*60*24);

5.将'$arr = array('james','tom','symfony')'
$arr = array('james','tom','symfony');
$a= implode(',',$arr);
var_dump($a);

6.$a='abcdef';截取$a 输出$a的第三个和第四个元素'cd'
$a='abcdef';
echo substr($a,'2','2');

7.最少的代码写一个求三个数字的最大值的函数,如传入三个数字3.5.8,返回最大值是8

function mymax($a,$b,$c){
  return $c>($a>$b?$a:$b)?$c:($a>$b?$a:$b);
}
echo mymax(20,50,5);


function my($a,$b,$c){
  $arr=$a.','.$b.','.$c;
  $str=explode(',',$arr);
  sort($str);
  $result=$str[count($str)-1];
  var_dump($result);
}
echo my(90,8,5);

8.写出函数创建长度为10 的数组,数组中的元素为递增的奇数,首项为1 ,
// 输出结果为array(Array ( [0] => 1 [1] => 3 [2] => 5 [3] => 7 [4] => 9 [5] => 11 [6] => 13 [7] => 15 [8] => 17 [9] => 19 )

 

for($i=0;$i<10;$i++){
$aa[]=$i*2+1;
}
// var_dump($aa);
print_r($aa)

 

 

9.写一个函数来实现字符串大小排序。如:“154287”排序成“875421”

  $str = '154287';
  function mysort($str){
      //计算字符串的长度
    $len = strlen($str);
      //进行循环,使之变成数组
    for($i=0;$i<$len;$i++){
      $myarr[$i] = substr($str,$i,1);
    }
    rsort($myarr); //逆向排序
    $result = implode('',$myarr);
    return $result;
  }


  echo mysort($str);

10.用正则表达式写一个电子邮件aaa@xx.com

  $arr="1415551519@qq.com";

  $pattern="/^[a-zA-Z0-9]+@[a-z]+\.[a-z0-9]+$/";
  $a=preg_match($pattern,$arr);
  echo $a;

 

 11.假设a.html和b.html在同一个文件夹下面,用javascript实现当打开a.html五秒钟后,自动跳转到b.html。

  function go2b(){
  window.location = “b.html”;
  window.close();
  }

  setTimeout( “go2b()”,5000 ); //5秒钟后自动执行go2b()

 12.冒泡排序法的基本思想是:对待排序记录关键字从后往前(逆序)进行多遍扫描,当发现相邻两个关键字的次序与排序要求的规则不符时,就将这两个记录进行交换。这样,关键字较小的记录将逐渐从后面向前面移动,就象气泡在水中向上浮一样,所以该算法也称为气泡排序法。

// 冒泡排序
function mysort($arr){
  for($i=0;$i<count($arr);$i++){
    for($j=0;$j<count($arr)-$i-1;$j++){
      if($arr[$j]>$arr[$j+1]){
        $tem = $arr[$j];
        $arr[$j] = $arr[$j+1];
        $arr[$j+1] = $tem;
      }
    }
  }
return $arr;
}
$arr=array(3,1,5,20,2,88,60);
var_dump(mysort($arr));

 13.把 John 新增到 users 阵列?

  $users[] = ‘john’; array_push($users,‘john’);

 14.用PHP写出显示客户端IP与服务器IP的代码

  答:打印客户端IP:echo $_SERVER[‘REMOTE_ADDR’]; 或者: getenv(‘REMOTE_ADDR’);

  打印服务器IP:echo gethostbyname(“www.bolaiwu.com”)

15.如何修改SESSION的生存时间(1分).

  答:方法1:将php.ini中的session.gc_maxlifetime设置为9999重启apache

  方法2:$savePath = “./session_save_dir/”;

  $lifeTime = 小时 * 秒;

  session_save_path($savePath);

  session_set_cookie_params($lifeTime);

  session_start();

  方法3:setcookie() and session_set_cookie_params($lifeTime);

 16.有一个网页地址, 比如PHP开发资源网主页: http://www.phpres.com/index.html,如何得到它的内容?($1分)

  答:方法1(对于PHP5及更高版本):

  $readcontents = fopen(“http://www.phpres.com/index.html”, “rb”);

  $contents = stream_get_contents($readcontents);

  fclose($readcontents);

  echo $contents;

  方法2:

  echo file_get_contents(“http://www.phpres.com/index.html”);

  

  echo file_get_contents("http://www.360doc.com/content/17/0821/21/46637018_681070212.shtml");

17.请说明php中传值与传引用的区别。什么时候传值什么时候传引用?(2分)

  答:按值传递:函数范围内对值的任何改变在函数外部都会被忽略

  按引用传递:函数范围内对值的任何改变在函数外部也能反映出这些修改

  优缺点:按值传递时,php必须复制值。特别是对于大型的字符串和对象来说,这将会是一个代价很大的操作。

  按引用传递则不需要复制值,对于性能提高很有好处。

 18.写一个函数,尽可能高效的,从一个标准 url 里取出文件的扩展名

  例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php
  答案1:
  function getExt($url){
  $arr = parse_url($url);
  $file = basename($arr['path']);
  $ext = explode(“.”,$file);
  return $ext[1];
  }
  答案2:
  function getExt($url) {
  $url = basename($url);
  $pos1 = strpos($url,”.”);
  $pos2 = strpos($url,”?”);
  if(strstr($url,”?”)){
  return substr($url,$pos1 + 1,$pos2 – $pos1 – 1);
  } else {
  return substr($url,$pos1);
  }
  }

19.使用五种以上方式获取一个文件的扩展名

  要求:dir/upload.image.jpg,找出 .jpg 或者 jpg ,

  必须使用PHP自带的处理函数进行处理,方法不能明显重复,可以封装成函数,比如 get_ext1($file_name), get_ext2($file_name)

  function get_ext1($file_name){
    return strrchr($file_name, ‘.’);
  }

  function get_ext2($file_name){
    return substr($file_name, strrpos($file_name, ‘.’));
  }

  function get_ext3($file_name){
    return array_pop(explode(‘.’, $file_name));
  }

  function get_ext4($file_name){
    $p = pathinfo($file_name);
    return $p['extension'];
  }

  function get_ext5($file_name){
    return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), ‘.’)));
  }

20.

//快速排序(数组排序)
  function quicksort($array) {
  if (count($array) <= 1) return $array;
  $key = $array[0];
  $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);
  }

 

 

 

 

 

 

 

 

 

 

 

 --------------------------------------------------------------

// $a="hello";
// $b=&$a;
// unset($b);
// // $b="word";
// echo $a;
// // echo $b;

 

posted @ 2017-08-20 21:15  林间有风-邓  阅读(412)  评论(0编辑  收藏  举报