you can't get in trouble with your boss for picking C#

L

Lyndon Samson

------=_Part_25442_32243826.1126843733903
Content-Type: text/plain; charset=ISO-8859-1
Content-Transfer-Encoding: quoted-printable
Content-Disposition: inline
=20
But i'm still convinced that ruby in ruby will got give us any real
benefits.
=20

How about dynamic analysis of code blocks suitable for JIT'ing or loop=20
unrolling etc?

How about AST analysis?

None of these require ruby but the higher level view of the logic may allow=
=20
better optimisations.

------=_Part_25442_32243826.1126843733903--
 
P

Phlip

Lyndon said:
How about dynamic analysis of code blocks suitable for JIT'ing or
loop unrolling etc?
How about AST analysis?

Note that there are three general ways to implement code:

- test driven development
- design by contract with proofs (Ada SPARKS)
- debugging day and night

Ruby has the first one nailed. Conquering the second one would put a lock on
the industry, and would demonstrate proof-driven development in a dynamic
language.

Has this worked in that other self-compiling language, Smalltalk?
 
R

Robert Klemme

Kirk said:
Many things in the Ruby universe are enterprise ready, at least for
some enterprises.

Btw, is J2EE enterprise ready? Is there a significant number of
applications out there that make full use of J2EE's feature set (including
scalability features) and serve large numbers of concurrent users? I'm
not prejudicing, just curious.

Regards

robert
 
R

Roland Schmitt

Hi!

Robert said:
Btw, is J2EE enterprise ready? Is there a significant number of
applications out there that make full use of J2EE's feature set (including
scalability features) and serve large numbers of concurrent users? I'm
not prejudicing, just curious.

Regards

robert



Yes, they are.
I'm working in a company with products based on J2EE/JBoss where the
scalability is one reason for our customers to choice the products. They
want to add users as they need and the front-end is a rich-client for
image processing, not only a web front-end.

In my opinion it is a good choice for decent applications, but not a
general solution for all tasks.

Regards,
Roland
 
R

Robert Klemme

Roland said:
Robert Klemme wrote:
Yes, they are.
I'm working in a company with products based on J2EE/JBoss where the
scalability is one reason for our customers to choice the products.
They want to add users as they need and the front-end is a
rich-client for image processing, not only a web front-end.

