一个潜在的有用的是使用闭包来产生动态的子函数 基于一个模板,使用一个相对简单的例子: [root@wx03 0729]# cat a1.pl sub multiply_by { my $multiplier = $_[0]; return sub { return $_[0] * $multiplier; } } my $times2 = multiply_by(2); my $times10 = multiply_by(10); print &$times2(4), " "; print &$times2(6), " "; print &$times10(4) ," "; [root@wx03 0729]# perl a1.pl 8 12 40 采用这种方式,闭包本质上让你创建定制的subs, 冻结参数的行为 被传递这在它们的创建期间。 我发现这个是有用的,如果我需要定义相关的数据 但是不是相同的行为对于应用元素到数据集,比如: 你也可以使用闭包来强制严格的数据封装,因为它们允许你创建变量,不存在与外部世界 只是一个想法,但是闭包类有一个特殊的意义在Perl 5, 而在大多数请求下 一个闭包有传统的"子函数" 运行在他定义的上下文, 我也发现perlers 经常使用它 从意义上说"函数引用到一个匿名的子函数" 这个可能 来自事实 闭包机制在perl是被部分破坏, 在一般意义只有应用于一个匿名子函数,不是一个显示命名的函数, 尝试这么做会导致"不共享"警告, 已经有很好的例子,你可以使用闭包posted 我不会给一个例子 [root@wx03 0729]# cat a2.pl use strict; use warnings; sub function { my $i = 0; sub test { print ++$i," "; } test(); test(); } [root@wx03 0729]# perl a2.pl Variable "$i" will not stay shared at a2.pl line 7. 你可能得到一个 "variable will not stay shared" 的警告,不会得到你期望的结果。 这个情况很多和 Apache::Registry 因为人们会写子函数 用全部变量和 Apache::Registry 覆盖整个脚本 到一个它自己的子函数. 闭包是很酷的 在回调模型: