编辑推荐
1.面向实践的Perl语言经典
2.简约、高效的编程秘籍
3.Perl语言非常有名的译者倾情再献
《Perl高效编程(第2版)》,本书是Perl编程领域的“圣经级”著作。它提供了一百多个详实的应用案例,足以涵盖编程过程中经常遇到的方方面面,由此详细阐释出各种高效且简洁的写法。
内容简介
《Perl高效编程(第2版)》是Perl 编程领域的“圣经级”著作。它提供了一百多个详实的应用案例,足以涵盖编程过程中经常遇到的方方面面,由此详细阐释出各种高效且简洁的写法。
《Perl高效编程(第2版)》第1 版曾畅销十年之久,而在第2 版中不仅修正了前版存在的一些问题,更与时俱进地引入了许多Perl 领域的新主题,使内容更加完善丰富,也更具实用性。
作者简介
Joseph N. Hall 一个自学成才的“电脑神童”,靠着玩TI公司的可编程计算器和带4KB内存的Radio Shack TRS-80 Model 1出道。他从14岁起就开始教别人用电脑,早在1984年就开始了职业编程生涯。他开始接触Unix和C语言是1987年,接触Perl则是1993年。
Joshua A. McAdams一直以在谷歌工作为荣。作为最近五年来非常活跃的Perl社区成员,他是Perlcast(www.perlcast.com)的创办者,主持了两届芝加哥YAPC::NA,同时也是Chicago.pm的召集人,他在全球的Perl会议上发表了不少演讲,另外,他还是一名CPAN的作者,并持续为The Perl Review和Perl Advent Calendar供稿。
brian d foy 《Perl语言入门(第5版)》以及Intermediate Perl的合著者,也是《精通Perl》的作者。他发起了第一个Perl用户组——New York Perl Mongers;作为The Perl Review的出版人,还维护着一部分Perl核心文档。另外,他也是一名Perl讲师,常常在聚会上发言。
盛春 大二开始自学Perl编程,在通读完《Perl 5详解》后利用暑期打工的机会,专职于Perl语言的CGI开发。毕业后的工作也一直以Perl语言作为主要开发工具,目前就职于思科IronPort的邮件及Web安全部门,负责中文反垃圾邮件规则的开发和维护以及内部工具和报告的开发。早年曾为PerlChina筹建社区站点,翻译过数篇技术文章。2007年和蒋永清合作翻译《Perl Testing程序高手秘笈》,2009年与蒋永清、王晖合作翻译《Perl 语言入门(第5版)》,2010年再度合作,翻译了即将出版的《使用Perl实现系统管理自动化》以及这本《Perl高效编程》。此外,在2009年还主持翻译了开源图书《Pro Git》。
王晖 《Perl 语言入门(第5版)》及《使用Perl实现系统管理自动化》的合译者。接触到Perl是在2000年,很快喜欢上了这门语言和它的社区,熟悉Linux/ Unix,在盛春的影响下成为Mac用户,目前和盛春一样服务于IronPort 的邮件及Web安全部门,大部分工作都是在FreeBSD下使用Perl来完成的,包括数据分析、采集、系统管理及Web应用等。希望国内能有更多的Perl爱好者及基于Perl的应用出现。
张东亮 2004年接触并喜欢上了Perl,对正则表达式相逢恨晚。建有个人博客“我爱正则表达式”,专用来记录Perl等脚本语言中正则表达式的学习心得和应用技巧。目前服务于IronPort的邮件及Web安全部门,负责维护反垃圾邮件/反病毒系统和内部网络的建设。
蒋永清 1997年在一台收银机上开始了Linux的自学,2002年夏开始接触 Perl编程,2003年开始参与PerlChina技术论坛。2004年至2009年完成了数十篇技术文章和两本Perl书籍的翻译。2010年起在北京从事互联网维护工作,随后翻译完成了另外两本Perl书籍。目前和家人、孩子、朋友一起在北京生活。
内页插图
目录
第1章 Perl基础 1
条款1 查阅Perl及其模块的文档 1
条款2 在需要时开启Perl新特性 3
条款3 打开约束指令,让编码更规范 4
条款4 了解魔符的含义 7
条款5 弄清变量名字空间 8
条款6 了解字串和数值比较间的差异 9
条款7 弄清何时变量为假,并依此作出正确判别 11
条款8 理解字符串和数字之间的转换 14
条款9 弄清列表和数组间的差别 17
条款10 如需空数组,请勿用undef赋值 19
条款11 仅需单个元素时请勿用切片 21
条款12 理解上下文及其对操作的影响 25
条款13 用数组或散列集结一组数据 27
条款14 用bignum处理大数 29
第2章 Perl的地道用法 31
条款15 为优雅、简洁而使用$_ 32
条款16 了解其他默认参数 35
条款17 常见简写和双关语 37
条款18 避免过分依赖标点符号 41
条款19 调整列表格式以便于维护 43
条款20 善用foreach、map和grep 44
条款21 了解各种字符串引用方法 47
条款22 掌握多种排序方式 50
条款23 通过智能匹配简化工作 54
条款24 用given-when构造switch语句 55
条款25 用do {}创建内联子程序 58
条款26 用List::Util和List::MoreUtils简化列表处理 60
条款27 用autodie简化错误处理 63
第3章 正则表达式 66
条款28 了解正则表达式操作符的优先级 66
条款29 使用正则表达式的捕获功能 69
条款30 使用更精确的空白字符组 74
条款31 使用命名捕获,给匹配加标签 77
条款32 仅需分组时,用非捕获括号 78
条款33 小心处理匹配变量 79
条款34 能懒则懒,不要贪婪 81
条款35 用零宽断言匹配字串中的特定位置 82
条款36 简单字串处理应避免使用正则表达式 85
条款37 提高正则表达式的可读性 87
条款38 避免不必要的回溯 90
条款39 仅编译正则表达式一次 93
条款40 预编译正则表达式 94
条款41 正则表达式的性能评测 95
条款42 不要滥造正则表达式 97
第4章 子程序 99
条款43 理解my和local之间的差异 99
条款44 若非必要请勿直接使用@_ 106
条款45 用wantarray按需返回列表 108
条款46 传递引用而非副本 110
条款47 用散列传递命名参数 113
条款48 通过参数原型声明以特殊方式解析参数 116
条款49 创建闭包锁住数据 118
条款50 用子程序创建新子程序 121
第5章 文件与文件句柄 124
条款51 不要忽略文件测试操作符 124
条款52 始终以三项参数的形式调用open 126
条款53 采用不同方式读取数据流 127
条款54 处理字符串的文件句柄 129
条款55 灵活的输出方式 132
条款56 用File::Spec或Path::Class处理文件路径 134
条款57 将数据留于磁盘以节约内存 136
第6章 引用 139
条款58 理解引用和引用的语法 139
条款59 将引用类型和原型进行比较 145
条款60 通过引用创建包含数组的数组 147
条款61 别将匿名数组和列表直接量搞混淆 149
条款62 通过匿名散列创建C风格的struct结构 150
条款63 小心循环数据结构 152
条款64 用map和grep操作复杂数据结构 154
第7章 CPAN 158
条款65 以非管理员权限安装CPAN模块 159
条款66 拥有自己的CPAN 161
条款67 减少公共代码带来的风险 164
条款68 安装模块前先行调研 166
条款69 确保Perl能找到我们的模块 168
条款70 为CPAN作贡献 171
条款71 了解常用模块 173
第8章 Unicode 176
条款72 在源代码中使用Unicode字符 177
条款73 告诉Perl该用何种编码方式 179
条款74 通过代码值或名字输入Unicode字符 180
条款75 位组字串转换到字符字串 182
条款76 Unicode字符和属性的模式匹配 185
条款77 同字素打交道,而不是字符 188
条款78 谨慎处理数据库中的Unicode 190
第9章 软件分发 192
条款79 用Module::Build构建发行版 192
条款80 不必手工新建软件发行版 194
条款81 给模块取个好名字 198
条款82 在代码中嵌入Pod文档 201
条款83 限制我们的发行版用于特定平台 204
条款84 检查Pod文档 206
条款85 嵌入其他语言代码 209
条款86 用XS链接低级语言,提高运行速度 211
第10章 测试 215
条款87 用prove灵活运行测试 215
条款88 有目的性地运行测试 218
条款89 用依赖注入避免特殊测试逻辑 220
条款90 避免给方法引入不必要的东西 222
条款91 把程序写成模块便于测试 224
条款92 用虚拟的对象或接口测试 227
条款93 用SQLite创建测试用数据库 231
条款94 用Test::Class编写结构化测试 232
条款95 项目一开始就准备好测试 235
条款96 度量测试覆盖率 240
条款97 把CPAN Testers当作QA团队 243
条款98 设置持续编译系统 244
第11章 警告信息 250
条款99 启用警告功能定位可疑代码 250
条款100 利用词法作用域选择性启用或关闭警告 253
条款101 用die抛出异常 255
条款102 用Carp来获得栈跟踪信息 256
条款103 正确处理异常 259
条款104 通过污染检查跟踪危险数据 261
条款105 对老旧程序启用污染警告 263
第12章 数据库 265
条款106 预备SQL语句以复用并节省时间 265
条款107 利用SQL占位符将参数值自动引起 268
条款108 通过绑定返回列快速访问数据 270
条款109 复用数据库连接 272
第13章 杂项 275
条款110 编译并安装自己的perl解释器 275
条款111 用Perl::Tidy美化代码 277
条款112 使用Perl Critic 280
条款113 用Log::Log4perl记录程序运行状态 284
条款114 明白循环内的数组何时会被修改 289
条款115 不要用正则表达式提取逗号分隔的字串 290
条款116 用unpack处理固定列宽的数据 291
条款117 用pack和unpack对数据作变形处理 293
条款118 借用typeglob访问符号表 298
条款119 用BEGIN初始化,以END善后 300
条款120 用单行Perl命令作为迷你程序 302
附录 Perl资源 307
前言/序言
Perl高效编程(第2版) 精彩掠影 《Perl高效编程(第2版)》并非一本简单的语言参考手册,它更像是一本深入Perl世界、探索其强大潜能的路线图。这本书的目标读者群相当广泛,从初学者渴望构建稳健、高效的Perl应用程序,到资深开发者希望精进技艺、优化代码性能,都能从中获益匪浅。它不屑于仅仅罗列语法特性,而是致力于传达一种“Perl之道”,教导读者如何运用Perl这把瑞士军刀,应对复杂多变的编程挑战。 深入理解Perl的精髓:不仅仅是语法 这本书的独特之处在于,它将Perl的强大表现力归根于其底层的设计理念和灵活的机制。它会带领读者剖析Perl的标量、数组、哈希等核心数据结构,但绝不流于表面。相反,它会深入探讨这些结构在内存中的表示方式、操作的效率差异,以及如何根据具体场景选择最优的数据结构。例如,在处理大量键值对时,是选择哈希效率更高,还是在特定情况下使用数组索引进行模拟会更省时省力?这些细微之处,往往是区分普通代码和高效代码的关键。 除了基本数据结构,书中对Perl的上下文(Scalar Context和List Context)的讲解更是鞭辟入里。理解上下文转换对于写出简洁、易懂且高效的Perl代码至关重要。读者将学会如何利用不同上下文的特性,让代码在不同场景下自动适应,避免冗余的显式转换,从而提升代码的可读性和执行效率。例如,一个函数在列表上下文中返回多个值,但在标量上下文中可能只需要返回一个汇总结果,Perl强大的上下文机制能够优雅地处理这种差异,而本书将详细阐述如何驾驭这一特性。 掌握Perl的“隐式魔法”:驯服强大的工具 Perl之所以被称为“瑞士军刀”,很大程度上在于其丰富的内建函数和强大的正则表达式引擎。本书不会对每一个内建函数一一列举,而是精选那些在实际开发中应用最广、最具效率提升潜力的函数进行深入剖析。读者将学习到如何巧妙运用`map`、`grep`、`sort`等函数,以声明式的方式处理集合数据,大幅减少手动循环的编写,从而提高代码的简洁性和可维护性。 而Perl强大的正则表达式引擎,更是本书的重头戏。书中会系统地讲解正则表达式的各个组成部分,包括元字符、量词、分组、断言等等,并提供大量实际应用案例。读者将不仅仅学会如何“匹配”文本,更会理解如何利用正则表达式进行高效的文本解析、数据提取、格式转换,甚至模式识别。例如,如何用最少的字符实现复杂的多行匹配?如何通过捕获组高效地提取所需信息?这些技巧在处理日志文件、解析配置文件、清洗数据等场景下,都能带来巨大的效率提升。 写出“Perl风格”的代码:优雅而高效 “Perl风格”的代码,往往是简洁、灵活且富有表现力的。本书会引导读者领略并实践这种风格。通过大量的代码示例,读者将学习到如何利用Perl的语法糖,如何进行链式调用,以及如何通过命名约定和代码组织,让代码更容易被理解和修改。 书中还会重点介绍Perl的模块化编程思想。读者将学会如何编写清晰、可复用的Perl模块,以及如何有效地使用CPAN(Comprehensive Perl Archive Network)上的海量模块。CPAN是Perl生态系统中最宝贵的财富之一,掌握如何在其浩瀚的库中找到适合的工具,并将其集成到自己的项目中,是高效Perl编程的关键一步。例如,在处理网络通信时,是手动编写Socket代码,还是直接利用`LWP`等成熟的模块?本书会给出清晰的指导。 提升代码性能:从细微处着手 对于追求极致性能的开发者而言,本书提供了宝贵的洞见。它会深入探讨Perl代码的性能瓶颈,并提供各种优化策略。这包括但不限于: 算法优化: 在某些情况下,算法本身的效率远比具体的代码实现更重要。书中会引导读者思考,在解决问题时,是否有更优的算法选择。 内存管理: Perl的内存使用也是影响性能的重要因素。书中会介绍如何识别内存泄漏,以及如何通过合理的内存分配和释放,优化程序内存占用。 I/O优化: 文件读写和网络通信是常见的性能瓶颈。本书会讲解如何进行高效的I/O操作,例如使用缓冲、批量处理等技术。 利用C/C++扩展: 对于计算密集型的任务,Perl也提供了与C/C++等语言集成的能力(如XS)。本书会适时介绍这种高级的性能优化手段,帮助读者突破Perl本身的计算瓶颈。 剖析工具的使用: 了解如何使用Perl自带的性能剖析工具(如`Devel::NYTProf`),能够帮助开发者准确地定位代码中的性能热点,从而进行有针对性的优化。 错误处理与调试:构建健壮的应用程序 高效编程不仅在于速度,更在于稳定性和可维护性。本书会详细讲解Perl的错误处理机制,包括`die`、`warn`、`eval`等,以及如何构建健壮的异常处理流程。读者将学会如何优雅地处理潜在的错误,防止程序崩溃,并向用户提供清晰的错误信息。 同时,书中也会提供实用的调试技巧和工具。从简单的`print`语句调试,到使用Perl自带的调试器(`perl debugger`),再到利用更高级的调试工具,本书将帮助开发者快速定位和解决代码中的bug。掌握有效的调试方法,能够大大缩短开发周期,提高软件质量。 现代化Perl开发的实践:拥抱新趋势 Perl语言本身也在不断发展,新的语法特性和最佳实践层出不穷。本书(第2版)自然会涵盖这些新内容,引导读者了解并实践现代Perl开发的理念。这可能包括: `use strict`和`use warnings`的重要性: 这两个pragma是编写健壮Perl代码的基石,本书会详细阐述它们的作用和最佳使用方法。 更现代的语法特性: 例如`say`函数、`foreach`的`my`变量等,这些新特性能够让代码更加简洁和易读。 现代化的模块使用: 介绍如何使用`Module::Build`或`Dist::Zilla`等工具来管理和构建Perl模块。 并发与并行: 探索Perl在处理并发和并行任务方面的解决方案,例如使用`threads`模块或`Coro`库,以应对多核处理器的挑战。 总结:成为一名更出色的Perl程序员 《Perl高效编程(第2版)》是一本旨在将读者从“会写Perl”提升到“善用Perl”的指南。它所提供的知识和技巧,不仅能帮助开发者编写出更快速、更稳定、更易于维护的Perl程序,更能培养一种解决问题的思维模式,让开发者在面对各种编程挑战时,都能游刃有余,事半功倍。它鼓励读者深入理解Perl的内在机制,而不是仅仅停留在表面语法。通过这本书的学习,你将能够更自信地驾驭Perl的强大能力,成为一名真正意义上高效的Perl程序员。