Can you post some figures (# of hosts, max concurrent users etc.) or is
this somehow confidential?
In my opinion it is a good choice for decent applications, but not a
general solution for all tasks.

Like so many...

Thanks!

robert
 
R

Roland Schmitt

Robert said:
Can you post some figures (# of hosts, max concurrent users etc.) or is
this somehow confidential?
Ok, looked at my current installations, find one with:
- 10 Servers (8*CPUs...)
- 120-160 Users
- Oracle and MSSSQL-DBs
- SAP-Integration

Hmm, ok, it is not that big, but because it is an type of accounting
system, it must be very reliable/scalable.


Regards,
Roland
 
T

Tim Sutherland

C# is heavily taking ideas from Ruby right now -- which is no surprise,
really.

Example from future C# ...

IEnumerable<string> expr = names
.Where(s => s.Length == 5)
.OrderBy(s => s.Foo)
.Select(s => s.ToUpper());
 
R

Robert Klemme

Roland said:
Ok, looked at my current installations, find one with:
- 10 Servers (8*CPUs...)
- 120-160 Users
- Oracle and MSSSQL-DBs
- SAP-Integration

Hmm, ok, it is not that big, but because it is an type of accounting
system, it must be very reliable/scalable.

You need 80 CPU's to serve 120-160 concurrent users? That would be 2
concurrent users per cpu *max*. This certainly sounds like bad resource
usage - or did I miss something here?

robert
 
L

Lothar Scholz

Hello Robert,


RK> You need 80 CPU's to serve 120-160 concurrent users? That would be 2
RK> concurrent users per cpu *max*. This certainly sounds like bad resource
RK> usage - or did I miss something here?

Maybe you missed the bad word in his email: SAP

It is a common joke that you need a SUN Enterprise Server for each user.
 
R

Roland Schmitt

Robert said:
You need 80 CPU's to serve 120-160 concurrent users? That would be 2
concurrent users per cpu *max*. This certainly sounds like bad resource
usage - or did I miss something here?

It is not that simple. There is a lot of graphic processing, character
recognition, web services and SAP.

So i think it is not an "typical example" where you use J2EE more or
less as a backend-end for a browser application.

Regards,
Roland
 
J

Josh Charles

JC> Very interesting. But you'll still need C ;) I'm interested to know
JC> how this will effect performance, thoug.
=20
No, you need C to implement a virtual machine, but not for the
language parser/bytecode compiler/runtime.
=20
But i'm still convinced that ruby in ruby will got give us any real
benefits.

My Point was that you still need to use C (a _strongly_ typed
language) at some point, or else you can't do what you want to do. I
was still reacting to the guy that flat out said that stronly typed
languages were just wrong. My entire point is that your should use
the best tool for the job. it would be bad idea to implement
something like basecamp in C. It would also be a bad idea to
implement the latest NVidia 3D device driver in Ruby.
 
A

Austin Ziegler

My Point was that you still need to use C (a _strongly_ typed
language) at some point,

C is anything *BUT* a strongly typed language. C is a very weakly typed
language that use some static type analysis for some optimizations. C++
is only marginally more strongly typed than C. Java and C# are also only
marginally more strongly typed than C++, in turn. There is a distinct
difference between the strong/weak typing axis and the static/dynamic
typing axis. Ruby is strong-dynamic; Ada is strong-static; C is weak-
static; JavaScript is weak-dynamic.

C's primary advantages are how close the development model is to the
bare metal of the machine without being tied to a single machine
architecture ("portable assembly") and that many thousands of man-years
of effort have been put into optimizing code generated by C compilers.
or else you can't do what you want to do.

Your assertion here is wrong. One does not require a strongly typed or
even a statically typed language to do what you're suggesting. What you
need is a development model that makes it easy to adapt to the hardware
on which you're developing. Ruby is several abstraction levels above the
hardware, and *that* is what I believe makes it difficult to consider
writing an OS in Ruby. That said, I will *also* point out that many
early operating systems were developed entirely in machine code or
assembly language, neither of which can be described as either strongly
or statically typed.
I was still reacting to the guy that flat out said that stronly typed
languages were just wrong.

I don't agree with Phlip here, but he's not completely *wrong*, either.
Static typing is a false promise -- it gives a promise of compile-time
correctness, but if you've ever had to debug a C program, you know
better. Statically typed languages -- which is what he was actually
talking about, and I'll thank you to not confuse the two axes -- aren't
the panacea or the benefit that their advocates claim. Dynamically typed
languages are far more suitable to *most* problems than statically typed
languages.
My entire point is that your should use the best tool for the job. It
would be bad idea to implement something like basecamp in C. It would
also be a bad idea to implement the latest NVidia 3D device driver in
Ruby.

Not if Ruby had a good model for generating optimized machine code for
that NVidia 3D device driver. C is appropriate because it's effectively
and efficiently portable while remaining close to the hardware on which
it is to run. It is also highly optimized and optimizable to machine
code. Solve those, and Ruby is appropriate for developing device drivers
as well as for developing Rails websites.

-austin
--=20
Austin Ziegler * (e-mail address removed)
* Alternate: (e-mail address removed)
 
D

Daryl Richter

Austin said:
[snip]
My Point was that you still need to use C (a _strongly_ typed
language) at some point,


C is anything *BUT* a strongly typed language. C is a very weakly typed
language that use some static type analysis for some optimizations.

"C is strongly-typed" is indeed a pernicious meme.

[Richter@GEN-WAYNE ~/src/c]$ cat weak_type.c
#include <stdio.h>

int main()
{

int i = 2000000000;
int j = 2000000000;
int k;

k = i * j;

printf( "%d * %d = %d\n", i, j, k );

}

[Richter@GEN-WAYNE ~/src/c]$ a.exe
2000000000 * 2000000000 = -1651507200

[rest snipped]
 
K

Kirk Haines

Btw, is J2EE enterprise ready? Is there a significant number of
applications out there that make full use of J2EE's feature set (including
scalability features) and serve large numbers of concurrent users? I'm
not prejudicing, just curious.

Fortunately, the last time I had to face the Java/Web world was 3 years and 5
months ago, and I have been making enterprise use of Ruby ever since then.


Kirk Haines
 
J

Josef 'Jupp' SCHUGT

Hi!

What is "enterprise ready"?

Such terms are called "buzzwords" where a buzzword is a word

- that is used ubiquitously,

- the meaning of which everyone knows, and

- that n people are known to assign (at least) n+1 different meanings.

Buzzwords are often used in modern fairy tale telling branches like
advertising, marketing and promotion.

Josef 'Jupp' SCHUGT
 
P

Phlip

Josh said:
My Point was that you still need to use C (a _strongly_ typed
language) at some point, or else you can't do what you want to do. I
was still reacting to the guy that flat out said that stronly typed
languages were just wrong.

First, some guideposts. C is weakly statically typed. Ruby is strongly
dynamically typed. Ada is strongly statically typed. Perl is weakly
dynamically typed.

Next, some definitions. "Strong" means you cannot glom two variables
together and the compiler will "guess" how to resolve their types. Perl is
"weak" when it lets you do this because in Perl everything is a string, so
every activity that's not obviously math can resolve to a string
manipulation.

"Dynamic" means all objects inherit from a great Object in the sky, which
virtually contains every possible method. So the line foo.bar() will compile
and run for any foo of any type that contains any bar(). "Static" means the
compiler trivially checks at compile time that all use of foo.bar() use a
foo that refers to an object of a class in the same inheritance hierarchy.
bar() must only bind to a single root bar() that all variations must derive
from.
My entire point is that your should use
the best tool for the job. it would be bad idea to implement
something like basecamp in C. It would also be a bad idea to
implement the latest NVidia 3D device driver in Ruby.

Totally. The closer to the metal, the more you need a strong statically
typed language. (C, a weak language, squeaks by because everyone who learns
it knows how to use it strongly.)

The closer to the user, the more you need a strong dynamic language, for the
command-and-control stuff. Note that the popular ORBs (CORBA, ActiveX), are
strongly dynamically typed, regardless of the languages that support them.

I forgot what I wrote, but what I meant was "static typing is wrong". Hacks
like generics are attempts to put "a little" dynamic typing into static
typing languages. Static typing should be optional, and it should not be an
excuse not to write unit tests. They make static typing less important for
robustness.
 
T

ToRA

Hey all,

On the typing issues, it seems that the third axis of declarative vs
inferred typing has been missed.

For example, in Java/C# etc. you have to declare the type of any and
every variable you create. In languages like ML / Haskell, the
compiler is able to infer the types of your variables (you may
optionally expicitly declare the type of them yourself if you want).
If you want a language that mixes the whole
dynamic/static/optional/inferred system there's Boo sitting on codehaus
that (the last time I looked) does all of those, which was quite neat.
[Tho .NET based]

Of course in the dynamic languages where the checks are done at
runtime, it doesn't make sense to declare the types yourself. Of
course some level of static typing / static analysis in a language like
ruby is still useful (e.g. for accurate IDE code completions)
I forgot what I wrote, but what I meant was "static typing is wrong".
I'd disagree, static typing is right, forced declaritive typing is
wrong. The computer should be able to infer the types of most things.

I'll admit that actually writing the algorithms to do the inference for
something as dynamic as ruby would be hard (and probably provably
"impossible") to cover every case, but if you're coding in the sane
90%ish of the language that doesn't use eval or equivalent to redefine
every method call to something else, then you should be able to have
the computer check that you are doing something right, or at least not
somethign that is impossibly wrong.
Hacks like generics are attempts to put "a little" dynamic typing into static
typing languages.
Actually, (java) generics adds a small layer of static safety to what
would other-wise would only be a dynamic operation. (Tho in java the
dynamic check is still made).
Static typing should be optional,
Declaritive typing should be optional. Static typing should be used
for whatever can be analysed, and dynamic typing the rest.
and it should not be an excuse not to write unit tests. They make static typing less important for robustness.
Absolutly, stepping back into context, type errors are just a small
subset of all the kinds of programming errors that tests (in all
guises) should be used to pick up on.

My £0.02

Tris
 
P

Phlip

ToRA said:
On the typing issues, it seems that the third axis of declarative
vs inferred typing has been missed.

That's because I don't understand it.
For example, in Java/C# etc. you have to declare the type of any
and every variable you create. In languages like ML / Haskell,
the compiler is able to infer the types of your variables (you may
optionally expicitly declare the type of them yourself if you want).

Woah, that is _exactly_ like the Eclipse editor for Java. If you don't
declare the type correctly, Eclipse will infer what it is (I suspect by
running a Java parser inside Java), and at a keystroke will push the correct
type in.

Conclusion: Java + Eclipse == Haskell ;-)
I'll admit that actually writing the algorithms to do the inference for
something as dynamic as ruby would be hard (and probably provably
"impossible") to cover every case, but if you're coding in the sane
90%ish of the language that doesn't use eval or equivalent to redefine
every method call to something else, then you should be able to have
the computer check that you are doing something right, or at least not
somethign that is impossibly wrong.

