Post #95,076
4/8/03 4:00:07 PM
|
Lots of ways
The Motif, X11 junk is one way to do OO C. Its hideous.
As for padding resumes - ObjC is a lot more impressive than "I can make objects in C" as this claim is so nebulous as to be worthless (and more importatantly - it often implies the guys is clueless as to what objects are). But that is another topic.
Anyhow, one way to do it is to stick function pointers into your structs. This is useful for relatively limited sorts of "objects". Like maybe IO descriptors that need to look the same regardless of whether you are writing to a file, socket, memory, etc... You only have a few "methods" so you can afford the redundancy of function pointers in the struct.
If you care about space at all, your struct layout basically needs to have a common header that you can always count on (so at one level all structs look alike), then you put the differing stuff below that. The simplest thing done is to stick an isA pointer first that points to a "class" record of some sort. The isA points to the method dictionary and object layout info - often stored in a linked list of some sort.
If you want to see how Objective C works - go to the Apple developers site and download the runtime. There are struct definitions for what a class is, what a method descriptor looks like, info on keeping name offsets in a lookup table, etc.
There's also a book on "design and implementation of C++" something like that - this is a good read if you want to see how to do it wrong. FWIW, C++'s biggest design error (IMNAAHO) is the vtable and name mangling. Tossing out the method descriptor info and relying on positional info is just plain the stupidest thing ever in code that is going to live longer than one dev cycle (basically all code).
I could write a book on this but the best thing is to look at lots of implementations and decide what you need. X11 stuff, C++ implementation, ObjectiveC runtime, and (I think - I forget if this is right) unix IO descriptors store function pointers for some ops to implement the "everything looks like a file" illusion.
"Packed like lemmings into shiny metal boxes. Contestants in a suicidal race." - Synchronicity II - The Police
|
Post #95,086
4/8/03 4:54:20 PM
|
That reminds me of another thread here.
Ovid may want to look at [link|http://z.iwethey.org/forums/render/content/show?contentid=66834|this] thread here, and take a gander at [link|http://www.nongnu.org/needle/|Needle].
Just passing on a pointer, so to speak....
Cheers, Scott.
|
Post #96,818
4/16/03 11:01:27 AM
|
Re: That reminds me of another thread here.
Needle is still a work in progress, and isn't ready for prime time. But it's already making me giggle madly, so in a few months I'll have something ludicrously cool to share. :)
|
Post #95,345
4/9/03 10:31:29 AM
|
Hold on here
Are you proposing to replace array of function pointers with a hash? Wouldn't it be a bit too slow? Are you saying that, say, Smalltalak does a lookup on method descriptor every time a message is passed?
--
It made Ketchup! Sweet Ketchup! Put it on a hot dog, put it on a burger, Put it on your sister and she'll holler blody murder! Sweet Ketchup.
--Tom Paxton.
|
Post #95,408
4/9/03 1:42:28 PM
|
Not too slow
slower? OK sure.
We have GIGAHertz machines these days and smalltalk was originally working with decent performance on 8MHz boxes.
Now to be fair, ST has some tricks. One is that the very most common message sends to the most common objects are actually treated specially and implemented as byte code ops - its sort of the 80/20 rule. So for instance the #ifTrue: message
finished ifTrue: [ dosomething ]
is pedagogically implemented as a polymorphic message to Boolean with specializations in subclasses True and False - but this isn't how it *really* works. Instead the compiler generates special instructions for a small number of key messages (which you can change BTW). Loops are also treated specially.
Otherwise - yeah - there's a lookup. Its a pretty cheap lookup though.
Plus, having the methods in a method dictionary lets you do crazy things like create new kinds of scope, wacky fallback strategies, etc....
Smalltalk is an environment that will let you create pretty much any kind of programming model you like.
"Packed like lemmings into shiny metal boxes. Contestants in a suicidal race." - Synchronicity II - The Police
|
Post #95,427
4/9/03 3:53:39 PM
|
C++ also uses lookups...
...when you declare your functions as Virtual - which is really the only proper way to do methods for objects.
|
Post #95,542
4/9/03 8:24:38 PM
|
No
C++ uses an index into an array of function pointers. Very fast, not terribly future-proof. Smaltallk (if I get it right) uses hashing on actual function signature. For most cases. My head is still spinning.
--
It made Ketchup! Sweet Ketchup! Put it on a hot dog, put it on a burger, Put it on your sister and she'll holler blody murder! Sweet Ketchup.
--Tom Paxton.
|
Post #95,609
4/9/03 11:33:43 PM
|
Method Dispatch in Smalltalk
Smaltalk (if I get it right) uses hashing on actual function signature. For most cases. My head is still spinning.
Strickly speaking, you are correct. However, most modern Smalltalks will optimize that lookup quite heavily. A Cincom developer once described to me the mechanism they use to make method lookups (on the average) faster than the typical implementation of C++ virtual method dispatch. Fascinating stuff!
-- -- Jim Weirich jweirich@one.net [link|http://w3.one.net/~jweirich|http://w3.one.net/~jweirich] --------------------------------------------------------------------- "Beware of bugs in the above code; I have only proved it correct, not tried it." -- Donald Knuth (in a memo to Peter van Emde Boas)
|
Post #95,782
4/10/03 1:39:03 PM
|
Yep - pretty amazing stuff
It totally depends on the implementation and there are a lot of really clever tricks. It might not seem like it - but ST actually (sometimes) gets you closer to the metal in a lot of nifty ways than something like C. Its very freaky.
For instance, the opencroquet guys are moving a huge amount of rendering into graphics hardware despite the fact that you're calling it from Smalltalk with ST data structures.
"Packed like lemmings into shiny metal boxes. Contestants in a suicidal race." - Synchronicity II - The Police
|