为什么是Cmdlets?

Jeffrey Snover描述了使用Cmdlets和APIs之间的区别。他总结说,“Cmdlets是特别为系统管理人员(Admins)用键盘操作而设计的,而APIs不是。Cmdlets是PowerShell的核心和精神。”

Cmdlets是从Cmdlet或者PSCmdlet基类继承创建的。而这两个类都是通过重写BeginProcessing、ProcessRecord和EndProcessing等虚函数实现的。

这些类因它们暴露的PowerShell底层多少而有所区别。但是Cmdlet 是轻量级的,能被其他的Cmdlets所调用,PSCmdlet 为PowerShell运行时,包括环境变量和Session状态,提供访问接口。

Jeffrey Snover通过阐述在PowerShell环境下Cmdlet所获得的更好支持,来支持他的观点。下面是他的一些主要论点:

  • 命名。Cmdlet的命名是明确的,能让系统管理员轻松地知道应该使用哪些命令。Cmdlets的命名模式是动名词性质的,而且对动词的使用有很好的使用指南。参数的使用指南也很丰富。相对而言,APIs就不是那么智能。
  • Tab键完成(Tab-Completion)。PowerShell为Cmdlets和参数提供了Tab键完成,而没有为APIs提供。
  • 帮助。Cmdlets提供了面向系统管理员的智能的帮助。APIs提供的是面向开发人员的帮助。
  • 发现能力。PowerShell提供了大量对系统管理人员友好的方式,以找到像Get-Command、Get-Help(这两个都支持wildcards)以及See-Also等这样的Cmdlets帮助。
  • APIs只能抛出错误,而Cmdlets能区分中断和非中断错误。非中断错误能更好地支持大量操作,并允许操作在收集所有的要素并组合成集合之后继续进行。
  • 通道。通过使用Cmdlets可以支持PIPELINE输入。APIs却需要用户做一些编程工作以获得类似的结果。

Jeffery还提到说,“在2.0版本里,Cmdlets和APIs之间的差距会越来越大。那时,会有一些重要的函数只在Cmdlets里才存在。”

查看英文原文: Why Cmdlets?

你可能感兴趣的:(为什么是Cmdlets?)