NewキーワードとCreateObject関数でのオブジェクト作成の違い

VB6,VBA,VBS,EXCEL,DOS,BAT,WSH,WORDの小技メモ

HTML/ CSS/ CGI-Perl/ JavaScript/ JavaApplet/ AccessUp/ Internet/ EnglishLearn/ ちゃいちゃん天使/ 天使メッセージ/ 飯田ワールド/ 結城ワールド/ プロフィール/ WEB相談室/ WEBアンテナ/ 燈明日記/ Perlノート/ 漢字起源/ yahoo

はじめに

本ページは、ウインドウズ系全般のティプスメモです。

そう、はじめはVB系のティプスメモだったのですが…いつの間にか、ウインドウズ系全般のティプスメモになってしまいました。

ちなみに、ティプス(Tips)とは、マニュアルに書かれていない技法や裏わざのことですが、本ページでは、私が経験してこれはと思ったノウハウのメモになっています。

尚、以下は本サイトの最新情報(ブログ)です。

それでは、本ページが何かのお役に立てれば幸いです。ごゆっくりご覧ください。

◆NewキーワードとCreateObject関数でのオブジェクト作成の違い

NEWキーワードとCreateObject関数はともにオブジェクトを生成しますが、違いはなんでしょうか…。

NEWキーワードの時は、生成するオブジェクト(COM)のインターフェイスが変更されると、参照がタイプライブラリ経由なのでAPまで再コンパイルが必要。

CreateObject関数の時は、参照が引数を元にレジストリ経由なので、COMのインターフェイスが変更されても、APの再コンパイルは必要がない。

したがって、CreateObject関数で生成したオブジェクトへの参照を、実行時バインディングにするならば、タイプライブラリの参照設定も必要ない。

なんか、『タイプライブラリの参照設定』『事前/実行時バインディング』が結構絡んできて分かりづらいですが…。

とりあえず、VBからEXCELを制御するときは、事前バインディングでCreateObject関数が定石のようです(MSが推奨、以下のURL参照)。

おわりに

以下のページには、すべてのTIPSがあります。もしよろしければ、どうぞ!

尚、ご感想、ご意見、誤字、脱字、間違い等がありましたら遠慮なくVB-TIPS掲示板へご指摘ください。