PHP面试小结(20240108)

2024-01-12 22:44
文章标签 面试 php 小结 20240108

本文主要是介绍PHP面试小结(20240108),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PHP 部分


1. php的包管理工具是如何实现自动加载的

换句话问:composer 实现原理是什么?spl_autoload_register()

首先,Composer 是 PHP 的一个包管理和包依赖管理的工具 ,

打开安装之后生成的 "vendor" 文件, 里面有个 "autoload.php" 文件. 只要引入这个文件, 所有通过 Composer 安装的类库就会全部加载完成:

require(__DIR__.'/vendor/autoload.php');

如果以后需要新增类库

  • 第一种方法: 使用命令 composer require, 比如 composer require phpunit/phpunit:~5.7, 比如 composer require twbs/bootstrap:4.0.0-beta.3;
  • 第二种方法: 在 "composer.json" 文件中追加, 然后执行 composer update;                执行 composer update, 将会升级 composer.json 中所有可升级的类库, 并自动更新升级其依赖. 这将引发一种问题 -- 某些类库尽管不是最新版本, 但是运行很正常很稳定, 我们并不需要更新他们. 如果使用"全部更新", 会自动将这些运行稳定的旧版本类库升级到最新版本, 却可能引入新的 Bug 和不确定性, 因此推荐使用"指定更新", 慎用"全部更新"
{"require":{"cebe/markdown":"1.1.1","phpunit/phpunit":"5.7.5"}
}

composer install:根据composer.lock安装依赖包(如果存在),否则根据composer.json

composer update:根据composer.json更新依赖到指定范围内最新版,并更新composer.lock文件

链接:https://www.jianshu.com/p/5954fe55d067

composer 使用细则_composer 版本规则-CSDN博客

详解composer的自动加载机制-CSDN博客

1.1 补充:PHP 的自动加载机制

PHP 的自动加载机制允许在代码中使用类时,不用显式地包含这些类的文件。相反,PHP 根据一组规则来查找相关的文件并自动加载它们。

以下是 PHP 自动加载机制的原理:

1、注册自动加载函数
通过 spl_autoload_register() 函数注册一个或多个自动加载函数。每当代码需要使用一个尚未定义的类或接口时,PHP 就会按照注册的顺序依次调用这些自动加载函数,直到找到定义文件为止。

2、根据类名或接口名生成文件路径
自动加载函数会根据类名或接口名来生成对应的文件路径,例如:类名 MyClass 可能对应的文件路径是 /path/to/project/src/MyClass.php,接口名 MyInterface 可能对应的文件路径是 /path/to/project/src/MyInterface.php。

3、加载文件并定义类或接口
如果文件存在,自动加载函数会通过 require_once 或 include_once 等函数将文件加载到内存中,并定义其中的类或接口。

以下是一个实现自动加载的示例:

function my_autoloader($class) {include 'classes/' . $class . '.class.php';
}spl_autoload_register('my_autoloader');

以上代码定义了一个名为 my_autoloader() 的自动加载函数。该函数会在 classes/ 目录下查找与 $class 参数对应的类文件,并包含进来。然后,通过 spl_autoload_register() 函数将该自动加载函数注册到 PHP 自动加载机制中。

使用 PHP 自动加载机制可以让开发者更加方便地编写和组织代码,避免了手工包含类文件的繁琐过程。

PHP 的自动加载机制_php 自动加载-CSDN博客

2.PHP怎么动态调用类中的方法
方法一:反射机制

在 PHP 中,可以使用反射机制来动态地调用类中的方法。下面是一种常见的方式

// 定义一个示例类
class MyClass {public function myMethod($param) {echo "Hello, $param!";}
}// 创建对象并获取其类名称
$obj = new MyClass();
$className = get_class($obj);// 通过反射获取类的信息
$reflectionClass = new ReflectionClass($className);// 判断要调用的方法是否存在于该类中
if ($reflectionClass->hasMethod('myMethod')) {// 获取方法的引用$methodReflector = $reflectionClass->getMethod('myMethod');// 设置方法为公共(如果需要)if (!$methodReflector->isPublic()) {$methodReflector->setAccessible(true);}// 传递参数并调用方法$params = ['John'];$result = $methodReflector->invokeArgs($obj, $params);// 输出结果var_dump($result); //Hello, John!
} else {echo 'The method does not exist.';
}// 这段代码首先创建了一个 MyClass 类,然后通过反射获取到该类的信息。
// 接着,我们判断要调用的方法是否存在于该类中,若存在则获取方法的引用。最后,我们将参数传递给方法进行调用,并打印出返回值。
<?php
class HelloWorld
{public function sayHelloTo($name){return 'Hello ' . $name;}
}
$reflectionMethod = new ReflectionMethod('HelloWorld', 'sayHelloTo');
echo $reflectionMethod->invokeArgs(new HelloWorld(), array('Mike-2222')); //结果: Hello  Mike-2222
方法二: call_user_func函数

PHP中提供了call_user_func函数用于动态调用类方法。

call_user_func(array($object, $methodName), $arg1, $arg2, ...)

其中,$object为类的实例化对象,$methodName为要调用的方法名,$arg1, $arg2, ...为方法所需要的参数。

示例代码:

