COM

このエントリーをはてなブックマークに追加
415デフォルトの名無しさん:2014/07/13(日) 03:23:13.23 ID:b3Vz6umr
>>406
サクラエディタのマクロはWSHだったような気がする
416デフォルトの名無しさん:2014/07/14(月) 15:28:36.63 ID:uZs3XM/U
IFileOperation でファイルのショートカットを作成することって出来ないの?

コピー・移動・リンク作成が直交的に作れたら美しいんだけど
417デフォルトの名無しさん:2014/07/14(月) 22:35:59.63 ID:DvBldTQU
EXCELをCOMアドインで操作していると、同じ処理をしているにも関わらず、
ある時は数秒で終わるのに、ある時は、何十秒も掛かったりと、挙動が
おかしいのですが、何か解決のヒントありますか?
418デフォルトの名無しさん:2014/07/15(火) 20:35:27.97 ID:UxnDWfjl
>>417
COMなんて使わずにこれ使えよ。マイクロソフトご謹製だよ。
http://www.microsoft.com/ja-jp/download/details.aspx?id=5124

ま、使うとかなり目眩がするけどなwww
419デフォルトの名無しさん:2014/07/21(月) 07:49:19.08 ID:6nmHe42m
>>416のシェルを使ったショートカット作成の件だけど、

→作成先フォルダのIDropTarget取得
→ショートカットを作るファイルのIDataObjectをCF_HDROPとかCF_SHELLIDLISTとかの形式で作成
 IFolderViewがある場合簡単。
→IDropTargetのDropその他を順番に呼び出す。その時effectをDROPEFFECT_LINKにしておく

みたいなウンコな方法か、ちまちま一個ずつ作るしかないの?
ちまちま一個だとUndoを一度にやってくれないし

もしかしてこのウンコの方法が正統な方法だったりする?
420デフォルトの名無しさん:2014/07/21(月) 07:53:53.45 ID:hvY5HB9k
うん
421デフォルトの名無しさん:2014/07/24(木) 19:57:03.53 ID:s9ARWR1P
COMによるOffice automationを調べていると
COM/ATLというような用語も見つかるのですが、COMとCOM/ATLというのは
異なる技術ですか?
私の理解では、C++でCOMやる場合は、CoInitializeExやCoUninitializeを使って
やる方式のことだと思っています。COM/ATLというのが分りません。
どなたか簡単に解説お願いします。
422片山博文MZ悪魔崇拝 ◆T6xkBnTXz7B0 :2014/07/24(木) 20:19:40.19 ID:BX5qEEGf
「active template library」で検索
423デフォルトの名無しさん:2014/08/07(木) 17:34:11.54 ID:utSp7A7J
>>421
プログラムが大きくなるとコンパイルに時間がかかるから
共通部分と分けるじゃない? あれが静的ライブラリで lib

さらに共通であちこちのexeで使われるようなものは1度コンパイルしておいて
動的にメモリに読み込んで使えるようにすればいいじゃん これが動的ライブラリで dll

さらに動的ライブラリdllにもC++のオブジェクト構造のような関数以外のものも入れたいなぁ
さらに言語非依存にして、そこで参照回数などのオブジェクトのメモリ管理も加えたCOM技術で作ったdll
COMサーバーという

この外部オブジェクトライブラリを使うのに、CoInitializeExやCoUninitializeを使うのはCOMクライアント
COMクライアントは別にC++でなくてもJavaScriptでもVBでもC#でもPerlでもなんでもいい

COMサーバーは大別してインプロセスサーバー、アウトプロセスサーバーがあるけど
ぶっちゃけ一から書くのはメンドクサイ
そこでライブラリ作ろうか〜ということで出来たのがATL/WTL
424デフォルトの名無しさん:2014/08/07(木) 17:50:19.99 ID:oQyOe1xD
わっかりやすーい
425デフォルトの名無しさん:2014/08/07(木) 19:32:56.15 ID:zGwpFhqC
参照カウントなんてどこで増やしてんの?
426デフォルトの名無しさん:2014/08/07(木) 20:30:34.00 ID:utSp7A7J
>>425
参照カウントはIUnkhownが担当してる
なぜ参照カウントが必要かというと使われなくなったオブジェクトを提供するために
dllをメモリに読み込んでいるわけだけど、つかわれなくなったら破棄するため

ちなみに何度も1個だけインターフェースを作ったり破棄したりする可能性のあるCOMは
dllの読み込みや破棄を連続で行わないためにClassFactoryを実装することが薦められている


COMは最初は言語非依存じゃなくて単に動的ライブラリdllにオブジェクト機能を持たせるだけだった
(インターフェイスの階層構造で、仮想ポインタの配列順で実現してた)
だから以前はヘッダが必要だった
つまりC++専用だった

IDispatchというインターフェイス名でを動的に関数ポインタを取得できるインターフェイスを作ることで
プログラム内にインターフェイス名を書くだけでよくなり言語非依存になった
従来の関数ポインタ順とは別にIDispatchを両方用意することをディアルインターフェースという
このあたりからOLEとか呼ばれるようになった

