zoukankan      html  css  js  c++  java
  • 关于 VBScript 中的 CreateObject

    本文主要记录,VBS中,CreateObject 和 WScript.CreateObject 的不同。


    CreateObject 是什么:

    他是一个 VBScript 的内置函数(Function),或者说是一个方法(Method),取决这个单词被用在了什么地方。

    CreateObject 的作用:

    微软官方文档说,它的作用是:Creates an Automation object of the specified class。翻译过来就是,用于创建一个指定类型的,自动化对象。而,An object is an instance of a class,所以,可以进一步解释为,它的作用是,创建一个指定 Class 的 Instance (实例)。不觉得,这个内置函数的作用,很像是 Python 里的 import xxx as y 么!

    为什么要使用 CreateObject 函数:

    VBScript 的运行环境中,自带的 Object 只有14个,或者说 Windows Scripting Host (WSH) 环境中,自带的 Object 只有14 个。因此能解决的问题比较有限,所以,VBScript 总会遇到,靠自带 Object 解决不了的问题。这时,为了解决问题(自动化),VBScript 就需要调用(借用)其他 “外部的Object” 或者 “程序”。那么,如何调用呢?答案就是,使用 CreateObject 函数!一个很好的例子就是,CreateObject("Excel.Application")。这个例子是,VBScript 在调用外部的 Excel 对象,来自动化 Excel 操作!要是不太理解WSH,可以去看我另一篇文章:Windows Scripting Host (WSH) 是什么?

    CreateObject 和 WScript.CreateObject 有什么不同:

    细心的同学,或发现,在使用 CreateObject 函数的过程中,会在代码中,看到两种不同的情况:

    • CreateObject (直接使用函数)
    • WScript.CreateObject (作为 Wscript 的 Method 来使用)

    那么这两种,使用方法,区别是什么呢?区别如下:

    1. CreateObject 是 VBScript 的内置函数,属于语言的一部分;而 WScript.CreateObject 是 WSH 中 WScript 对象的 Method;在 VBS 语言中,CreateObject 总是可用的,而 WScript.CreateObject 只有在宿主为 wscript.exe 和 cscript.exe 的情况下才可以使;在 WMI、QTP、SecureCRT、EmEditor 等,其他宿主环境是无法使用的。

    2. 这两种函数,所使用的参数的,含义不同;它俩的第一个参数,含义是相同的,但是它俩的第二个参数,含义就完全不同了;CreateObject 的第二个参数用来通过 DCOM 在远程服务器上创建对象;而 WScript.CreateObject 的第二个参数用来创建本地对象并响应事件。

    3. 这两种函数的速度不一样;因为 CreateObject 是 VBS 的内置函数,不需要通过COM来调用,所以稍微快了一点点。

    4. 建议,尽量使用 CreateObject 函数,除非你需要响应事件;因为这样 可移植性更好、速度更快、代码更短。

    参考阅读:

    1. CreateObject Method | Microsoft Docs
    2. Instance (computer science) - Wikipedia
    3. VBScript CreateObject Function
    4. VBS调用Windows对象中server.CreateObject和wscript.creatobject的区别_百度知道
    5. VBS中CreateObject和WScript.CreateObject的区别

  • 相关阅读:
    Linux嵌入式 -- 内核
    Linux嵌入式 -- 内核
    utf8和utf8mb4区别
    二叉树的实现
    python资源大全2
    树与树算法
    二叉树
    70.最小生成树
    68.营救问题(广搜)
    67.迷宫问题(广搜)
  • 原文地址:https://www.cnblogs.com/bitssea/p/12593940.html
Copyright © 2011-2022 走看看