4.23文创礼盒,买2个减5元 读书月福利
欢迎光临中图网 请 | 注册

PHP面试一战到底

作者:闫小坤
出版社:清华大学出版社出版时间:2021-09-01
开本: 其他 页数: 312
中 图 价:¥66.8(7.5折) 定价  ¥89.0 登录后可看到会员价
加入购物车 收藏
运费6元,满69元免运费
?快递不能达地区使用邮政小包,运费14元起
云南、广西、海南、新疆、青海、西藏六省,部分地区快递不可达
本类五星书更多>

PHP面试一战到底 版权信息

PHP面试一战到底 本书特色

PHP作为一种流行的开发语言,已被应用到全球约80%的网站和网络应用里。一份统计资料显示,PHP在全球被部署在超过 210万台服务器上,有2.4亿的网站在使用 PHP。PHP如此庞大的应用范围,催生了一大批以掌握Linux、Nginx、MySQL、PHP(LNMP)技能为生的程序员。 PHP之所以应用广泛,是由于其拥有语法简洁、函数丰富、学习成本低、开发效率高、开源软件多等特性,以至于网络上流传着 “PHP是*好的语言” 的戏语。PHP 的这些优势,让成为PHP程序员的门槛降得很低:没有任何编程基础的同学,也可以在数周时间内掌握PHP语法,在数月时间内开发一些小型的网站或应用 本书编者从事PHP开发已10年有余,也深知补全PHP开发所需的技能树绝非易事,但愿意抛砖引玉,将PHP学习中的技能个个剖析,面试中的要点详细讲解,旨在为即将参加PHP面试的同学们,在PHP的学习过程中描绘出一幅路线图,为面试过程 提供一些技巧方法。 本书以PHP 7.4为蓝本,介绍PHP程序员所需的技能树,以BAT等知名互联网企业的面试题为例,讲解面试中可能遇到的问题,并提供解决方法。 希望面试者通过阅读本书能够掌握PHP的精髓,发挥自己的真才实学,在职场中拿到称心如意的Offer。

PHP面试一战到底 内容简介

本书基于PHP**版本撰写,主要讲解了以下四部分的内容:PHP的基础知识和环境搭建;PHP语言层面的知识,包括数据类型、变量、函数、类和对象、字符串、数组、文件与目录、PHP 7新特性等;其他必须要掌握的PHP语言之外的知识和技能,包括关系型数据库、非关系型数据库、常见的数据结构与算法、常见漏洞及其防范措施、计算机网络、操作系统、设计模式、Nginx、PHP-FPM、高并发应对、Restful、日志等;面试攻略和职业规划。本书注重基础知识,深入底层原理,以提高学习能力为道,以传授面试技巧为术,希望面试者能够发挥出自己的真才实学。 本书适合于即将或正在面试的PHP初级或中级程序员、对PHP开发感兴趣的人员、有一定的PHP开发经验,希望更深入了解的人员、有编程经验,希望转型做PHP开发的人员使用。

PHP面试一战到底 目录

第1章 PHP开发基础知识 1

1.1 环境搭建 1

1.1.1 下载与安装 2

1.1.2 CLI模式 2

1.1.3 CGI模式 3

1.1.4 开发工具 6

1.2 基本语法 10

1.2.1 基本规范 10

1.2.2 数据类型 10

1.2.3 变量 11

1.2.4 常量 12

1.2.5 运算符 13

1.2.6 流程控制 13

1.2.7 函数 15

1.2.8 字符串 16

1.2.9 数组 16

1.2.10 类与对象 17

1.2.11 异常处理 18

1.2.12 命名空间 19

1.3 本章小结 19

1.4 练习 19

第2章 数据类型 20

2.1 布尔类型 20

2.1.1 概念 20

2.1.2 面试题:冒泡排序 21

2.1.3 类型转换 22

2.1.4 面试题:布尔数据比较 22

2.2 整型 23

2.2.1 概念 23

2.2.2 面试题:大数求和 23

2.3 浮点型 25

2.3.1 概念 25

2.3.2 面试题:浮点数的比较 25

2.3.3 面试题:证明题 26

2.3.4 面试题:比较两个浮点数的大小 26

2.4 字符串 26

2.4.1 概念 26

2.4.2 面试题:从string中取其中的单个字符 27

2.4.3 面试题:求字符串表示的*大长度 27

2.4.4 面试题:反转字符串 28

2.5 数组 29

2.6 对象 29

2.7 回调函数 29

2.7.1 概念 29

2.7.2 回调函数的使用 30

2.7.3 面试题:call_user_func()和call_user_func_array()的区别 32

2.8 迭代器 33

2.9 资源 33

2.10 NULL值 34

2.10.1 概念 34

2.10.2 面试题:NULL值比较 34

2.11 本章小结 34

2.12 练习 35

第3章 变量 36

3.1 变量引用 36

3.1.1 指针与引用 36

3.1.2 引用的取消 37

3.1.3 forech的引用陷阱 37

3.2 预定义变量 40

3.2.1 概念 40

3.2.2 面试题:执行脚本的位置 41

