POV-Ray : Newsgroups : povray.off-topic : Java Server Time
1 Nov 2024 11:13:54 EDT (-0400)
  Java (Message 1 to 10 of 23)  
Goto Latest 10 Messages Next 10 Messages >>>
From: Darren New
Subject: Java
Date: 22 Sep 2011 13:56:35
Message: <4e7b76d3$1@news.povray.org>
I will say, I'm only back into Java for a week, and even in spite of Java 
generics and inner classes and all that, I'm already much more appreciative 
of how much crap MS fixed in C#. :-)  Stuff that's taking me 4 or 5 lines, 
with the types repeated three times each, is a one-liner in C#, even without 
LINQ.

-- 
Darren New, San Diego CA, USA (PST)
   How come I never get only one kudo?


Post a reply to this message

From: nemesis
Subject: Re: Java
Date: 22 Sep 2011 14:42:14
Message: <4e7b8186@news.povray.org>
Darren New escreveu:
> I will say, I'm only back into Java for a week, and even in spite of 
> Java generics and inner classes and all that, I'm already much more 
> appreciative of how much crap MS fixed in C#. :-)  Stuff that's taking 
> me 4 or 5 lines, with the types repeated three times each, is a 
> one-liner in C#, even without LINQ.

yeah, I like it how MS took ideas from Python and Haskell too.

-- 
a game sig: http://tinyurl.com/d3rxz9


Post a reply to this message

From: Invisible
Subject: Re: Java
Date: 23 Sep 2011 05:42:16
Message: <4e7c5478@news.povray.org>
On 22/09/2011 06:56 PM, Darren New wrote:
> I will say, I'm only back into Java for a week, and even in spite of
> Java generics and inner classes and all that, I'm already much more
> appreciative of how much crap MS fixed in C#. :-) Stuff that's taking me
> 4 or 5 lines, with the types repeated three times each, is a one-liner
> in C#, even without LINQ.

Now you know why I dislike using languages which aren't Haskell...


Post a reply to this message

From: Invisible
Subject: Re: Java
Date: 23 Sep 2011 11:28:20
Message: <4e7ca594$1@news.povray.org>
On 22/09/2011 06:56 PM, Darren New wrote:
> I will say, I'm only back into Java for a week, and even in spite of
> Java generics and inner classes and all that, I'm already much more
> appreciative of how much crap MS fixed in C#. :-)

Last time I used Java, we did a little dance. It went like this:



"Object-oriented programming allows you to use facilities such as 
subclassing to extend the application in ways the original designers 
never anticipated."

"By declaring your class 'final', you can prevent anybody subclassing it."



"Multiple inheritance is EVIL! We support only single inheritance."

"We support multiple inheritance using 'interfaces'. They're like 
classes, but not as good."



"For receiving input, use the InputStream classes. For output, use the 
OutputStream classes."

"For receiving input, use the Reader classes. For output, use the Writer 
classes. The InputStream and OutputStream classes are now formally 
deprecated. (Even though System.in, System.out and System.err mention 
them explicitly.)"



"We will never deprecate the AWT."

"The AWT is now deprecated. Please use Swing in new applications."



"To create a horizontal scrollbar, create a Scrollbar object passing the 
SCROLLBAR_AXIS_HORIZONTAL static constant. To create a vertical 
scrollbar, create a Scrollbar object passing the SCROLLBAR_AXIS_VERTICAL 
static constant. To determine whether a given scrollbar is horizontal or 
vertical, call getAxis() and compare against these static constants. Do 
not hard-code the numerical values, as more may be added in future."



"The 'int' type is not a class."

"If you want 'int' to be a class, you must wrap it using the 'Int' class."

"The int[] type is a class."



"For structuring complex applications, use the ApplicationFactory class."

"The ApplicationFactory class is now deprecated. Please use 
ApplicationCenter for new."

"The ApplicationCenter class is now deprecated. The ApplicationFactory 
class has been formally UNdeprecated. Please use ApplicationFactory for 
new applications."


Basically, the language is loaded with hypocrisy, and the libraries were 
huge, bloated, overly complex, insufficiently documented, and prone to 
radical alterations every minor point release. (In fact, I gather that 
these days, they don't even call it Java 1.5.x any more. They just call 
it 5.x...)