さらにこのインターフェイス名やGUIDはOS(というかレジストリ)に記録するものなので
Windowsアプリからはどこからでも利用できるはず・・・・
それならブラウザ内の埋め込みスクリプトからも利用できるようにしようということで ActiveX と名前を変え

ActiveXサーバーを作るものだから ATL(Active Template Library)なんだと思う
427デフォルトの名無しさん:2014/08/08(金) 01:05:55.34 ID:hqeBSYtp
COMはレジストリ登録必須じゃなくて従来のdllと同じようにアプリケーションに閉じた形で使えたら
もう少し使いでがあったんだがなぁ。
428デフォルトの名無しさん:2014/08/08(金) 01:12:38.28 ID:B23vVFp/
>>427
dllをLoadLibraryして関数呼べばCOMオブジェクト作れるでしょ?
レジストリ登録はCoCreateInstanceでCOMオブジェクト作るなら必要ってだけで
自前でやる分には何の問題もない
429デフォルトの名無しさん:2014/08/08(金) 01:27:40.29 ID:hqeBSYtp
なるほど、自分でDllGetClassObject呼んでやればいいのか。
もう使うことはないだろうが、参考になった。
430デフォルトの名無しさん:2014/08/08(金) 04:42:26.72 ID:1UU7vf/D
>>426
すべてが行き当たりばったりなんですね
431デフォルトの名無しさん:2014/08/08(金) 07:00:09.81 ID:/GOXeWKw
>>423
細かい突っ込みだが WTL は COM と関係ないべ
432デフォルトの名無しさん:2014/08/08(金) 09:24:29.43 ID:gW33htdT
433デフォルトの名無しさん:2014/10/23(木) 13:56:20.92 ID:ISc0F2Qf
OLEオブジェクトにゼロデイ脆弱性、Microsoftが暫定対策プログラムを公開
http://www.forest.impress.co.jp/docs/news/20141022_672480.html
434デフォルトの名無しさん:2014/11/07(金) 16:14:18.00 ID:tCwEoRvN
分散オブジェクトは距離に応じた最適な大きさ(機能)があって、
一律の仕組みにすることが最良ではなかった。
435デフォルトの名無しさん:2014/12/06(土) 08:07:09.24 ID:1X8GhzUe
>>430
だがそれがいい
436デフォルトの名無しさん:2014/12/08(月) 00:18:29.73 ID:imKvrg71
COMは.NETの登場で廃れると思ってたが結局10年経っても廃れなかったな、ネイティブコードの言語が健在だから
437デフォルトの名無しさん:2014/12/08(月) 10:11:02.56 ID:rVPpfxjW
非同期処理には向いてないっぽい
438デフォルトの名無しさん:2014/12/12(金) 09:04:26.82 ID:s5Npqjiu
DCOMの非同期版みたいなのをMSが考案してMSJかMSDNマガジンでそれを読んだが、全く流行らなかった。名前も思い出せないわ。
439デフォルトの名無しさん:2014/12/12(金) 11:51:31.03 ID:RkbkbG+A
結局、MS Office は .NET では書かれないんだからな。そりゃCOMとOLEが残るわな。
440デフォルトの名無しさん:2014/12/12(金) 11:55:33.92 ID:r3Fvlg1D
OOOとかLibreOとかGoogleSpreadsheetとかで間に合うのに
なんでみんな有料のものを喜んで買うんだ
441デフォルトの名無しさん:2014/12/12(金) 12:16:02.48 ID:j/Rc/sNK
MS自体がデスクトップアプリで.NETなんか使わんと言ってるようなもんだからな
442デフォルトの名無しさん:2014/12/13(土) 00:14:39.65 ID:pBf+dW7w
DLLとしてのCOM実装は実行オーバーベッドもないし、それでいてコンポーネントベースのオブジェクト指向を実現できるからな、シンプルでよく出来てる

流行り廃りではなく、ネイティブコードならいつまでも使い続けらる技術だよ

.NETには何の魅力も長所も感じない

動作が遅い、デフォで導入されてない.NETフレームワークのインストールも、OSに任せればインターネット接続が要るし、丸ごと再頒布するにはデカ杉
443デフォルトの名無しさん:2014/12/13(土) 00:17:26.75 ID:hYWK5mUP
最近のOSには入ってるしインストールの手間はないだろ
444デフォルトの名無しさん:2014/12/13(土) 00:25:07.03 ID:pBf+dW7w
Win8からは.NET fxはVer4.5しかインストールされてないよ、デフォでは

.NET3とか2のエンジンは、Windows Featureのon/offの所からから明示的に導入しないと、.NETランタイム不在と認識される

.NET4は3や2の代用にはならない
445デフォルトの名無しさん:2014/12/13(土) 00:34:37.63 ID:pBf+dW7w
.NET fx2の再頒布モジュールは30~40MBでたいして大きくはないんだけど、それを製品に添付してインストールしようとすると、Win8はそれを利用しないんだよね

確かにインストールは開始するんだけど、持ち込んだ.NET fx2は古すぎて気に入らないのか、無視してネットからDLしようとする