3.3.3 面试题:获取当前访问页面的URL 42

3.3 垃圾回收机制 42

3.4 作用域 43

3.4.1 函数作用域 43

3.4.2 global关键字 44

3.4.3 引用文件的变量作用域 44

3.4.4 超全局变量 44

3.5 本章小结 45

3.6 练习 45

第4章 函数 47

4.1 匿名函数与闭包 47

4.1.1 匿名函数与闭包的概念 47

4.1.2 匿名函数里的变量作用域 48

4.1.3 面试题:匿名函数中$this的使用 49

4.1.4 面试题:闭包是什么 49

4.2 递归 50

4.2.1 递归的原理 50

4.2.2 递归的优缺点 50

4.2.3 面试题:用递归实现斐波那契数列 51

4.2.4 面试题:二叉树的中序遍历 51

4.3 Lambda表达式 53

4.3.1 概念 53

4.3.2 匿名函数、闭包和Lambda表达式的关系 53

4.4 生成器(Generator)与 yield 54

4.4.1 生成器 54

4.4.2 yield 56

4.4.3 生成器的设计 56

4.4.4 面试题:用yield实现斐波那契数列 57

4.5 函数式编程 58

4.5.1 什么是函数编程 58

4.5.2 函数编程的理念 59

4.5.3 函数式编程的优势 60

4.6 本章小结 60

4.7 练习 60

第5章 类和对象 61

5.1 魔术方法 61

5.2 自动加载 62

5.2.1 __autoload 63

5.2.2 spl_autoload_register 64

5.2.3 spl_autoload 65

5.2.4 面试题:引用文件函数的区别 65

5.3 命名空间 66

5.3.1 命名空间的使用规范 66

5.3.2 面试题:命名空间 69

5.3.3 面试题:类名冲突的解决方法 69

5.4 PSR-4标准 69

5.5 本章小结 70

5.6 练习 71

第6章 字符串 73

6.1 字符串比较 73

6.2 类型转换 74

6.2.1 字符串转换为数字 74

6.2.2 面试题:表达式转换为数字 75

6.2.3 其他类型转换为字符串 75

6.3 字符集与字符编码 76

6.3.1 字符集 76

6.3.2 UTF-8编码规则 77

6.3.3 面试题:Unicode字符长度 78

6.3.4 Unicode与UTF-8的关系 78

6.4 字符串查找 78

6.5 关键词搜索 81

6.6 子序列 83

6.7 字符串转换操作 84

6.8 正则表达式 87

6.8.1 正则表达式基础 87

6.8.2 面试中常见的正则表达式 91

6.9 本章小结 93

6.10 练习 93

第7章 数组 94

7.1 数组函数 94

7.1.1 count 94

7.1.2 natsort 95

7.1.3 array_merge 96

7.1.4 栈与队列的操作 97

7.1.5 集合计算 98

7.2 数组排序 99

7.2.1 多维数组排序 99

7.2.2 多个数组排序 100

7.3 数组查找与搜索 102

7.3.1 面试题:找出缺失元素 102

7.3.2 面试题:删除数组中的重复项 105

7.4 数组的遍历操作 107

7.4.1 面试题:多维数组 107

7.4.2 面试题:螺旋访问数组 107

7.5 本章小结 109

7.6 练习 109

第8章 文件与目录 111

8.1 文件引用 111

8.1.1 文件引用方法 111

8.1.2 面试题:说明几个文件引用函数的区别 113

8.2 BOM 头 113

8.2.1 BOM的检测 113

8.2.2 BOM文件的修改 114

8.3 上传与下载 116

8.3.1 文件上传 116

8.3.2 文件下载 118

8.3.3 面试题:文件上传时的大小限制 119

8.4 文件操作 119

8.4.1 读取文件函数对比 119

8.4.2 文件锁 120

8.4.3 大文件读写 120

8.4.4 SPL文件处理 122

8.5 目录操作 123

8.5.1 面试题:计算相对路径 123

8.5.2 面试题:遍历目录 125

8.5.3 文件查找 126

8.6 硬连接和软连接 126

8.6.1 概念 126

8.6.2 面试题:硬连接和软连接 127

8.6.3 面试题:硬连接占用空间吗 127

8.6.4 面试题:部署上线系统的原理 128

8.7 本章小结 129

8.8 练习 129

第9章 PHP 7新特性 130

9.1 PHP 7 的新变化 130

9.1.1 标量类型声明 130

9.1.2 新增操作 131

9.1.3 太空船操作符(组合比较符) 131

9.1.4 通过define()定义常量数组 132

9.1.5 匿名类 132

9.1.6 Unicode codepoint 转译语法 132

9.1.7 Group use declarations 133

9.1.8 错误处理 133

9.2 PHP 7 的执行效率 133

9.2.1 内存优化 134

9.2.2 变量结构 134

9.2.3 字符串 134

9.2.4 数组 134

9.3 PHP 7变量在内核中的实现 135

9.3.1 PHP 5变量内部实现 135

9.3.2 PHP 5变量问题剖析 138

9.3.3 PHP 7 变量内部实现 139

