PHP程序员必须会的 45 个PHP 面试题(第三部分)

Souleigh ✨
• 阅读 1622

Q25:此代码将返回什么?解释结果。

主题:PHP
难度:⭐⭐⭐

考虑代码。结果将返回什么?

$something = 0;
echo ('password123' == $something) ? 'true' : 'false'; 

答案是true。您永远不要将其==用于字符串比较。即使将字符串与字符串进行比较,PHP也会将它们隐式转换为浮点数,并且如果它们看起来是数字,则进行数字比较。===还可以

例如

'1e3' == '1000' // true 

也返回true。

Q26:array_map,array_walk和array_filter之间到底有什么区别?

主题:PHP
难度:⭐⭐⭐

  • array_walk 接受一个数组和一个函数F,并通过用F(x)替换每个元素x对其进行修改。
  • array_map进行完全相同的操作,除了不代替就地修改,而是返回带有转换后元素的新数组。
  • array_filter使用函数F,而不是变换元素,将删除F(x)不为真的所有元素

Q27:解释exec()与system()与passthru()之间的区别?

主题:PHP 难度:⭐⭐⭐

  • exec() 用于调用系统命令,也许自己处理输出。
  • system() 用于执行系统命令并立即显示输出-大概是文本。
  • passthru() 用于执行您希望从中返回原始值的系统命令-大概是二进制文件。

Q28:您将如何使用PHP创建Singleton类?

主题:PHP
难度:⭐⭐⭐

/**
 * Singleton class
 *
 */
final class UserFactory {
    /**
     * Call this method to get singleton
     *
     * @return UserFactory
     */
    public static
    function Instance() {
        static $inst = null;
        if ($inst === null) {
            $inst = new UserFactory();
        }
        return $inst;
    }

    /**
     * Private ctor so nobody else can instantiate it
     *
     */
    private
    function __construct() {

    }
} 

使用方法:

$fact = UserFactory::Instance();
$fact2 = UserFactory::Instance(); 

但:

$fact = new UserFactory() 

引发错误。

Q29:PDO的query()与execute()有什么区别?

主题:PHP
难度:⭐⭐⭐

  • query 运行标准SQL语句,并要求您正确转义所有数据,以避免SQL注入和其他问题。
  • execute运行一个准备好的语句,该语句使您可以绑定参数,以避免需要转义或引用参数。如果多次重复查询,execute也将表现更好。

最佳实践是坚持准备好的语句并执行以提高_安全性_。除了在客户端提供转义功能外,_准备好的语句_在服务器端_也会编译_一次,然后可以在每次执行时传递不同的参数。

Q30:空合并运算符的用途是什么?

主题:PHP
难度:⭐⭐⭐

空合并运算符如果存在且不为NULL,则返回其第一个操作数。否则,它将返回其第二个操作数。

例:

$name = $firstName ?? $username ?? $placeholder ?? "Guest"; 

Q31:区分异常和错误

主题:PHP
难度:⭐⭐⭐

  • Error无法从中恢复。错误的唯一解决方案是终止执行。Exception通过使用try-catch块或将异常抛出给调用者,您可以从中恢复
  • 您将无法处理Errors使用try-catch块。即使您使用try-catch块处理它们,如果它们发生,您的应用程序也将无法恢复。另一方面,Exceptions可以使用try-catch块进行处理,并且可以使程序流程正常(如果发生)。
  • ExceptionsErrors运行应用程序的环境有关的应用程序有关。

Q32:什么是异常类函数?

主题:PHP
难度:⭐⭐⭐

Exception类中可以使用以下功能。

  • getMessage() −例外消息
  • getCode() −例外代码
  • getFile() -源文件名
  • getLine() −源代码行
  • getTrace() − n个数组 backtrace()
  • getTraceAsString() −格式化的跟踪字符串
  • Exception::__toString 给出异常的字符串表示形式。

Q33:区分参数化和非参数化功能

主题:PHP
难度:⭐⭐⭐

  • 参数化的函数在调用时不接受任何参数。
  • 参数化函数在调用时采用一个或多个参数。当输出取决于运行时给定的动态值时,可以在程序的运行时使用它们。有两种方法可以访问参数化函数:
  1. _按值调用_:(这里我们直接传递值)
  2. _按引用调用_:(这里我们传递存储值的地址位置)

Q34:通过引用解释函数调用

主题:PHP
难度:⭐⭐⭐

在通过引用调用的情况下,如果在函数内部修改了实际值,则将对其进行修改。在这种情况下,我们需要使用&带形式参数的符号。在&表示可变的参考。

例:

function adder(&$str2) {  
    $str2 .= 'Call By Reference';  
}
$str = 'This is ';  
adder($str);  
echo $str; 