かといってもっと新しい.NET fx2再頒布モジュールがある訳でもない
446デフォルトの名無しさん:2014/12/13(土) 04:28:04.73 ID:jrsNMnhJ
何がんばっちゃってんのこいつ?
447デフォルトの名無しさん:2014/12/13(土) 06:14:24.22 ID:KcZztYF+
448名無しさん@そうだ選挙に行こう:2014/12/14(日) 11:37:06.17 ID:X+6lyliS
.NETからDLL呼ぶためにはP/Invokeを手で書かないといけないけど、COMDLLならTLBからインタロップ自動生成してるから楽
まあ普通のDLLもIDLファイル作っとけばいいんだろうけど、普通やらないもんな
449デフォルトの名無しさん:2015/01/02(金) 20:24:42.85 ID:mlj15zVW
Inside COM(日本語版)って結構高く売れんのかね?
450デフォルトの名無しさん:2015/01/02(金) 20:29:14.43 ID:F7Nf/+TC
>>449
今更新規に学ぶ人なんか居ないから売れない
既に理解してる身としてはまだまだ使い道ある技術だけどね
451デフォルトの名無しさん:2015/01/03(土) 01:17:50.23 ID:AuGuhWCh
>>449
読んだのはだいぶ前だけどそこそこ勉強にはなったな
COMの利点はC++で作ったDLLを他の言語から使えるって事かな
OSの基本機能はC++で実装する事がほとんどだろうからCOM自体は永久に無くならんだろうね
452デフォルトの名無しさん:2015/01/03(土) 11:28:31.16 ID:duDbuP4G
ステマ乙
453デフォルトの名無しさん:2015/01/03(土) 15:18:55.60 ID:AuGuhWCh
>>452
ステマって誰が儲かんだよw
ま、いい売り文句を言えたと理解しておこう
454デフォルトの名無しさん:2015/01/06(火) 08:32:22.24 ID:c/PNiN5K
元々はC++のvtblを巧みに利用したインターフェース志向の技法で、DLLというコンポーネント分散によって言語依存が消えた

でBasic言語にC++のvtbl構造を模倣する仕組みを入れてCOMをネイティブにあつかえるようにしてVBAが出来た

てことなんだろうと思う
455デフォルトの名無しさん:2015/01/06(火) 23:31:34.41 ID:KFlyuGQs
>>454
VBからCOMが使えるのは間違い無いが、VBから使う時は名前(文字列)によるメソッド検索をしてると
Inside COMに書いてあった気がする (QueryInterfaceだっけ?)
どっちにしても、言語に依存しないのはいい事だ

LinuxはC言語が唯一のインターフェースだから、そろそろ言語非依存のインターフェースが普及してほしいよ
候補は色々あるけど、どれも普及はしてないな
456デフォルトの名無しさん:2015/01/06(火) 23:34:43.36 ID:C2mmH5Le
IDispatchだろ
457デフォルトの名無しさん:2015/01/06(火) 23:47:22.80 ID:KFlyuGQs
>>456
すまん…スゲー昔の記憶だけ書き込んでた…
反省はしてない
458デフォルトの名無しさん:2015/01/06(火) 23:50:36.05 ID:kiKfNKwr
>>456
だね、俗に言うレイトバインディング
VB4まではそれしか使えなかった
459デフォルトの名無しさん:2015/01/07(水) 00:33:09.37 ID:A8Vu2ukb
>>455
Win32だってC言語ベースのAPIだからね
DirectXとか一部だけでしょCOMなのは

C++の抽象クラスとvtblをつかったポリモーフィズム技法をDynamic Libraryに適用すればCOMもどきはできるんじゃないかな

WindowsでのCOM DLLみたいに、OSからの認識規則なんかを誰かが決めてやらないとダメだけど
460デフォルトの名無しさん:2015/01/07(水) 02:06:30.69 ID:HBIMK+Li
ORBとかCORBAでしょ
XPCOMとかもあったけどLinuxでは結局どれも流行らなかったのかな
Linuxだと普通GPLでソース公開だから、そんなもの使わなくてもスタティックリンクでokってことなのかもな
461デフォルトの名無しさん:2015/01/07(水) 07:25:24.74 ID:nx6cbjbg
>>449
Inside OLE(日本語版)がAmazonで良い値が付いてるな
売ろうかw
462デフォルトの名無しさん:2015/01/07(水) 08:53:21.20 ID:v+HQiVT1
初期のOLEはCOMではなくDDEで動いてたんだっけ

OLEはアタマが付いていかなくて最後まで仕組みを理解できなかったな
463デフォルトの名無しさん:2015/01/07(水) 09:04:35.98 ID:7s8hjn62
いまはwebAPI全盛だな
464デフォルトの名無しさん
>>460
Linux上だと↓これだけあるかな

CORBA (Orbit2 GNOMEが使ってた)
XPCOM (Firefox)
UNO (OpenOffice.orgとその派生)
D-Bus

よく考えたらD-Busもコンポーネントモデルとも言えるしかなり普及してたよ
つう事でLinuxにはD-Busがあると言えるかな