PHP面试中会被问到得问题及答案总结

52 篇文章 0 订阅
34 篇文章 0 订阅

1.PHP魔术方法

1.__construct(),类的构造函数
2.__destruct(),类的析构函数
3.__call(),在对象中调用一个不可访问方法时调用
4.__callStatic(),用静态方式中调用一个不可访问方法时调用
5.__get(),获得一个类的成员变量时调用
6.__set(),设置一个类的成员变量时调用
7.__isset(),当对不可访问属性调用isset()或empty()时调用
8.__unset(),当对不可访问属性调用unset()时被调用。
9.__sleep(),执行serialize()时,先会调用这个函数
10.__wakeup(),执行unserialize()时,先会调用这个函数
11.__toString(),类被当成字符串时的回应方法
12.__invoke(),调用函数的方式调用一个对象时的回应方法
13.__set_state(),调用var_export()导出类时,此静态方法会被调用。
14.__clone(),当对象复制完成时调用
15.__autoload(),尝试加载未定义的类
16.__debugInfo(),打印所需调试信息


2.PHP设计模式如何实现?

工厂模式、单例模式、注册模式、适配器模式、观察者模式、策略模式、原型模式、装饰器模式

工厂模式:用工厂方法代替new操作的一种模式,如果需要更改所实例化的类名,只需在工厂方法内修改,不
需逐一寻找代码中具体实例化的地方。


单例模式:防止重复实例化,避免大量的new操作,减少消耗系统和内存的资源,使得有且仅有一个实例对象。


3. PHP框架,框架优缺点

 thinkphp

优点
1.借助成熟的Java思想
2.易于上手,有丰富的中文文档;学习成本低,社区活跃度高
3.框架的兼容性较强,PHP4和PHP5完全兼容、完全支持UTF8等。
4.适合用于中小项目的开发
5.从thinkphp3.2.2引入composer包管理工具


缺点
1.对Ajax的支持不是很好;
2.目录结构混乱,相比其他框架目录结构要差一点;
3.上手容易,但是深入学习较难。

laravel 

优点
1.laravel的设计思想是很先进的,非常适合应用各种开发模式TDD, DDD 和BDD
2.支持composer包管理工具
3.集合了php 比较新的特性,以及各种各样的设计模式,Ioc 容器,依赖注入等。

缺点
1.基于组件式的框架,所以比较臃肿

 4.mysq|索引MyISAM和 InnoDB 的基本区别?索引结构如何实现?

A、MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持;
B、MyISAM类型的表强调的是性能,其执行速度比InnoDB类型更快;
C、InnoDB不支持FULLTEXT类型的索引;
D、InnoDB中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行,但
是MyISAM只要简单的读出保存好的行数即可;
E、对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引;
F、DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除;
G、LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,
导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用;
H、MyISAM支持表锁,InnoDB支持行锁。

MyISAM:成熟、稳定、易于管理,快速读取。一些功能不支持(事务等),表级锁。
InnoDB:支持事务、外键等特性、数据行锁定。空间占用大,不支持全文索引等。

 

5.redis存储类型及优势?

string、list、set(集合)、sorted set|(有序集合)、hash


优势
1、存储速度快。因为数据存储于内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)
2、支持丰富的数据类型,支持string,list,set,sorted set,hash
3、支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行
4、丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除

6.redis队列使用及Redis和memcached有哪些优势

1、memcached所有的值均是简单的字符串,Reids作为其替代者,支持更为丰富的数据类型
2、Redis的速度比memcached快很多
3、Redis可以持久化其数据
4、Redis支持数据的备份,即master/slave模式的数据备份

7.Redis雪崩

缓存雪崩
当缓存服务器重启或者大量缓存集中在某一个时间段失效,这样在失效的时候,会给后端系统带来很大压力,导致系统崩溃。


如何避免?

1、在缓存失效后,通过加锁或者队列来控制读数据库写缓存的线程数量。
2、做二级缓存,A1为原始缓存,A2为拷贝缓存,A1失效时,可以访问A2,A1缓存失效时间设置为短期,
A2设置为长期 3:不同的key,设置不同的过期时间,让缓存失效的时间点尽量均匀。
3、缓存定期备份

8.tcp协议三次握手.