输出:

This is Call By Reference 

Q35:为什么我们使用extract()?

主题:PHP
难度:⭐⭐⭐

extract()函数将变量从数组导入局部符号表。

此函数将数组键用作变量名,将值用作变量值。对于每个元素,它将在当前符号表中创建一个变量。

此函数返回成功提取的变量数。

例:

$a = "Original";
$my_array = array("a" => "Cat","b" => "Dog", "c" => "Horse");
extract($my_array);
echo "\$a = $a; \$b = $b; \$c = $c"; 

输出:

$a = Cat; $b = Dog; $c = Horse 

Q36:解释什么是PHP闭包,为什么它使用“ use”标识符?

主题:PHP
难度:⭐⭐⭐⭐

考虑以下代码:

public function getTotal($tax)
{
    $total = 0.00;

    $callback =
        function ($quantity, $product) use ($tax, &$total)
        {
            $pricePerItem = constant(__CLASS__ . "::PRICE_" .
                strtoupper($product));
            $total += ($pricePerItem * $quantity) * ($tax + 1.0);
        };

    array_walk($this->products, $callback);
    return round($total, 2);
} 

您能解释一下为什么使用它吗?


这就是PHP表示闭包的方式。基本上,这意味着您允许匿名函数在其作用域_之外_“捕获”局部变量(在本例中为,$tax并引用$total)并保留其值(或在PHP程序员必须会的 45 个PHP 面试题(第三部分) total本身的引用) )作为匿名函数本身内的状态。

闭包是一个单独的命名空间,通常,您不能访问此命名空间之外定义的变量。

  • use 允许您访问(使用)闭包内部的后续变量。
  • use是早期的约束力。这意味着在定义闭包时将复制变量值。因此,在闭包内部修改$ tax不会产生外部影响,除非它像对象一样是指针。
  • 您可以像的情况一样将变量作为指针传递&$total。这样,修改$totalDOES的值会产生外部影响,原始变量的值会更改。

Q37:PHP中最新的静态绑定到底是什么?

主题:PHP
难度:⭐⭐⭐⭐

基本上,可以归结为以下事实:self关键字不遵循相同的继承规则。self始终解析为使用它的类。这意味着,如果您在父类中创建方法并从子类中调用该方法,self则不会像您期望的那样引用该子项。

后期静态绑定引入了static关键字的新用法,从而解决了这一特殊缺点。当您使用时static,它代表您第一次使用它的类,即。它“绑定”到运行时类。

考虑:

class Car {
    public static
    function run() {
        return static::getName();
    }

    private static
    function getName() {
        return 'Car';
    }
}

class Toyota extends Car {
    public static
    function getName() {
        return 'Toyota';
    }
}

echo Car::run(); // Output: Car
echo Toyota::run(); // Output: Toyota 

Q38:如何衡量PHP脚本的执行时间?

主题:PHP
难度:⭐⭐⭐⭐

我想知道执行一次PHP while循环需要多少毫秒。你可以帮帮我吗?


您可以使用此microtime功能。

考虑:

$start = microtime(true);
while (...) {

}
$time_elapsed_secs = microtime(true) - $start; 

Q39:合并两个PHP对象的最佳方法是什么?

主题:PHP
难度:⭐⭐⭐⭐

//We have this:
$objectA->a;
$objectA->b;
$objectB->c;
$objectB->d;

//We want the easiest way to get:
$objectC->a;
$objectC->b;
$objectC->c;
$objectC->d; 

这有效:

$obj_merged = (object) array_merge((array) $obj1, (array) $obj2); 

你也可以使用array_merge_recursive有_深层复制_行为。

另一种方法是:

foreach($objectA as $k => $v) $objectB->$k = $v; 

这比<7版本的PHP中的第一个答案要快(估计要快50%)。但是在PHP> = 7中,第一个答案快了400%。

Q40:比较mysqli或PDO-优缺点是什么?

主题:PHP
难度:⭐⭐⭐⭐

让我们命名一些:

  • PDO是标准,这是大多数开发人员期望使用的标准。
  • 将应用程序从一个数据库迁移到另一个数据库并不是很常见,但是迟早您可能会发现自己正在使用不同的RDBMS处理另一个项目。如果您在家中使用PDO,那么到那时至少要少学习一件事。
  • 使用PDO的真正好处是您可以获取数据,并将其自动注入到对象中。
  • PDO具有一些有助于SQL注入的功能
  • 从执行速度的角度来看,MySQLi会胜出,但是除非您使用MySQLi有很好的包装器,否则它处理预准备语句的功能将很糟糕。插入-几乎相等,选择-mysqli是对于未准备好的报表,速度提高了2.5%/准备语句的速度提高了6.7%。