We need look no further than the efforts to optimize Smalltalk to see how
far this concept can (and can't) push.
My £0.02

That's why I just added this:

http://www.c2.com/cgi/wiki?RubyVsJava

It compares Java's Log4j to its clone, Ruby's Log4r.

"So they both apparently solve exactly same problem in exactly the same way.

"log4j's src folder has 31,764 lines of code.

"log4r's src folder has 2,071 lines of code."

Some languages are just more fun to belt out lots of lines with, I guess...
 
L

Lothar Scholz

Hello ToRA,


T> For example, in Java/C# etc. you have to declare the type of any and
T> every variable you create. In languages like ML / Haskell, the
T> compiler is able to infer the types of your variables (you may
T> optionally expicitly declare the type of them yourself if you want).

You forget that this does absolutely not fit into the ruby model. You
can't do type inference with overloaded operators. I don't know
Haskell but i know a little bit of OCAML and there you have to use the
ugly floating point operators "+." etc.

Otherwise there is nothing the compiler can find out.

Ruby is highly overloaded, so type interference is almost impossible.
Take this together with all the other methods (i don't talk about eval
here) and you see that this is a different world.
 
P

Phlip

Lothar Scholz http://www.ruby-ide.com

Just a note, dude. I clicked on your URL there, and was greeted with...

"our full featured editor that is inspired by the famous emacs and vi
editors"

Your marketeers need to learn there's no faster way to turn some of us off
to an editor than praise its comparison to those pieces of crap. I worked vi
classic for 2 years, and vim for 2 years, and I will do anything to avoid
them.

If you all do indeed mean vim-like power without the f~~~ed up keystrokes,
find another way to say it. CUA keystrokes provide the flattest possible
learning curve for modern programmers...
 

Members online

No members online now.

Forum statistics

Threads
474,183
Messages
2,570,967
Members
47,517
Latest member
Andres38A1

Latest Threads

Top