函数总结:

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

数组:

1.数组转换为字符串:  implode(',',$arr);

  字符串转换为数组:  explode(',',$arr);

2.sort($aa);  只能对数组进行排序

3.count — 计算【数组】中的单元数目或对象中的属性个数

字符串

strlen — 获取字符串长度

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

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

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

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”

$arr = "154287";
$long=strlen($arr);
for($i=0;$i<6;$i++){
$str[] = $arr[$i];
}
sort($str);
$j=$long-1;
for($j;$j>=0;$j--){
$myarr[]=$str[$j];
}
$a=implode(',',$myarr);
echo $a;

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;

邓_php_笔试!!!的更多相关文章

  1. C++常见笔试面试要点以及常见问题

    1. C++常见笔试面试要点: C++语言相关: (1) 虚函数(多态)的内部实现 (2) 智能指针用过哪些?shared_ptr和unique_ptr用的时候需要注意什么?shared_ptr的实现 ...

  2. 满堂红CIO邓劲翔:房屋中介突围

    人脸识别.客户关系管理进度监控.业务流程实时监控.网站访问人数及流量实时监控等实际企业应用场景淋漓尽致.羽羽如生的以大屏幕上图表形式展现在人们面前,如果你不去继续询问,你不会知道这是一家才刚刚在房地产 ...

  3. 2016网易春招Java在线笔试回忆录

    别看是在线笔试,但是非常严格,全称窗口不得最小化和关闭,转移,全称需要打开摄像头监控,使用草稿纸需要摄像头对准……反正2个小时,题量在那儿摆着,有作弊的功夫不如好好做做最后的编程题呢……网易不让泄漏原 ...

  4. BAT及各大互联网公司2014前端笔试面试题--Html,Css篇

    很多面试题是我自己面试BAT亲身经历碰到的.整理分享出来希望更多的前端er共同进步吧,不仅适用于求职者,对于巩固复习前端基础更是大有裨益. 而更多的题目是我一路以来收集的,也有往年的,答案不确保一定正 ...

  5. BAT及各大互联网公司2014前端笔试面试题--JavaScript篇

    很多面试题是我自己面试BAT亲身经历碰到的.整理分享出来希望更多的前端er共同进步吧,不仅适用于求职者,对于巩固复习js更是大有裨益. 而更多的题目是我一路以来收集的,也有往年的,答案不确保一定正确, ...

  6. 邓白氏码的申请-iOS公司开发者账号准备

    相比较个人开发者账号的申请,公司(or企业)的账号申请要稍显复杂,很关键的一点就是邓白氏码的申请,而在网上找了好久也没有找到相对系统的方法流程.因此, 用本文记录我在公司申请邓白氏码过程,以备之后不时 ...

  7. 申请邓白氏编码的时候总是提示 Enter a valid Street Address 怎么办?

    今天要申请一个苹果开发者公司(Company)账号,然后需要邓白氏编码,然后填写企业的基本信息.其中对于Street Address认真的对照着中文翻译为如下格式: Kang Hesheng buil ...

  8. iOS-申请邓白氏编码的超详细流程介绍

    导读 11.22号要申请苹果公司开发者账号,所以当天下午申请了邓白氏编码,昨天邓白氏编码下来了,这里就做一下记录,分享给大家. 概览 11.22提交的邓白氏编码申请,11.28(礼拜一)华夏邓白氏发来 ...

  9. IT求职中,笔试、面试的算法准备

    PS:此文章为转载,源地址:http://www.newsmth.net/nForum/#!article/CoderInterview/849     作者应该是在美国进行的笔试面试,感觉面试的的公 ...

随机推荐

  1. redis 写入的时候报错

    redis 写入报错 1)报错内容 Exception in thread "main" redis.clients.jedis.exceptions.JedisDataExcep ...

  2. GpG使用指南

    1. 简介 1991年,程序员Phil Zimmermann为了避开政府监视,开发了加密软件PGP.这个软件非常好用,迅速流传开来,成了许多程序员的必备工具.但是,它是商业软件,不能自由使用.所以,自 ...

  3. [js高手之路] vue系列教程 - vue的基本用法与常见指令(1)

    本系列课程选用vue的版本为1.0.21, 什么是vue? vue是由尤雨溪开发的一款基于MVVM的框架,M->模型,V->视图, 也就是说模型数据改变了,视图也跟着改变, 视图内容改变, ...

  4. SQL Server Service Broker创建单个数据库会话

    概述 SQL Server Service Broker 用来创建用于交换消息的会话.消息在目标和发起方这两个端点之间进行交换.消息用于传输数据和触发消息收到时的处理过程.目标和发起方既可以在同一数据 ...

  5. Gulp自动化构建工具的简单使用

    相关网站 gulp官方网址:http://gulpjs.com gulp中文网站:http://www.gulpjs.com.cn/ gulp插件地址:http://gulpjs.com/plugin ...

  6. 别纠结mybatis啦,赶紧来瞅瞅吧

    自从用了mybatis后,被坑的次数不下于无数次,今天我们就来说说最最头疼的错误,看看有多少人入过这个坑呢. 当程序出现了 Result Maps collection already contain ...

  7. AVFoundation 框架初探究(二)

    接着第一篇总结 系列第一篇地址:AVFoundation 框架初探究(一) 在第一篇的文章中,我们总结了主要有下面几个点的知识: 1.对AVFoundation框架整体的一个认识 2.AVSpeech ...

  8. 【NOIP2012】旅行计划

    题解 双向链表加倍增... 正写着不一定能写对2333 终于写对了... 然而我的双向链表和别人的都不一样... 瑟瑟发抖... 代码 //by 减维 #include<cstdio> # ...

  9. 聊聊ThreadLocal原理以及使用场景-JAVA 8源码

    相信很多人知道ThreadLocal是针对每个线程的,但是其中的原理相信大家不是很清楚,那咱们就一块看一下源码. 首先,我们先看看它的set方法.非常简单,从当前Thread中获取map.那么这个ge ...

  10. 牛客网linux试题-错误整理-20171013

    创建对象时,对象的内存和指向对象的指针分别分配在:堆区,栈区 堆内存用来存放由new创建的对象和数组,在堆中产生了一个数组或对象后,还可以在栈中定义一个特殊的变量,让栈中这个变量的取值等于数组或对象在 ...