9.3.4 PHP 7 与 PHP 5 变量内部实现的差别 142

9.3.5 面试题:检测链表中的环 142

9.4 字符串的内核实现 144

9.4.1 字符串的结构 145

9.4.2 二进制安全 145

9.4.3 柔性数组 146

9.4.4 面试题:string 内部实现 149

9.4.5 面试题:内存对齐机制 150

9.4.6 面试题:内存对齐机制的规则 150

9.4.7 面试题:柔性数组 150

9.4.8 面试题:二进制安全 151

9.4.9 面试题:zend_string结构体 151

9.5 数组的内核实现 151

9.5.1 数组概述 151

9.5.2 PHP 5数组在内核中的实现 152

9.5.3 PHP 7数组在内核中的实现 153

9.6 从PHP 5迁移到PHP 7 154

9.7 本章小结 156

9.8 练习 156

第10章 RDS关系型数据库 157

10.1 连接 157

10.2 执行SQL 160

10.3 表引擎 161

10.3.1 MyISAM和InnoDB的基本概念 161

10.3.2 面试题:MyISAM与InnoDB的区别 161

10.3.3 面试题:OLAP和OLTP 161

10.3.4 OLAP 的12条规则 162

10.4 索引 163

10.5 事务 165

10.6 PDO 167

10.7 慢SQL优化 169

10.7.1 发现慢SQL的方法 169

10.7.2 性能分析 170

10.7.3 性能优化 171

10.8 数据表设计 171

10.8.1 设计实务 171

10.8.2 面试题 172

10.9 隔离级别 173

10.10 MVCC机制 177

10.11 DDL操作 177

10.12 分库分表 178

10.13 本章小结 179

10.14 练习 179

第11章 NoSQL数据库 180

11.1 Memcache 180

11.1.1 内存管理 180

11.1.2 一致性哈希 181

11.2 Redis 182

11.2.1 数据结构 182

11.2.2 面试题 184

11.2.3 位图应用 185

11.2.4 持久化策略 187

11.3 集群介绍 190

11.3.1 Codis 190

11.3.2 Twemproxy 191

11.3.3 Redis Cluster 191

11.3.4 面试题 192

11.4 本章小结 192

11.5 练习 192

第12章 数据结构与算法 193

12.1 栈和队列 193

12.1.1 栈 193

12.1.2 栈的面试题 194

12.1.3 队列 197

12.2 链表 198

12.2.1 链表的概念 198

12.2.2 面试题 198

12.3 树的定义及分类 200

12.3.1 树的定义 200

12.3.2 树的分类 200

12.3.3 树的遍历 204

12.3.4 二叉树面试知识点总结 209

12.4 树的应用——字典树 209

12.4.1 字典树的原理 209

12.4.2 字典树的应用 213

12.5 排序 215

12.5.1 选择排序 215

12.5.2 冒泡排序 216

12.5.3 插入排序 217

12.5.4 堆排序 218

12.5.5 快速排序 221

12.5.6 归并排序 223

12.5.7 桶排序 224

12.5.8 常见排序算法总结 226

12.6 分治法 226

12.6.1 分治法的概念 226

12.6.2 分治法的面试题 227

12.7 动态规划 230

12.7.1 斐波那契数列的动态规划解法 230

12.7.2 动态规划方法的两个经典问题 231

12.8 贪心算法 238

12.8.1 概念 238

12.8.2 面试题 239

12.8.3 霍夫曼树 240

12.9 本章小结 242

12.10 练习 242

第13章 PHP安全知识 243

13.1 概述 243

13.2 输入校验 244

13.3 XSS攻击 248

13.4 SQL注入 251

13.5 CSRF攻击 254

13.6 SSRF攻击 257

13.7 短信轰炸 258

13.8 接口防刷 260

13.9 本章小结 261

13.10 练习 262

第14章 常见面试题 263

14.1 计算机网络相关面试题 263

14.2 操作系统相关面试题 270

14.3 设计模式相关面试题 274

14.4 Nginx相关面试题 278

14.5 PHP-FPM相关面试题 284

14.6 Linux 287

14.7 关于高并发 290

14.8 Restful风格 292

14.9 日志 293

14.10 本章小结 294

14.11 练习 294

第15章 面试攻略 296

15.1 规划阶段 297

15.2 准备阶段 299

15.3 面试阶段 302

15.4 Offer选择 303

15.5 入职阶段 304

15.6 面试的其他问题 306

15.7 本章小结 306

15.8 练习 306

第16章 职业漫谈 307

16.1 职业发展 307

16.2 能力框架 308

16.3 工作与总结 309

16.4 技术晋升 309

16.5 技术储备 310

16.6 PHP工程师的Plan B 311

16.7 本章小结 311

参考书目及资料 312

展开全部

PHP面试一战到底 作者简介

   闫小坤 毕业于中国科学技术大学,计算机硕士。服务端技术专家,10余年PHP开发经验。曾就职于腾讯、滴滴等互联网公司,有良好的架构能力和丰富的业务抽象经验。

商品评论(0条)
暂无评论……
书友推荐
编辑推荐
返回顶部
中图网
在线客服