473,320 Members | 2,035 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,320 software developers and data experts.

what's OOP's jargons and complexities?

in computer languages, often a function definition looks like this:

subroutine f (x1, x2, ...) {
variables ...
do this or that
}

in advanced languages such as LISP family, it is not uncommon to define
functions inside a function. For example:

subroutine f (x1, x2, ...) {
variables...
subroutine f1 (x1...) {...}
subroutine f2 (x1...) {...}
}

often these f1 f2 inner functions are used inside f, and are not
relevant outside of f. Such power of the language gradually developed
into a style of programing. For example:

subroutine a_surface () {
coordinatesList = ...;
subroutine translate (distance) {...}
subroutine rotate (angle) {..}
}

such a style is that the a_surface is no longer viewed as a function.
But instead, a boxed set of functions, centered around a piece of data.
And, all functions for manipulating this piece of data are all embodied
in this function. For example:

subroutine a_surface (arg) {
coordinatesList = ...
subroutine translate (distance) {set coordinatesList to translated
version}
subroutine rotate (angle) {set coordinatesList to rotated version}
subroutine return () {return coordinatesList}

if (no arg) {return coordinatesList}
else { apply arg to coordinatesList }
}

In this way, one uses a_surface as a data, which comes with its owe set
of functions:

mySurface = a_surface();
a_surface(rotate(angle)); # now the surface data has been rotated
a_surface(translate(distance)); # now its translated
myNewSurface = a_surface(return())

So now, a_surface is no longer viewed as a subroutine, but a boxed set
of things centered around a piece of data. All functions that work on
the data are included in the boxed set. This paradigm available in
functional languages has refined so much so that it spread to other
groups that it became knows as Object Oriented Programing, and complete
languages with new syntax catered to such scheme emerged.

In such languages, instead of writing them like this:

mySurface = a_surface();
a_surface(rotate(angle));

the syntax is changed to like this, for example:

mySurface = new a_surface();
mySurfaceRotated = mySurface.rotate(angle);

In such languages, the super subroutine a_surface is no longer called a
function or subroutine. They are now called a "Class". And now the
variable "mySurface = a_surface()" is now called a "Object". The
subroutines inside the function a_surface() is no longer called
inner-subroutines. They are called "Methods".

This style of programing and language have become so fanatical that in
such dedicated languages like Java, everything in the language are
"Classes". One can no longer just define a variable or subroutine.
Instead, one creates these meta-subroutine "Classes". Everything one do
are inside Classes. And one assign variables inside these Classes to
create "Objects". And one uses "Methods" to manipulate Objects. In this
fashion, even data types like numbers, strings, and lists are no longer
atomic data types. They are now Classes.

For example, in Java, a string is a class String. And inside the class
String, there are Methods to manipulate strings, such as finding the
number of chars, or extracting parts of the string. This can get very
complicated. For example, in Java, there are actually two Classes of
strings: One is String, and the other is StringBuffer. Which one to use
depends on whether you intend to change the data.

So, a simple code like this in normal languages:

a = "a string";
b = "another one";
c = join(a,b);
print c;

or in lisp style

(set a "a string")
(set b "another one")
(set c (join a b))
(print c)

becomes in pure OOP languages:

public class test {
public static void main(String[] args) {
String a = new String("a string");
String b = new String("another one");
StringBuffer c = new StringBuffer(40);
c.append(a); c.append(b);
System.out.println(c.toString());
}
}

here, the "new String" creates a String object. The "new
StringBuffer(40)"
creates the changeable string object StringBuffer, with room for 40
chars. "append" is a method of StringBuffer. It is used to join two
Strings.

Notice the syntax "c.append(a)", which we can view it as calling a
inner subroutine "append", on a super subroutine that has been assigned
to c, where, the inner subroutine modifies the inner data by appending
a to it.

And in the above Java example, StringBuffer class has another method
"toString()" used to convert this into a String Class, necessary
because System.out.println's parameter requires a String type, not
StringBuffer.

For a example of the complexity of classes and methods, see the Java
documentation for the StringBuffer class at
http://java.sun.com/j2se/1.4.2/docs/...ingBuffer.html

in the same way, numbers in Java have become a formalization of many
classes: Double, Float, Integer, Long... and each has a bunch of
"methods" to operate or convert from one to the other.

Instead of

aNumber = 3;
print aNumber^3;

in Java the programer needs to master the ins and outs of the several
number classes, and decide which one to use. (and if a program later
needs to change from one type of number to another, it is often
cumbersome.)

This Object Oriented Programing style and dedicated languages (such as
C++, Java) have become a fad like wild fire among the programing
ignoramus mass in the industry. Partly because of the data-centric new
perspective, partly because the novelty and mysticism of new syntax and
jargonization.