三次握手协议指的是在发送数据的准备阶段,服务器端和客户端之间需要进行三次交互:
第一次握手:客户端发送含有标志得数据段到服务器,并进入请求状态,等待服务器确认;
第二次握手:服务器收到数据段,必须确认客户的数据段,同时自己也发送一个数据包,此时服务器进入相应状态;
第三次握手:客户端收到服务器的响应包,向服务器发送确认包,此包发送完毕,客户端和服务器进入链接状态,完成三次握手。
连接建立后,客户端和服务器就可以开始进行数据传输了。

9.冒泡排序

 简单来说就是相邻得两个数作比较,相对较小得一个数排在前面

function bubbleSort($arr)
{
    $len = count($arr);
    for ($i = 0; $i < $len - 1; $i++) {
        for ($j = 0; $j < $len - 1 - $i; $j++) {
            if ($arr[$j] > $arr[$j+1]) {
                $tmp = $arr[$j];
                $arr[$j] = $arr[$j+1];
                $arr[$j+1] = $tmp;
            }
        }
    }
    return $arr;
}

10.Linux常用命令

1、ls命令
2、cd 命令
3、pwd 命令
4、mkdir 命令
5、rm 命令
6、rmdir 命令
7、mv 命令
8、chmod 命令


11. 文件夹遍历

function getAllFiles($path){
    foreach(scandir($path) as $file){
        if($file === '.'|| $file === '..') continue;
        if(is_dir($path.'/'.$file)) getAllFiles($path.'/'.$file);
        else echo $path.'/'.$file."\n";
    }
}
getAllFiles('/Usersm/test');

12. SESSION 与 COOKIE的区别是什么,请从协议,产生的原因与作用说明?

A、http无状态协议,不能区分用户是否是从同一个网站上来的,同一个用户请求不同的页面不能看做是同一个用户。
B、SESSION存储在服务器端,COOKIE保存在客户端。Session比较安全,cookie用某些手段可以修改,不安全。

Session依赖于cookie进行传递。
禁用cookie后,session不能正常使用。
Session的缺点:保存在服务器端,每次读取都从服务器进行读取,对服务器有资源消耗。
Session保存在服务器端的文件或数据库中,默认保存在文件中,文件路径由php配置文件的session.save_path指定。
Session文件是公有的。

13.nginx负载均衡

负载均衡不论是各种软件或硬件上的解决方案,主要还是将大量的并发请求按照一定的规律分发给不同的服务器处理,从而减少某台服务器的瞬时压力,提高网站的抗并发能力。



一、负载均衡的作用

1、转发功能

按照一定的算法【权重、轮询】,将客户端请求转发到不同应用服务器上,减轻单个服务器压力,提高系统并发量。

2、故障移除

通过心跳检测的方式,判断应用服务器当前是否可以正常工作,如果服务器期宕掉,自动将请求发送到其他应用服务器。

3、恢复添加

如检测到发生故障的应用服务器恢复工作,自动将其添加到处理用户请求队伍中。

二、Nginx实现负载均衡
同样使用两个tomcat模拟两台应用服务器,端口号分别为8080 和8081

1、Nginx的负载分发策略

      Nginx 的 upstream目前支持的分配算法: 
1)、轮询 ——1:1 轮流处理请求(默认)

      每个请求按时间顺序逐一分配到不同的应用服务器,如果应用服务器down掉,自动剔除,剩下的继续轮询。 
2)、权重 ——you can you up
      通过配置权重,指定轮询几率,权重和访问比率成正比,用于应用服务器性能不均的情况。 
3)、ip_哈希算法
      每个请求按访问ip的hash结果分配,这样每个访客固定访问一个应用服务器,可以解决session共享的问题。 

2、配置Nginx的负载均衡与分发策略

14.linux性能优化

硬件资源

•CPU

•内存

•磁盘

•网络

软件资源

•软件锁

•线程池/连接池

15、什么事面向对象?主要特征是什么?

面向对象是程序的一种设计方式,它利于提高程序的重用性,使程序结构更加清晰。主要特征:封装、继承、多态

16、在程序的开发中,如何提高程序的运行效率?

A、优化SQL语句,查询语句中尽量不使用select *,用哪个字段查哪个字段;少用子查询可用表连接代替;少用模糊查询;
B、数据表中创建索引;
C、对程序中经常用到的数据生成缓存。

17、对于大流量的网站,您采用什么样的方法来解决访问量问题?

A、有效使用缓存,增加缓存命中率
B、使用负载均衡
C、对静态文件使用cdn进行存储和加速
D、想法减少数据库的使用
E、查看出现统计的瓶颈在哪里
F、反向代理

18.简述高并发网站解决方案。

A、前端优化(CND加速、建立独立图片服务器)
B、服务端优化(页面静态化、并发处理[异步|多线程]、队列处理)
C、数据库优化(数据库缓存[Memcachaed|Redis]、读写分离、分库分表、分区)
D、Web服务器优化(负载均衡、反向代理)

19.你用什么方法检查PHP脚本的执行效率(通常是脚本执行时间)和数据库SQL的效率(通常是数据库Query时间),并定位和分析脚本执行和数据库查询的瓶颈所在?

A、PHP脚本的执行效率
a、代码脚本里计时;
b、xdebug统计函数执行次数和具体时间进行分析,最好使用工具winCacheGrind分析;
c、在线系统用strace跟踪相关进程的具体系统调用。

B、数据库SQL的效率
a、sql的explain(mysql),启用slow query log记录慢查询;
b、通常还要看数据库设计是否合理,需求是否合理等。

20、对于大流量的网站,您采用什么样的方法来解决各页面访问量统计问题。

A、确认服务器是否能支撑当前访问量;
B、优化数据库访问;
C、禁止外部访问链接(盗链), 比如图片防盗链;
D、控制文件下载,尤其是大文件;
E、使用不同主机分流(负载均衡);
F、使用浏览统计软件,了解访问量,有针对性的进行优化。

21、 MySQL数据库作发布系统的存储,一天五万条以上的增量,预计运维三年,怎么优化?

A、设计良好的数据库结构,允许部分数据冗余,尽量避免join查询,提高效率;
B、选择合适的表字段数据类型和存储引擎,适当的添加索引;
C、mysql库主从读写分离;
D、找规律分表,减少单表中的数据量提高查询速度;
E、添加缓存机制,比如memcached,redis等;
F、不经常改动的页面,生成静态页面;
G、书写高效率的SQL。比如 SELECT * FROM TABEL 改为 SELECT field_1, field_2, field_3 FROM TABLE。

22、常用字符串函数。 

serialize()、unserialize()   序列化是将变量转换为可保存或传输的字符串的过程。
strlen()    返回字符串长度。
strrev()    反转字符串。
strpos(原字符串,待查找字符串) 存在返回第一个字符下标,不存在返回false。
strstr(原字符串,待查找字符串) 返回待查找字符串及其后剩余部分,不存在返回false。
str_replace("world", "Kitty", "Hello world!")    将某个字符串替换为另一个字符串。
explode(" ",原字符串)   将原字符串按分割字符串转成数组。
implode(" ",原数组)        将原数组中的元素连接分割字符组合成字符串。
trim()      移除字符串两侧的空白字符和其他字符。ltrim()移除左边、rtrim()移除右边。
substr("Hello world",6) 返回字符串的一部分。
substr_replace(string,replacement,start,length) 函数把字符串的一部分替换为另一个字符串。
htmlspecialchars()  把一些预定义的字符转换为 HTML 实体。
str_repeat("Shanghai",5)    字符串重复指定次数。
str_split("Shanghai",3)     将字符串分割成数组,可以指定每个数组元素长度。

23.常用数组函数

array_keys()    返回数组中所有的键名。
array_values()  返回数组中所有的值。
array_shift()   删除数组中首个元素,并返回被删除元素的值。
array_unshift() 在数组开头插入一个或多个元素,并返回数组元素个数。
array_diff()    比较数组,返回差集(只比较键值)。
array_intersect()   比较数组,返回交集(只比较键值)。
array_diff_assoc()  比较数组,返回差集(比较键名和键值)。
array_merge()   把一个或多个数组合并为一个数组。
array_pop() 删除数组的最后一个元素(出栈)。
array_push()    将一个或多个元素插入数组的末尾(入栈)。
sort()  对数组进行升序排序。
rsort() 对数组进行降序(逆向)排序。
asort() 对关联数组按照键值进行升序排序。
ksort() 对数组按照键名进行升序排序。
array_rand()    返回数组中一个或多个随机的键。
array_combine() 通过合并两个数组来创建一个新数组。
array_unique()  删除数组中的重复值。

 

 

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值