Post #45,112
7/11/02 1:33:43 AM
|
Paul Graham on OO
(* When Paul Graham talks about patterns in his code, he means patterns up to and including "object-oriented programming." This isn't hyperbole, either, as CLOS -- the Common Lisp Object System, and one of the candidates for World's Most Powerful OO System *)
Paul Graham is not particularly hip about OO. He is leaving it out of his LISP-remake, ARC:
[link|http://www.paulgraham.com/noop.html| [link|http://www.paulgraham.com/noop.html|http://www.paulgraham.com/noop.html]]
Stepanov, who worked on STL, is another "respected" person who has bashed OO, BTW, complaining about its IS-A view of a HAS-A world.
________________ oop.ismad.com
|
Post #45,126
7/11/02 4:19:50 AM
|
Note his first criticism
A large part of his reason for not needing OO is access to and familiarity with more powerful programming techniques.
Techniques that I suspect would be even less to your liking than OO.
Cheers, Ben
"... I couldn't see how anyone could be educated by this self-propagating system in which people pass exams, teach others to pass exams, but nobody knows anything." --Richard Feynman
|
Post #45,239
7/11/02 8:24:56 PM
|
Elitist claim?
(* A large part of his reason for not needing OO is access to and familiarity with more powerful programming techniques. Techniques that I suspect would be even less to your liking than OO. *)
"More powerful"?
Such as?
I admit that in the past I have fussed about closures, but agree that they do seem to simplify code by roughly 2 to 5 percent (my rough guestimate). Nothing revolutionary though.
You are also implying that OO is for "middle of the road" programmers.
An odd response it was. (Damned Yoda syntax keeps popping up in my head after seeing "Clones" the other day.)
________________ oop.ismad.com
|
Post #45,241
7/11/02 9:10:14 PM
|
Don't guess, measure!
Look at your programs and count the number of times you use higher-order functions. I just looked at the code I wrote today in Ocaml. There's about 450 lines of code, in 29 functions.[*] 20 of those 29 use higher-order functions (ie, functions as values) in some way. 15 of the 20 that use higher-order functions explicitly construct closures. The other 5 simply take functions as arguments. That's way more than 2-5%. One of the reasons the percentage is so high is because I tend to use folds (like map or reduce in Python) instead of explicit recursion or looping. Eliminating explicit loops means I can't get the pattern of iteration wrong -- which makes a whole class of bugs impossible.
Anyway, I think Paul Graham is wrong about the usefullness of OO. But when you write the language, you get to decide what goes in it. That's why I'm writing my own language instead of complaining about Arc. :)
[*] Yeah, I know I should refactor -- 15 lines/function is on the high side. But this is pure throwaway exploratory code. Once I figure out how to do it at all, I'll make the code good.
|
Post #45,326
7/12/02 4:14:05 PM
|
Simplify
(* Eliminating explicit loops means I can't get the pattern of iteration wrong -- which makes a whole class of bugs impossible. *)
Yes, but messing up loops may only be a small portion of total errors.
Good API designs can reduce loop complexity. For example, looping thru a DB result set (or cursor) can be as simple as:
rs = openRS([criteria]) while getNext(rs) { [loop contents] }
What is there to screw up here?
Again, I am not hellbent against closures, but I think they are overrated. They confuse newbies and complicate the language, adding only a marginal improvement.
If you have a "killer example" of closures doing something realistic far better than traditional approaches, I would like to see it.
(Perhaps one could argue that closures help clean up or wrap bad API's.)
________________ oop.ismad.com
|
Post #45,381
7/12/02 8:19:18 PM
|
Re: Simplify
You wrote: > Good API designs can reduce loop complexity. For example, looping thru a > DB result set (or cursor) can be as simple as: > > rs = openRS([criteria]) > while getNext(rs) { > [loop contents] > } > > What is there to screw up here?
For one thing, you haven't closed the cursor. :)
This is a perfect example of why abstracting common patterns of iteration into a higher-level API is a good idea. Namely, you need to get the fold function correct once, and then every future use of it will be correct. In this case, if you had an iteration function available you would not have accidentally created a resource leak.
People -- all people -- are bad at repetition and detail work. If we have to repeat even a trivial task, then we will screw it up. For a simple example, try quickly counting from 1 to 300 out loud without screwing up. I just tried it, and got up to 114 before stumbling over my words. Now consider that this task is much easier than writing even the simplest computer program.
This is why I am so hell-bent on abstracting the common patterns in my code. I know that I suck at detail work. Closures are a good thing because they let me build my program out of tested, interchangeable parts.
|
Post #45,428
7/13/02 12:43:23 AM
|
Depends on the language
In many languages, when the database handle goes out of scope, it closes the cursor for you and cleans up. No leak.
OTOH when you get used to that and then need to work in an environment that doesn't have it, the adjustment is painful. I am even worse at detail work I have gotten out of the habit of doing... :-/
Cheers, Ben
"... I couldn't see how anyone could be educated by this self-propagating system in which people pass exams, teach others to pass exams, but nobody knows anything." --Richard Feynman
|
Post #45,584
7/15/02 12:01:18 AM
|
This is why I prefer PHP to C... :-)
"Ah. One of the difficult questions."
|
Post #45,245
7/11/02 10:06:20 PM
|
You can judge that for yourself
Go [link|http://www.paulgraham.com/onlisptext.html|download] a book of his and let us know when you have read enough of it to decide whether or not you like the way that he uses macros and closures.
Cheers, Ben
"... I couldn't see how anyone could be educated by this self-propagating system in which people pass exams, teach others to pass exams, but nobody knows anything." --Richard Feynman
|
Post #45,246
7/11/02 10:06:32 PM
|
You can judge that for yourself
Go [link|http://www.paulgraham.com/onlisptext.html|download] a book of his and let us know when you have read enough of it to decide whether or not you like the way that he uses macros and closures.
Cheers, Ben
"... I couldn't see how anyone could be educated by this self-propagating system in which people pass exams, teach others to pass exams, but nobody knows anything." --Richard Feynman
|
Post #45,138
7/11/02 10:13:53 AM
|
HAS-A is orthogonal to OO
As you have been told repeatedly.
Regards,
-scott anderson
"Welcome to Rivendell, Mr. Anderson..."
|
Post #45,163
7/11/02 12:12:02 PM
|
Guess you gotta...
Whip those Shapes thinga-ma-bobs out again.
That one in sed... just kills me.
I wondered why I was tan on my RIGHT side and not my left side after the trip...
greg, curley95@attbi.com -- REMEMBER ED CURRY!!!
|
Post #45,172
7/11/02 12:42:47 PM
|
Muah.
Regards,
-scott anderson
"Welcome to Rivendell, Mr. Anderson..."
|
Post #45,240
7/11/02 8:27:15 PM
|
It is more common in OO
(* HAS-A is orthogonal to OO, As you have been told repeatedly. *)
More OO newbies over-use IS-A than p/r newbies.
Further, the less IS-A you use in OO designs, the less OO it is. (Of course this gets into what the definition of OO is, which even OO fans cannot agree on.)
________________ oop.ismad.com
|
Post #45,259
7/11/02 11:27:31 PM
|
Don't go there. You will regret it.
"Ah. One of the difficult questions."
|
Post #45,855
7/17/02 1:32:20 AM
|
What is wrong with a little romp with a cute harmless troll?
________________ oop.ismad.com
|
Post #45,272
7/12/02 10:05:18 AM
|
Been down this road before...
and got sucky mileage with the Bryce-mobile.
I repeat: IS-A/HAS-A discussions are orthogonal to OO.
Any claims of suitability, "what everyone does", or resorting to your own definitions are merely hand-waving on your part, and do not change this.
Regards,
-scott anderson
"Welcome to Rivendell, Mr. Anderson..."
|
Post #45,330
7/12/02 4:27:29 PM
|
Defining definition
(* Any claims of suitability, "what everyone does", or resorting to your own definitions are merely hand-waving on your part, and do not change this. *)
I hate to tell you this, but "what everyone does" is pretty much how words get defined. You are not the Sole Oracle of Definitions.
If there is no bearing on common opinion, then why should I accept your definition over mine anyhow?
________________ oop.ismad.com
|
Post #45,335
7/12/02 4:43:17 PM
|
Mister...
Egads the man instantiated classes in SED for chris-sake...
How much more INANNE can you get than that.
It shows that OO is just a way to classify and flow the program... not the be all, end all you obviously think OTHERS think it is.
We can (given a bit of time and effort from somone other than you) use XBASE in an OO way. Easily you fail to understand the principle of the matter. Just because someone chooses to use OO does not mean thier programming is in anyway shape or form inferior... OR superior either.
What it does mean, there is a frame of work to use, and a framework to construct by, and framework to reference, a framework to work within, a framework to make other frameworks, a framworke to embbed another framework, a framework to be used in the wrong way, a framewaork to be ignored if they so choose.
That last statement, applies to nearly EVERYTHING built in this world, be it digital, analog or physical.
We understand, you believe OO is not the way of the world. I believe you are just a person trying to force us to your way of thinking... as my favorite saying goes...
"YOU DON'T UNDERSTAND!"
greg, curley95@attbi.com -- REMEMBER ED CURRY!!!
|
Post #45,431
7/13/02 1:12:39 AM
|
Frameworks and votes
There are frameworks for p/r also. They just tend to look and work differently.
(* We understand, you believe OO is not the way of the world. I believe you are just a person trying to force us to your way of thinking *)
That is exactly what OO has done to the industry, forced everybody into it wether they like it or not. Javatization has ruined the field.
There is no survey that shows most programmers prefer OO. Heck, many "high end OO experts" claim that most production programmers don't even know what OO is.
________________ oop.ismad.com
|
Post #45,513
7/14/02 3:05:57 AM
|
Now...
That we understand each other... Bryce leave it at that...
I know that frameworks are in everything that are programmed... It is just a matter of taste in the way you do things...
You can really(technically feasible but not reccomended)) even do assembly in an OO way... just like you can do it the p/r way...
Just because you don;t like OO, doesn't mean NO-ONE should... And just because OO "bigots" Like Scott Anderson (sorry for the dig there Scott), he shouldn;t expect people to forego anything OTHER than OO...
So like I am asking, OO is just as good and just as bad as ANY other way of programming... they all have thier goods and bads... You just learn to deal with them the way you prefer...
That is really what we have been trying to come to the agreement on. You sometimes tend to make this an all or nothing arguement, which of course it cannot be.
Thanks for the millions of keystrokes on this subject... lets wear out the ketboards on something else... Shall we?
greg, curley95@attbi.com -- REMEMBER ED CURRY!!!
|
Post #45,659
7/15/02 12:54:12 PM
|
Erect Ape
(* Just because you don;t like OO, doesn't mean NO-ONE should *)
1. I am saying that OOP is currently over-hyped and forced on too many programmers in practice. There are fewer places to get to get away from it.
2. OO fans here still seem to think that OOP is *objectively* better, and that those who don't like it are flawed upstairs not to see that. CRC called OOP "a natural and logical extension to structured programming" (paraphrased) as if it is an upright-walking ape.
If the hype about OO died down and more p/r techniques and API's came into the mix, then I would not be fussing nearly as much.
________________ oop.ismad.com
|
Post #45,717
7/15/02 9:10:12 PM
|
Hey.. I feel the *same* way about the tyranny of
Organized Religions\ufffd - and especially re the secondary effects, all so neatly chronicled by now.
But since this mindset leads to the periodic heaped dead burned bodies (in God's Name), I tend to think about the topic as not.. a mere bagatelle. But I don't expect the momentum to cease any time soon - not even as WW-The Last opens. 'We' aren't ready to break this habit, no matter the Next body-count. Or the Next.
Maybe it's ditto re Your fav Windmill? (however a much more trivial ultimate decision, it would seem.) Hell, maybe *none* of this stuff is Real?
Ashton Quixote Productions LLC Tell us Your Troubles and we'll explain how it was that You Caused Them.. cha cha cha.
|
Post #45,852
7/17/02 1:16:12 AM
|
What we need are more DISorganized religions? Hmmm
________________ oop.ismad.com
|