Understanding COM - DevCon 2022
Links and resources from my talk today at Access DevCon Vienna 2022, Understanding COM.
data:image/s3,"s3://crabby-images/7677d/7677dc8b5e2d7f69828f95b97d431c98c0fadf90" alt="Understanding COM - DevCon 2022"
Slide Deck
UnderstandingCOM-DevCon2022.pdf
Further Reading
High-Level COM Overview
What the #$%& is COM!?
One of the most important concepts in VBA is also one of the least understood. Let’s shine a light on the Component Object Model.
data:image/s3,"s3://crabby-images/80bae/80bae041ce0741384421280f9ed3b00d2c1d10d4" alt=""
What is COM?
The concept of COM explained in under 100 words. #Under100
data:image/s3,"s3://crabby-images/b4d31/b4d3185881286feadf333b4e4fe9bd0d6d327e13" alt=""
High Level Overview of COM
This whirlwind tour of the Component Object Model technology will jump start your journey of automating Excel from VBA in Access.
data:image/s3,"s3://crabby-images/17110/171100da7179510b333e90f98b0420edfbde8fd8" alt=""
Overcoming Programming Language Barriers with COM
COM is sort of like a Chinese restaurant.
data:image/s3,"s3://crabby-images/e15d9/e15d90172611624270eddebcf05082621eeba488" alt=""
Early vs. Late Binding at the Chinese Restaurant
In this continuation of our Chinese restaurant-COM metaphor, we expand the example to illustrate the differences between early and late binding.
data:image/s3,"s3://crabby-images/928d8/928d8f26c27b6b6e7dae115159d7a907ebb3958f" alt=""
Managing Memory in COM
We continue on with our restaurant analogy to explain the concept of reference counting and COM object cleanup.
data:image/s3,"s3://crabby-images/4f77c/4f77c6be1c38e84090f1b71f042204d18e94fa61" alt=""
COM Server Types: In-Process vs. Local vs. Remote
There are three basic types of COM servers: in-process, local, and remote. What do they have in common? What are the differences? Let’s explore.
data:image/s3,"s3://crabby-images/94081/94081bfc3b8da98e36e96fb13c2cbd26f6557011" alt=""
Low-Level Details
The IUnknown Interface
All COM objects are required to support at least one interface: the IUnknown interface. In this short article, we explore the three methods of IUnknown.
data:image/s3,"s3://crabby-images/7cfc1/7cfc11a32dbbd0010a72c8d1da718ee98b2af4e7" alt=""
The IDispatch Interface
For a COM object to support late binding in VBA, it must implement the IDispatch interface. Let’s explore IDispatch and its four methods.
data:image/s3,"s3://crabby-images/ada41/ada4193d908254a2b005bfa9706e1c3169b7ee1e" alt=""
Reference Counting’s Fatal Flaw: Circular References
We look at several types of circular references along with a handy tool that you can use to help identify circular references in your own code.
data:image/s3,"s3://crabby-images/97739/977396ceca6fc3e6b53c1742e6240e3eaed4b2f9" alt=""
Loading VBE Addins - A Windows Registry Tour
Let’s pull back the curtain and see how VBA loads VBE COM add-ins via a series of registry calls.
data:image/s3,"s3://crabby-images/4875f/4875fe7ac9bee232c2b407d9c17f84c935b1e419" alt=""
Practical Applications
Microsoft Office COM Automation Libraries
The VBA developer’s guide to automating Microsoft Office applications: early vs late binding; CreateObject vs GetObject; and tips on cleaning up after yourself.
data:image/s3,"s3://crabby-images/08058/0805837a1ce210feceb44ced735027865ddfa712" alt=""
Early Binding vs. Late Binding: The Essential Guide for VBA Developers
The Absolute Minimum Every VBA Developer Absolutely, Positively Must Know About Early and Late Binding in COM (No Excuses!)
data:image/s3,"s3://crabby-images/f0333/f033386220db85aa68f1c2a890aafda38ff4eb7d" alt=""
Future Presentations
If you enjoyed today's presentation, you can catch me at the following upcoming events:
Access Europe – Mike Wolfe (Building Ribbon Interfaces in Code) – Europe – AccessUserGroups.org
data:image/s3,"s3://crabby-images/4a558/4a55899da4a073fdb1b5305058aa8c17fdd75bde" alt=""