It is especially hyped by the opportunist Sun Microsystems with the
inception of Java, internet, and web applications booms around 1995. At
those times, OOP (and Java) were thought to revolutionize the industry
and solve all software engineering problems, in particular by certain
"reuse of components" concept that was thought to come with OOP.

As part of this new syntax and purity, where everything in a program is
of Classes and Objects and Methods, many many complex issues and
concept have arisen in OOP.

we now know that the jargon Class is originally and effectively just a
boxed set of data and subroutines, all defined inside a subroutine. And
the jargon "Object" is just a variable that has been set to this super
subroutine. And the inner subroutines are what's called Methods.

-----------------

because of psychological push for purity, in Java there are no longer
plain subroutines. Everything is a method of some class. Standard
functions like opening a file, square root a number, for loop thru a
list, if else branching statements, or simple arithmetic operations...
must now some how become a method of some class. In this way, the OOP
Hierarchy is born.

Basic data types such as now the various classes of numbers, are now
grouped into a Number class hierarchy, each class having their own set
of methods. The characters, string or other data types, are lumped into
one hierarchy class of data types. Many types of lists (variously known
as arrays, vectors, lists, hashes...), are lumped into a one hierarchy,
with each node Classe having their own set methods as appropriate. Math
functions, are lumped into some math class hierarchy.

Now suppose the plus operation +, where does it go? Should it become
methods of the various classes under Number headings, or should it be
methods of the Math class set? Each language deals with these issues
differently. As a example, see this page for the hierarchy of Java's
core language classes:
http://java.sun.com/j2se/1.4.2/docs/...kage-tree.html

The hierarchy concept is so entangled in pure OOP such that OOP is
erroneously thought of as languages with a hierarchy. (there are now
also so-called Object-Oriented databases that are centered on the
concept of all data are trees ...)

Normally in a program, when we want to do some operation we just call
the subroutine on some data. Such as

open(this_file)
square(4)

But now with the pure OOP style, there can no longer be just a number
or this_file path, because everything now must be a Object. So, the
"this_file", usually being just a string representing the path to a
file on the disk, is now some "file object". Initiated by something
like

this_file = new File("path to file");

where this file class has a bunch of methods such as reading or writing
to it.

see this page for the complexity of the IO tree
http://java.sun.com/j2se/1.4.2/docs/...kage-tree.html

see this page for the documentation of the File class itself, along
with its 40 or so methods and other things.
http://java.sun.com/j2se/1.4.2/docs/...a/io/File.html

Tomorrow i shall cover more manmade jargons and complexities arising
out of the OOP hype, in particular Java.

instantiation
initializer, constructor, assessor
access level specifier
abstract class and abstract methods
instance methods and class methods
interface, inheritance, polymorphism.
Xah
xa*@xahlee.org
http://xahlee.org/PageTwo_dir/more.html

Nov 14 '05 #1
18 1355

"Xah Lee" <xa*@xahlee.org> wrote in message
news:11**********************@f14g2000cwb.googlegr oups.com...
public class test {
public static void main(String[] args) {
String a = new String("a string");
String b = new String("another one");
StringBuffer c = new StringBuffer(40);
c.append(a); c.append(b);
System.out.println(c.toString());
}
}


Actually, it can be as simple as:
public class test {
public static void main(String[] args) {
String c = new String("a string"+" another one");
System.out.println(c);
}
}

I will not get into your "history" of the "OOP hype".
Nov 14 '05 #2

"Dan Perl" <da*****@rogers.com> wrote in message
news:U9********************@rogers.com...
Actually, it can be as simple as:
public class test {
public static void main(String[] args) {
String c = new String("a string"+" another one");
System.out.println(c);
}
}


I forgot. It can be even simpler:

