作者: Edengundam(马涛)
今天思考了很久, WMI对于Windows来说是非常重要的一个工具. 包含了很多特性, 目前我正在看WMI关于事件和WQL的资料. PowerShell在今后也会提供WMI的供应程序(provider).
不过今天我想介绍PowerShell的单引号和反引号, 以及与Bash, Perl之间的一些对比. 学习任何事务时候, 开始用的是相似性进行记忆, 但是随着知识的积累, 你最终还会一定会引入对比记忆. 不过根据笔者在学习C, C#, bash, Perl, PowerShell的过程中, 始终认为, 首先应该以相似性为主. 这点在我学习BRE, ERE, ARE, 即基本正则表达式(废弃), 扩展正则表达式(现代正则表达式), 高级正则表达式时, 给我印象最为深刻.
如果您对bash, Perl不了解, 也没有关系, 之所以要对比, 只是为了告诉您: 伟大的思想, 表现往往是一致的. 再稍后, 我会单独来讲双引号. 其实只要记住规则, PowerShell中的引号可要比bash的简单很多了(准确说是传统的sh, 因为bash中最好使用'$()', 而避免反引号的使用).
在bash, Perl, PowerShell中, 对引号的比较往往涉及如下三个方面: 变量展开(也被称为: 变量代换, 变量篡改. ), 转义字符, 引号自身.
|
变量代换
|
转义字符支持程度
|
单引号自身引用
|
Bash
|
不允许
|
不允许
|
不允许
|
Perl
|
不允许
|
允许两种,见注1
|
见注1
|
PowerShell
|
不允许
|
不允许
|
见注2
|
在我们看例子前, 我们先来看看转义字符. 在C, C++, C#, Java, ksh, bash, Perl等等语言中, 转义字符都是反斜线(/). 通过特定语法规则, 使用转义字符可以构建被称为转义字符序列的特殊表达式. 这种表达式, 往往通知语言的词法分析模块, 对该转义序列进行特殊处理.
由于历史原因, Dos, Windows操作系统使用反斜线作为路径的分隔符, 这使得PowerShell团队做出了惊人的抉择, 使用反引号(重音符号)作为转义字符. 这种惊人的不一致, 让有类似我举例语言背景的人们可能很恶心(我的第一反应就是这样). PowerShell团队做出这种无奈的举动也是事出有因的. 如果遵照传统, 那么我们在PowerShell中使用目录时候, 恐怕都要连续使用两个反斜线才能干活, 这恐怕会让我们疯掉>_<. 正如PowerShell团队的架构师所说, 其实用反引号虽然开始不习惯, 但是你只需要几分钟去适应. 反正它都是转义字符而已, 再说转移序列又没有变化^_^.
PowerShell中支持的转移序列有点少, 特别是相比Perl的来说:
正如你所见到的, 除了转义字符变了, 其他的都没有变. 在Perl中还有一些功能强大的转移序列, 这里我就不再多说, 有兴趣的人可以参考关于Perl的书籍. 这样的转移序列例如: /U, /E, /L, /l, /u.
在我们来看几个例子(转义序列的例子放到下次举例):
我相信, 这些例子对于聪明的您来说, 应该不需要过多解释. 您一定要看清楚"单引号"和"反引号". 经过无数次事实证明(这些证明一般都是别人在论坛求助时发生的, 我曾经遇到过几次), 大部分人, 第一眼看到单引号, 反引号, 双引号时, 会错误的使用另一种引号. 这往往缘于他们对引号的不了解, 如果对引号的特性很清楚, 在看到引号时, 代码编写者的意图, 您也一定猜测到了.
OK, 由于明天要去看病, 今天只啰唆这么多, 希望大家喜欢. 引号, 往往在bash中就是判断一个人水平的好考点. 因此希望大家能予以重视.