class User {public function getName($id){return "name".$id;}
}$user = new User();
$name = call_user_func(array($user, 'getName'), 100);
echo $name;

输出结果:

name100
方法三: 使用call_user_func_array函数

call_user_func函数类似,PHP中也提供了call_user_func_array函数用于动态调用类方法,并且可以通过一个数组来传递参数。

call_user_func_array(array($object, $methodName), $arguments)

其中,$object为类的实例化对象,$methodName为要调用的方法名,$arguments为一个数组,包含方法所需要的参数。

示例代码:

class User {public function getName($id, $type){return "name".$id."-".$type;}
}$user = new User();
$name = call_user_func_array(array($user, 'getName'), array(100, 'vip'));
echo $name;

输出结果:

name100-vip
方法四: 使用可变函数名称

PHP中一个较为简单的方法是使用可变函数名称来动态调用类方法。

$object->$methodName($arg1, $arg2, …)

其中,$object为类的实例化对象,$methodName为要调用的方法名称,$arg1, $arg2, …为方法所需要的参数。

示例代码:

class User {public function getName($id){return "name".$id;}
}$user = new User();
$name = $user->getName(100);
echo $name;

输出结果:

name100
总结

以上介绍了三种动态调用类方法的方法,分别使用call_user_funccall_user_func_array以及可变函数名称。在实际开发中,我们可以根据具体的情况来选择不同的方法。

注意,动态调用类方法可能会导致一些安全问题,特别是在接收外部参数时,务必要进行安全过滤。

参考:https://imangodoc.com/7pRurY5o.html

3.self,this 有什么区别
4.MySQL中查询逗号拼接的字段(有个字段值保存的是用逗号拼接的用户ID)
5.反射有什么用处
6.什么是单点登录,实现的核心点(站在前后端的角度)

1、门面使用

2、mysql主从同步,主从延迟问题

3.   redis主从复制,redis默认使用哪个库,其中一个库满了如何切换到另外一个库

4.负载均衡: iphash文件怎么配置

5.锁 如何添加

6.堆,栈介绍

Linux: 

1.查看进程启动目录

2.环境变量怎么配置

3.定时任务怎么查看和配置

4.在Linux上如何把一个PHP脚本使用守护京城的方式运行

5.运行命令是后面的> 和 >> 表示什么意思

6.手写lru 算法

这篇关于PHP面试小结(20240108)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/599399

相关文章

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

java面试常见问题之Hibernate总结

1  Hibernate的检索方式 Ø  导航对象图检索(根据已经加载的对象,导航到其他对象。) Ø  OID检索(按照对象的OID来检索对象。) Ø  HQL检索(使用面向对象的HQL查询语言。) Ø  QBC检索(使用QBC(Qurey By Criteria)API来检索对象。 QBC/QBE离线/在线) Ø  本地SQL检索(使用本地数据库的SQL查询语句。) 包括Hibern

分布式系统的个人理解小结

分布式系统:分的微小服务,以小而独立的业务为单位,形成子系统。 然后分布式系统中需要有统一的调用,形成大的聚合服务。 同时,微服务群,需要有交流(通讯,注册中心,同步,异步),有管理(监控,调度)。 对外服务,需要有控制的对外开发,安全网关。

PHP原理之内存管理中难懂的几个点

PHP的内存管理, 分为俩大部分, 第一部分是PHP自身的内存管理, 这部分主要的内容就是引用计数, 写时复制, 等等面向应用的层面的管理. 而第二部分就是今天我要介绍的, zend_alloc中描写的关于PHP自身的内存管理, 包括它是如何管理可用内存, 如何分配内存等. 另外, 为什么要写这个呢, 因为之前并没有任何资料来介绍PHP内存管理中使用的策略, 数据结构, 或者算法. 而在我们

php中json_decode()和json_encode()

1.json_decode() json_decode (PHP 5 >= 5.2.0, PECL json >= 1.2.0) json_decode — 对 JSON 格式的字符串进行编码 说明 mixed json_decode ( string $json [, bool $assoc ] ) 接受一个 JSON 格式的字符串并且把它转换为 PHP 变量 参数 json

如何将文件夹里的PHP代码放到一个文件里

find ./dir -name "*.php" -exec 'cat' {} \; > dir.out

PHP抓取网站图片脚本

方法一: <?phpheader("Content-type:image/jpeg"); class download_image{function read_url($str) { $file=fopen($str,"r");$result = ''; while(!feof($file)) { $result.=fgets($file,9999); } fclose($file); re

PHP防止SQL注入详解及防范

SQL 注入是PHP应用中最常见的漏洞之一。事实上令人惊奇的是,开发者要同时犯两个错误才会引发一个SQL注入漏洞。 一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。这两个重要的步骤缺一不可,需要同时加以特别关注以减少程序错误。 对于攻击者来说,进行SQL注入攻击需要思考和试验,对数据库方案进行有根有据的推理非常有必要(当然假设攻击者看不到你的

PHP防止SQL注入的方法(2)

如果用户输入的是直接插入到一个SQL语句中的查询,应用程序会很容易受到SQL注入,例如下面的例子: $unsafe_variable = $_POST['user_input'];mysql_query("INSERT INTO table (column) VALUES ('" . $unsafe_variable . "')"); 这是因为用户可以输入类似VALUE”); DROP TA