public class test {
public static void main(String[] args) {
System.out.println("a string"+" another one");
}
}
Nov 14 '05 #3
Dan Perl wrote:
Actually, it can be as simple as:
public class test {


There is no "public" or "class" in C. Please don't post such trash to
comp.lang.c. In fact, C++ is not topical in any of the five newsgroups
you posted to. I don't know where you're posting from, so I apologize to
the perl, python, lisp, scheme, and C people who see this in their
newsgroups. Followup-To set to comp.lang.c++ where you can play with
your bloated language all you wish.
Nov 14 '05 #4
"Xah Lee" <xa*@xahlee.org> writes:
[snip]

If you must post a followup to this, please drop comp.lang.c from the
newsgroups header. I can't speak for the other newsgroups, but it's
definitely off-topic here in comp.lang.c. Thank you.

--
Keith Thompson (The_Other_Keith) ks***@mib.org <http://www.ghoti.net/~kst>
San Diego Supercomputer Center <*> <http://users.sdsc.edu/~kst>
We must do something. This is something. Therefore, we must do this.
Nov 14 '05 #5
Xah Lee wrote his usual masturbatory crap:

Lisp is not topical in 3 of the 5 newsgroups you spewed on.
Java is not topical in 5 of the 5 newsgroups you spewed on.
Get your head out your butt and post to Java newsgroups if you want and
they'll have you. Are you inflicting this crap on the rest of us
because the Java people know you to be a troll?
Followup-to set to comp.lang.java.advocacy where it might belong.
Nov 14 '05 #6
Xah Lee wrote:
[...]
Tomorrow i shall cover more manmade jargons and complexities arising
out of the OOP hype, in particular Java. [...]


I hope you will not, or that if you do so you will
do it elsewhere. Go pound sand.

--
Eric Sosman
es*****@acm-dot-org.invalid
Nov 14 '05 #7
Martin Ambuhl <ma*****@earthlink.net> writes:

| Dan Perl wrote:
|
| > Actually, it can be as simple as:
| > public class test {
|
| There is no "public" or "class" in C. Please don't post such trash to
| comp.lang.c. In fact, C++ is not topical in any of the five

But, it was anything but C++. Maybe Java.

--
Gabriel Dos Reis
gd*@integrable-solutions.net
Nov 14 '05 #8
Good post.

First article that demistifies this OO centered approach
in quite a long time.

This approach has its strength, but also has it weakness,
it is not the solution for every problem appearing in
data processing.

Nov 14 '05 #9
Gabriel Dos Reis wrote:
Martin Ambuhl <ma*****@earthlink.net> writes:

| Dan Perl wrote:
|
| > Actually, it can be as simple as:
| > public class test {
|
| There is no "public" or "class" in C. Please don't post such trash to
| comp.lang.c. In fact, C++ is not topical in any of the five

But, it was anything but C++. Maybe Java.


And why is Java topical for any of the five newsgroups he spewed on,
which deal with perl, python, lisp, scheme, and C? There must be a high
correlation between using Java and idiocy.
Nov 14 '05 #10
Martin Ambuhl wrote:
<snip>
And why is Java topical for any of the five newsgroups he spewed on,
which deal with perl, python, lisp, scheme, and C? There must be a high
correlation between using Java and idiocy.


If you set followups (and I certainly agree that you had cause on this
occasion), please indicate the fact in the body of your article in
future. Thank you.
Nov 14 '05 #11
jacob navia <ja***@jacob.remcomp.fr> writes:
Good post.

First article that demistifies this OO centered approach
in quite a long time.


I have no idea whether it was "good" or not, but it was blatantly
off-topic in at least comp.lang.c, and probably all the other
newsgroups to which it was cross-posted. Jacob, please don't
encourage this kind of newsgroup abuse.

--
Keith Thompson (The_Other_Keith) ks***@mib.org <http://www.ghoti.net/~kst>
San Diego Supercomputer Center <*> <http://users.sdsc.edu/~kst>
We must do something. This is something. Therefore, we must do this.
Nov 14 '05 #12
jacob navia <ja***@jacob.remcomp.fr> wrote in news:41fb3c85$0$10470
$8*******@news.wanadoo.fr:

[ Follow-ups set to news.misc ]
First article that demistifies this OO centered approach
in quite a long time.


Dear Jacob and others reading comp.lang.c:

Xah Lee is a known troll. He admits to being a troll on his web site. For
the last two or so weeks, he has been cross-posting to Python and Perl
groups in the hopes of starting a Python-Perl flamewar. It seems like
broadened his "horizons" when that failed.

I do remember the comp.lang.c group being a more excitable bunch but
please try not to feed the troll. To put it mildly, he has issues. Don't
own those issues. Please.

Relevant links:

http://xahlee.org/Netiquette_dir/troll.html

Maybe the increased number of hits to his web site will make him feel
better about himself and thus slow him down a little.

Sinan.
Nov 14 '05 #13
jacob navia wrote:

Good post.

First article that demistifies this OO centered approach
in quite a long time.

This approach has its strength, but also has it weakness,
it is not the solution for every problem appearing in
data processing.


Xah Lee is a known troll, who likes to crosspost to many OT groups
and stir up the ants. F'ups set.

--
"If you want to post a followup via groups.google.com, don't use
the broken "Reply" link at the bottom of the article. Click on
"show options" at the top of the article, then click on the
"Reply" at the bottom of the article headers." - Keith Thompson
Nov 14 '05 #14

Xah Lee wrote:
in computer languages, often a function definition looks like this: xa*@xahlee.org
http://xahlee.org/PageTwo_dir/more.html


Your ideas are original, insightful and simply reflect incredibly deep
creative genius. I have read your work and I want to hire you for
highly classified work in software design and philosophical writing.
Would you possibly be available to meet with me in my secret mountain
compound to discuss terms?

Larry

Nov 14 '05 #15
"Larry" <la**********@yahoo.com> writes:
Xah Lee wrote:
in computer languages, often a function definition looks like this:

xa*@xahlee.org
http://xahlee.org/PageTwo_dir/more.html


Your ideas are original, insightful and simply reflect incredibly deep
creative genius. I have read your work and I want to hire you for
highly classified work in software design and philosophical writing.
Would you possibly be available to meet with me in my secret mountain
compound to discuss terms?

Larry


You forgot to mention the coordinates of your secret mountain compound:

28 deg 5 min N, 86 deg 58 min E
--
__Pascal Bourguignon__ http://www.informatimago.com/

Nobody can fix the economy. Nobody can be trusted with their finger
on the button. Nobody's perfect. VOTE FOR NOBODY.
Nov 14 '05 #16
Pascal Bourguignon escreveu:
"Larry" <la**********@yahoo.com> writes:

Xah Lee wrote:
in computer languages, often a function definition looks like this:

xa*@xahlee.org
http://xahlee.org/PageTwo_dir/more.html


Your ideas are original, insightful and simply reflect incredibly deep
creative genius. I have read your work and I want to hire you for
highly classified work in software design and philosophical writing.
Would you possibly be available to meet with me in my secret mountain
compound to discuss terms?

Larry

You forgot to mention the coordinates of your secret mountain compound:

28 deg 5 min N, 86 deg 58 min E

Pascal!!

You spoiled a carefully kept Larry's secret. . . now it will have to
change his compound. . .

Nov 14 '05 #17
Pascal Bourguignon wrote:
You forgot to mention the coordinates of your secret mountain compound:

28 deg 5 min N, 86 deg 58 min E


Mount Everest?
Nov 14 '05 #18
Grumble <de*****@kma.eu.org> wrote:
Pascal Bourguignon wrote:
You forgot to mention the coordinates of your secret mountain compound:

28 deg 5 min N, 86 deg 58 min E


Mount Everest?


Shhh!
--
Bradd W. Szonye
http://www.szonye.com/bradd
Nov 14 '05 #19

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

24
by: Xah Lee | last post by:
in computer languages, often a function definition looks like this: subroutine f (x1, x2, ...) { variables ... do this or that } in advanced languages such as LISP family, it is not uncommon...
56
by: Xah Lee | last post by:
What are OOP's Jargons and Complexities Xah Lee, 20050128 The Rise of Classes, Methods, Objects In computer languages, often a function definition looks like this: subroutine f (x1, x2, ...)...
18
by: Xah Lee | last post by:
What are OOP's Jargons and Complexities Xah Lee, 20050128 Classes, Methods, Objects In computer languages, often a function definition looks like this: subroutine f (x1, x2, ...) {...
0
by: DolphinDB | last post by:
Tired of spending countless mintues downsampling your data? Look no further! In this article, you’ll learn how to efficiently downsample 6.48 billion high-frequency records to 61 million...
0
isladogs
by: isladogs | last post by:
The next Access Europe meeting will be on Wednesday 6 Mar 2024 starting at 18:00 UK time (6PM UTC) and finishing at about 19:15 (7.15PM). In this month's session, we are pleased to welcome back...
0
by: jfyes | last post by:
As a hardware engineer, after seeing that CEIWEI recently released a new tool for Modbus RTU Over TCP/UDP filtering and monitoring, I actively went to its official website to take a look. It turned...
0
by: ArrayDB | last post by:
The error message I've encountered is; ERROR:root:Error generating model response: exception: access violation writing 0x0000000000005140, which seems to be indicative of an access violation...
1
by: CloudSolutions | last post by:
Introduction: For many beginners and individual users, requiring a credit card and email registration may pose a barrier when starting to use cloud servers. However, some cloud server providers now...
1
by: Shællîpôpï 09 | last post by:
If u are using a keypad phone, how do u turn on JavaScript, to access features like WhatsApp, Facebook, Instagram....
0
by: af34tf | last post by:
Hi Guys, I have a domain whose name is BytesLimited.com, and I want to sell it. Does anyone know about platforms that allow me to list my domain in auction for free. Thank you
0
by: Faith0G | last post by:
I am starting a new it consulting business and it's been a while since I setup a new website. Is wordpress still the best web based software for hosting a 5 page website? The webpages will be...
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 3 Apr 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome former...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.