我今天遇到了一个让我停下来思考的功能.我想不出有这么好的理由:
sub replace_string {
my $string = shift;
my $regex = shift;
my $replace = shift;
$string =~ s/$regex/$replace/gi;
return $string;
}
Run Code Online (Sandbox Code Playgroud)
我能看到的唯一可能的值是,它使您能够控制替换使用的默认选项,但我认为没有用.看到这个函数后,我的第一反应就是"这是做什么的?".一旦我了解它的作用,我就会假设从那时起就做到了.这意味着如果它发生变化,它将破坏我需要它的任何代码.这意味着该功能可能永远不会改变,或者更改它会破坏大量代码.
现在我想追踪原来的程序员,并在他或她身上打败一些感觉.这是一个有效的愿望,还是我错过了这个功能带来的一些价值?
Sch*_*ern 11
该功能的问题包括:
replace_string
并没有告诉您,您正在进行不区分大小写的全局替换而不进行转义.$string =~ s{$this}{$that}gi
你可以学习它曾经意味着什么,它不像它的一些奇怪的角落特征. replace_string
每个人都必须了解其中的每一个细节,并且每个人都会有所不同.qr//
但这比s///
其隐藏的知识要高得多.优点是:
g
和i
默认值始终存在(但名称不明显).s{}{}
困难).$1
,$+
等...),但它们会自动局部范围的功能.如果你将它们用于另一个正则表达式,它们不会干涉.封装有点过分热心.
print replace_string("some/path", "/", ":");
Run Code Online (Sandbox Code Playgroud)
是的,你可以在不必更换/使用不同的分隔符或在正则表达式中转义/获得一些魔力.
如果它只是一个冗长的替代品,s///
那么我猜它是由某人从一种使用正则表达式需要额外语法的语言来到Perl的人编写的,而且这种方式更适合编码.如果是这样的话,我会将它归类为Perl baby-talk:对经验丰富的程序员来说傻乎乎的尴尬但不坏 - 不过还不足以保证殴打,无论如何.;)
如果我真的很眯眼,我几乎可以看到这样一个函数可能有用的情况:将一堆模式应用于一堆字符串,允许用户输入条款,为回调提供CODE引用...