Q41:<=>运算符有什么用途?

主题:PHP
难度:⭐⭐⭐⭐

<=>运算符将提供组合比较,因为它将:

  • 如果任一侧的值_相等,_则返回0
  • 如果_左侧的值较大,_则返回1
  • 如果_右边_的值_更大,_则返回-1

考虑:

 //Comparing Integers
echo 1 <= > 1; //outputs 0
echo 3 <= > 4; //outputs -1
echo 4 <= > 3; //outputs 1

//String Comparison

echo "x" <= > "x"; // 0
echo "x" <= > "y"; //-1
echo "y" <= > "x"; //1 

Q42:PHP是否具有线程?

主题:PHP
难度:⭐⭐⭐⭐

标准php不提供任何多线程功能,但是有一个(实验性)扩展名实际上是- pthreads。第二个最好的办法是让一个脚本通过CLI执行另一个脚本,但这有点基本。根据您尝试执行的操作以及操作的复杂程度,这可能是,也可能不是。

Q43:PHP是单线程还是多线程?

主题:PHP
难度:⭐⭐⭐⭐
PHP本质上不是单线程的。但是,在这种情况下,Unix系统上最常见的PHP安装是单线程安装,最常见的Apache安装也是如此,而nginx则没有基于线程的体系结构。在最常见的Windows设置和一些更高级的Unix设置中,PHP可以并且确实在一个进程中操作多个解释器线程。
自2000年以来,PHP作为解释器就支持多线程。

Q44:提供一些方法来模仿PHP中的多个构造函数

主题:PHP
难度:⭐⭐⭐⭐⭐

众所周知,您不能在PHP类中放置两个具有唯一参数签名的__construct函数,但我想这样做:

class Student 
{
   protected $id;
   protected $name;
   // etc.

   public function __construct($id){
       $this->id = $id;
      // other members are still uninitialised
   }

   public function __construct($row_from_database){
       $this->id = $row_from_database->id;
       $this->name = $row_from_database->name;
       // etc.
   }
} 

用PHP实现此目的的最佳方法是什么?


我可能会做这样的事情:

 class Student
{
    public function __construct() {
        // allocate your stuff
    }

    public static function withID( $id ) {
        $instance = new self();
        $instance->loadByID( $id );
        return $instance;
    }

    public static function withRow( array $row ) {
        $instance = new self();
        $instance->fill( $row );
        return $instance;
    }

    protected function loadByID( $id ) {
        // do query
        $row = my_awesome_db_access_stuff( $id );
        $this->fill( $row );
    }

    protected function fill( array $row ) {
        // fill all properties from array
    }
} 

然后,如果我想要一个我知道ID的学生:

$student = Student::withID( $id ); 

从技术上讲,您不是在构建多个构造函数,而只是在构建静态辅助方法,而是通过这种方式避免在构造函数中使用大量意大利面条式代码。

另一种方法是结合使用工厂风格和流利风格

class Student
{
    protected $firstName;
    protected $lastName;
    // etc.

    /**
     * Constructor
     */
    public function __construct() {
        // allocate your stuff
    }

    /**
     * Static constructor / factory
     */
    public static function create() {
        $instance = new self();
        return $instance;
    }

    /**
     * FirstName setter - fluent style
     */
    public function setFirstName( $firstName) {
        $this->firstName = $firstName;
        return $this;
    }

    /**
     * LastName setter - fluent style
     */
    public function setLastName( $lastName) {
        $this->lastName = $lastName;
        return $this;
    }
}

// create instance
$student= Student::create()->setFirstName("John")->setLastName("Doe"); 

Q45:如何在PHP中实现方法重载?

主题:PHP
难度:⭐⭐⭐⭐⭐

您不能重载PHP函数。函数签名仅基于它们的名称,并且不包括参数列表,因此不能有两个具有相同名称的函数。

但是,您可以声明一个可变参量,该可变参函数接受可变数量的参数。您将使用func_num_args()func_get_arg()获取参数,并正常使用它们。

考虑:

function myFunc() {
    for ($i = 0; $i < func_num_args(); $i++) {
        printf("Argument %d: %s\n", $i, func_get_arg($i));
    }
}

/*
Argument 0: a
Argument 1: 2
Argument 2: 3.5
*/
myFunc('a', 2, 3.5); 

为了处理异常,代码可能被包围在一个try块中。

每个 try 必须至少有一个提示。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Stella981 Stella981
3年前
Ecshop用户中心的收藏列表里显示商品缩略图
1)、修改includes/lib\_clips.php文件将下面代码$sql'SELECTg.goods_id,g.goods_name,g.market_price,g.shop_priceASorg_price,'.修改为$sql'SELECTg.goods_id,g.goods_nam
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这