Last time I checked, java.awt.Component has about 80+ methods. Every 
single AWT widget inherits these 80+ methods. Any guesses what the hell 
the difference between widget.init(), widget.start() and widget.begin() 
is? The documentation helpfully fails to say. (E.g., "start() - starts 
the widget." Yeah, thanks for that. I gathered.)



It still amuses me how almost every statically-typed programming 
language lacks parametric types, /except/ for arrays, which are 
hard-wired into the language.

(It still makes me cry that Haskell to this day still doesn't support 
parametric unboxed arrays - you know, like what almost every programming 
language known to man /does/ provide, out of the box...)

In Java, "int" is not a class. But "int[]" is. In fact, every array is a 
class. And you cannot ever subclass it.

> Stuff that's taking me
> 4 or 5 lines, with the types repeated three times each, is a one-liner
> in C#, even without LINQ.

I love the way that with the JDK, compiling a class compiles every class 
it depends on, but declaring two mutually-dependent classes is enough to 
break the compiler. I wonder if they fixed that yet?

I love how you run your Java applet in IE and it works perfectly, and 
when you run it in Netscape it dies with java.lang.NullPointerException.

I love how we have System.err (because System.error would be far too 
verbose), and yet we have java.lang.ArrayIndexOutOfBoundsException. 
Because, say, java.language.exception.ArrayIndex would be too hard?

I still think that Java is a great /idea/ - you specify a programming 
language and a library of classes which is guaranteed to work the same 
on *all* platforms. That's a very neat idea.

I also still think that the actual Java /design/ and /implementation/ 
utterly suck. Nice idea, too bad it went so drastically wrong from 
thereon in.

(I suppose you could argue that C# is the same. You know, if it actually 
worked on more than one platform...)


Post a reply to this message

From: Mike Raiford
Subject: Re: Java
Date: 23 Sep 2011 12:43:42
Message: <4e7cb73e@news.povray.org>
On 9/23/2011 10:28 AM, Invisible wrote:

> (I suppose you could argue that C# is the same. You know, if it actually
> worked on more than one platform...)

Mono.

-- 
~Mike


Post a reply to this message

From: Orchid XP v8
Subject: Re: Java
Date: 23 Sep 2011 13:25:07
Message: <4e7cc0f3$1@news.povray.org>
On 23/09/2011 05:43 PM, Mike Raiford wrote:
> On 9/23/2011 10:28 AM, Invisible wrote:
>
>> (I suppose you could argue that C# is the same. You know, if it actually
>> worked on more than one platform...)
>
> Mono.

Does Mono support more than 0.2% of what .NET supports yet?

-- 
http://blog.orphi.me.uk/
http://www.zazzle.com/MathematicalOrchid*


Post a reply to this message

From: Jim Henderson
Subject: Re: Java
Date: 23 Sep 2011 14:20:42
Message: <4e7ccdfa$1@news.povray.org>
On Fri, 23 Sep 2011 18:25:07 +0100, Orchid XP v8 wrote:

> On 23/09/2011 05:43 PM, Mike Raiford wrote:
>> On 9/23/2011 10:28 AM, Invisible wrote:
>>
>>> (I suppose you could argue that C# is the same. You know, if it
>>> actually worked on more than one platform...)
>>
>> Mono.
> 
> Does Mono support more than 0.2% of what .NET supports yet?

Yes.  Go read the mono page and see what compatibility is.

Jim


Post a reply to this message

From: Darren New
Subject: Re: Java
Date: 24 Sep 2011 00:54:55
Message: <4e7d629f$1@news.povray.org>
On 9/23/2011 8:28, Invisible wrote:
> Last time I used Java, we did a little dance. It went like this:

I agree with every one of these rants.

Now, throw in Eclipse, as well as code that generates java code, which the 
IDE doesn't know about.

> "For receiving input, use the InputStream classes. For output, use the
> OutputStream classes."
>
> "For receiving input, use the Reader classes. For output, use the Writer
> classes. The InputStream and OutputStream classes are now formally
> deprecated. (Even though System.in, System.out and System.err mention them
> explicitly.)"

And now there's a third set, NIO, or "New I/O".  I wonder what they'll call 
the fourth set.

> "We will never deprecate the AWT."
> "The AWT is now deprecated. Please use Swing in new applications."

Yeah, I remember that one.

> "For structuring complex applications, use the ApplicationFactory class."
>
> "The ApplicationFactory class is now deprecated. Please use
> ApplicationCenter for new."
>
> "The ApplicationCenter class is now deprecated. The ApplicationFactory class
> has been formally UNdeprecated. Please use ApplicationFactory for new
> applications."

Oh, wait until you use some "dependency injection". Then you'll have *no* 
idea how your code is structured. You not only get the indirection of 
factories making other factories, but the factories you're depending on 
aren't even compiled at the same time as everything else. Good luck figuring 
out what you're trying to instantiate.

> documentation helpfully fails to say. (E.g., "start() - starts the widget."
> Yeah, thanks for that. I gathered.)

Yep, yep. Altho MS has been starting to do that sort of crap lately too, 
I've noticed.  The first release of Java had identical documentation for 
StreamReader and StreamWriter, because they did the cut-and-paste and forgot 
to change "read" to "write" everywhere.

> I love the way that with the JDK, compiling a class compiles every class it
> depends on, but declaring two mutually-dependent classes is enough to break
> the compiler. I wonder if they fixed that yet?

Nope.

> I love how we have System.err (because System.error would be far too
> verbose), and yet we have java.lang.ArrayIndexOutOfBoundsException. Because,
> say, java.language.exception.ArrayIndex would be too hard?

I did some code yesterday where I had to break one type name over multiple 
lines to keep within the 80-character line limit standard. It doesn't help 
when you have stuff like
   FastPersistentLinearCollection<OrganizationIndividualRelationshipEntity>

I kid you not.

-- 
Darren New, San Diego CA, USA (PST)
   How come I never get only one kudo?


Post a reply to this message

From: Orchid XP v8
Subject: Re: Java
Date: 24 Sep 2011 09:33:24
Message: <4e7ddc24@news.povray.org>
>> "For receiving input, use the InputStream classes. For output, use the
>> OutputStream classes."
>>
>> "For receiving input, use the Reader classes. For output, use the Writer
>> classes. The InputStream and OutputStream classes are now formally
>> deprecated. (Even though System.in, System.out and System.err mention
>> them
>> explicitly.)"
>
> And now there's a third set, NIO, or "New I/O". I wonder what they'll
> call the fourth set.

*facepalm*

>> "We will never deprecate the AWT."
>> "The AWT is now deprecated. Please use Swing in new applications."
>
> Yeah, I remember that one.

Was it you that said something about "committing to backwards 
compatibility way too early"?

>> "For structuring complex applications, use the ApplicationFactory class."
>>
>> "The ApplicationFactory class is now deprecated. Please use
>> ApplicationCenter for new."
>>
>> "The ApplicationCenter class is now deprecated. The ApplicationFactory
>> class
>> has been formally UNdeprecated. Please use ApplicationFactory for new
>> applications."
>
> Oh, wait until you use some "dependency injection". Then you'll have
> *no* idea how your code is structured. You not only get the indirection
> of factories making other factories, but the factories you're depending
> on aren't even compiled at the same time as everything else. Good luck
> figuring out what you're trying to instantiate.

It just amuses me that they thought the current design was bad, so they 
deprecated it and build a better replacement. And then they decided the 
repliacement was worse than the original, so they UNdeprecated it. I 
mean, WTF?

>> documentation helpfully fails to say. (E.g., "start() - starts the
>> widget." Yeah, thanks for that. I gathered.)
>
> Yep, yep. Altho MS has been starting to do that sort of crap lately too,
> I've noticed.

I notice Office no longer comes with any documentation at all, just a 
link to an online forum. (So if you have no Internet access, there's no 
documentation AT ALL.) That's a nice touch... Why pay for experts to 
write correct documentation when you can get your users to spread 
erroneous twiddle for free?

> The first release of Java had identical documentation for
> StreamReader and StreamWriter, because they did the cut-and-paste and
> forgot to change "read" to "write" everywhere.

Yep. That's the great thing about embedding documentation in the source 
code; it keeps the two in sync.

Oh, wait...

>> I wonder if they fixed that yet?
>
> Nope.

LOL. At least VisualStudio J++ got that right... (Oh, wait, Sun sued 
Microsoft to make them discontinue that product.)

> I did some code yesterday where I had to break one type name over
> multiple lines to keep within the 80-character line limit standard. It
> doesn't help when you have stuff like
> FastPersistentLinearCollection<OrganizationIndividualRelationshipEntity>
>
> I kid you not.

That's just silly...

-- 
http://blog.orphi.me.uk/
http://www.zazzle.com/MathematicalOrchid*


Post a reply to this message

From: Darren New
Subject: Re: Java
Date: 24 Sep 2011 11:37:28
Message: <4e7df938$1@news.povray.org>
On 9/24/2011 6:33, Orchid XP v8 wrote:
> Was it you that said something about "committing to backwards compatibility
> way too early"?

Yep. That was the fundamental failure, caused by the whole "write once" 
marketing campaign.

> I notice Office no longer comes with any documentation at all, just a link
> to an online forum.

It has documentation. It just mixes it in with the online forum. I think you 
have to chose to install it locally, tho, which is what you might be seeing.

>> I did some code yesterday where I had to break one type name over
>> multiple lines to keep within the 80-character line limit standard. It
>> doesn't help when you have stuff like
>> FastPersistentLinearCollection<OrganizationIndividualRelationshipEntity>
>>
>> I kid you not.
>
> That's just silly...

It makes perfect sense in context. It's just absurdly verbose.

What would be in C#

   var z = from y select z where z.id = myID

in java becomes

   List<OrganizationIndividualRelationshipEntity> z =
     Lists.ImmutableCopyOf(
       Lists.filter(y, new 
Predicate<List<OrganizationIndividualRelationshipEntity>() {
      @override boolean apply(OrganizationIndividualRelationshipEntity x) {
      return x.id = myID;
      }
     }
     )
     }

I've lost track of closing braces....
     )

-- 
Darren New, San Diego CA, USA (PST)
   How come I never get only one kudo?


Post a reply to this message

Goto Latest 10 Messages Next 10 Messages >>>

Copyright 2003-2023 Persistence of Vision Raytracer Pty. Ltd.