Jump to content

Talk:Comparison of C Sharp and Java

Page contents not supported in other languages.
From Wikipedia, the free encyclopedia
This is an old revision of this page, as edited by 176.195.178.252 (talk) at 04:15, 3 May 2014 (Arbitrary size decimals: new section). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.
WikiProject iconJava Start‑class Low‑importance
WikiProject iconThis article is within the scope of WikiProject Java, a collaborative effort to improve the coverage of Java on Wikipedia. If you would like to participate, please visit the project page, where you can join the discussion and see a list of open tasks.
StartThis article has been rated as Start-class on Wikipedia's content assessment scale.
LowThis article has been rated as Low-importance on the project's importance scale.

Speed/performance comparison

Microsoft bans benchmarking .NET Framework without their written permission: Microsoft .NET Framework Benchmark Testing Terms. And Mono is not the official .NET implementation to compare with Oracle Java. That's why adding speed/performance comparison to this article is not correct. So, based on above facts remove this section, please.69.18.50.2 (talk) 10:07, 2 December 2012 (UTC) cs_student[reply]

I still think performance would be an aspect readers would find relevant. I agree that the section as it stands now is misleading. We could remove it, but we could also try to work in the caveats you mention. Would you care to try? Useerup (talk) 11:29, 2 December 2012 (UTC)[reply]
The only implementation where its allowed to benchmark results for C# is Mono. Yet C# is shown supported on a variety of platforms in this article because of Mono. Plus the paragraph (at least now) shows clearly that the comparison is made with Mono. I don't know why it should be removed. Hervegirod (talk) 09:31, 20 December 2012 (UTC)[reply]
As I wrote, I absolutely believe the issue is relevant. There are some (very) old perf tests showing that .NET is faster than Java on Windows. They are dated and are probably not representative of the current state, and I'm not comfortable mentioning that in the paragraph. I would prefer that the article explain that there very well could be differences between the 1st party implementation and Mono but that there's no comparison data available because of the licensing terms. Useerup (talk) 12:11, 20 December 2012 (UTC)[reply]
A contractual ban on benchmark publishing seems like an antitrust violation that Microsoft could easily use to ensure that the only benchmarks that get published are ones that favor the .NET framework. That said, we have no reason to submit to their will. 68.173.113.106 (talk) 20:50, 21 July 2013 (UTC)[reply]

I updated this section to match the current link, Microsoft has changed their position on benchmarking should someone want to try to find references, seems they are mostly comparable from what I can tell.


5/24/2013: I removed this sectionEvolvedmicrobe (talk) 21:18, 24 May 2013 (UTC). Although I believe this is HIGHLY relevant to a comparison between the two and would love to see someone put it back in with a more thought out section. I thought it suffered from the following problems.[reply]

1 - The style and content of the opening paragraph was not up to par. This statement came off as pretty vacuous: "Comparing language speed is tricky. It depends on the virtual machine and the environment used. It can also depend on whether the benchmark code was written in an idiomatic or an optimised style."

2 - The benchmark tests given are not useful. Java and C# are such similar languages that it should have been possible to directly compare them by essentially writing the same program line for line. However the algorithms/code used in these benchmarks differs substantially (for example, encoding things as bytes versus unicode characters, writing multi-threaded versus single threaded applications, optimization switches, etc.). The largest difference between Mono/Java (Binary trees test) is entirely an artifact of mono being run with an outdated version of the garbage collector, and the more common microsoft implementation shows essentially no difference at all for that test.

I would love to see a more rigourous section developed here. This article: http://www.itu.dk/~sestoft/papers/numericperformance.pdf seems like it could be a good start, though it only focuses on numeric computations, and it seems comparing garbage collectors, native interopt, memory usage, etc. would all be important.

Unless the article can say something meaningful, well supported, and useful, I think this section should remain out. — Preceding unsigned comment added by Evolvedmicrobe (talkcontribs) 21:15, 24 May 2013 (UTC)[reply]

Addendum: Just noticed the article title says it is only comparing Microsoft to Oracle, I think we should expand that to Mono and IBM so we can add this performance section. — Preceding unsigned comment added by Evolvedmicrobe (talkcontribs) 21:44, 24 May 2013 (UTC)[reply]

Page Is Irrelevent

Is Wikipedia in the business of providing competing product comparisons?

These are two proprietary products produced by competing corporations. The features in both products are subject to change based on the owners goals and marketing decisions without public input. Thus many of the details are volitile and the article will quickly go stale. There are already inaccuracies on both sides of the comparison some due to the age of the article and others intended to skew the article.

The features comparison colors the yes and no values green and red respectively. This is an immediate value judgement on the included of featues. Due to this red/green coloring a minority of the tables of features have more red boxes on the C# side than the Java side. A simple glance at this bias reveals an immediate inference that C# is better than Java, despite many of the features that are not in Java are conscious design decision by Sun/Oracle.

It could be said that Microsoft has taken a kitchen sink approach to language design while Sun/Oracle has taken a more measured approach to feature inclusion. This is implied by the discussion about keyword growth in Java vs C#. So, as a common comparing any two languages in computer science, feature count and quality of features are not relevent to language utility, inferiority, or superiority. Thus the red/green coloring is misleading and at times innaccurate.

Finally, the code samples are also misleading. All the code samples as displayed have a greater line count for Java than the 'equivelent' C# implying Java is more verbose. In the article this is true for multiple reasons. The algorithms are different. In the Input/output section the Java example uses buffered IO while the C# sample does not. The Java implementation uses a superfluous File object constructor on both input and output which is not necessary (Constuctors for FileReader and FileWriter exist with a String argument for a file path like C#). Also to make the IO buffered in the C# example would need a call to a BufferedReader and BufferedWriter constructor to bring the number of constructor calls between the two samples equal.

Similarly, the "Pass by Reference" uses style to increase the line count Java sample. First: The swap method adds a line of whitespace after the temporary variable initialization. Second: A three line comment is added above the main method in the Java example. Third: the output line at the end of the main method is split into two lines in the Java example while being syntactically identical. Finally, even more damning the example is chosen to show the differences in C# and Java while casting the Java in a bad light because it "still" has not changed the value of s. Another equally simple example can be chosen where C# does not produce the results expected.

These are just two of the examples of how code that is contended to be "equal" is used to show disadvantages in Java. There are more.

This page should be scrapped and not rewriten for the reasons stated at the top. If not scrapped is should be rewritten to remove biases noted above.

One last note, I make my living writing C# code.

The views expressed in this article are solely the views of the author and not the owner of this IP address.

Seconded - this entire article is clearly VERY biased. EboMike (talk) 20:53, 2 March 2013 (UTC)[reply]
Thirded... While something like this could be useful (and it actually did answer a question I was looking up), it is in no way encyclopedic in nature. Something like this belongs on a tech advice site like stackoverflow, not wikipedia. Potatman (talk) 16:50, 15 March 2013 (UTC)[reply]
Fourthed. It's an unbalanced article, and it appears to be not consistent about trying to compare contemporaneous language specifications, a clear indication of poor research. (It doesn't belong on StackOverflow though; it would be rapidly closed as flamebait.) It's a shame, as a balanced comparison would be a genuinely useful thing, but I get the impression that most people preferring one or the other regard the trade-offs they are making as reasonable (assuming they don't go for outright language partisan fanboyism foolishness). Unfortunately, the proportion of academic — i.e., properly peer reviewed — references used is very small; having more independent voices describing the differences would be helpful here because of the languages' shared history. Or the core language designers from either side; I doubt they'd indulge in the sort of poor scholarship displayed here. 82.42.214.208 (talk) 01:04, 3 October 2013 (UTC)[reply]

I found it very informative though, and filled with useful information — Preceding unsigned comment added by 132.183.102.105 (talk) 23:43, 12 March 2013 (UTC)[reply]

Sure, it may have information in it, but that doesn't change the fact that it is not suitable for Wikipedia in its current form. EboMike (talk) 02:04, 22 March 2013 (UTC)[reply]


Page is very useful - An encylopedia at best is a source of useful knowledge, this page contains a great deal of useful information. In response to arguments that this is irrelevant:

  • These are two proprietary products produced by competing corporations.

Ignoring how C# and Java are open standards, why would this matter? If there was an article on advertising strategies of Coca-Cola and Pepsi it would still be interesting and useful.

  • Many of the details are volitile (sic) and the article will quickly go stale.

That what we know changes is not a reason to never teach. What is the current status of hormone replacement therapy? How about dietary recommendations of sodium levels?

  • Other issues related to colors and verbosity

Someone cleaned these up "try {" in Java versus "try\n\t{" in C#. Variable usage of white space is irrelevant, the reader will know that, ditto with colors.

  • Bias

If information is incorrect or presented in a poor fashion, it should be removed. This is an entirely separate issue. Why in the "Pass by reference" only immutable and basic types are used? String in Java is well known to be immutable while StringBuffer is the corresponding mutable class, in this case it seems that in java all the values are passed by reference. 194.127.8.25 (talk) 13:31, 4 October 2013 (UTC)Marco (talk) 15:04, 4 October 2013 (UTC)[reply]

  • Not Encyclopedic

Admittedly, Britannica probably would not have this article. Britannica is also not as good as wikipedia. This article is a compendium recommending a lot of good information. People need to get things done with computers, C/Java/Python/C++/C#/Haskell are all ways to get stuff done, how do they compare? Many people have found this article useful. — Preceding unsigned comment added by Evolvedmicrobe (talkcontribs) 21:42, 24 May 2013 (UTC)[reply]

Err... Java is an open standard. 68.173.113.106 (talk) 21:01, 21 July 2013 (UTC) (woops, sorry! I thought it was but the oracle google lawsuit made me wonder.[reply]
I agree there really is no point to having articles like this at all. This is something that makes sense for a Gartner or Forrester report but not an encyclopedia. MadScientistX11 (talk) 21:02, 17 December 2013 (UTC)[reply]

Reference Type - Delete Phantom Reference Discussion?

I think there is a section that needs to be deleted, but am worried I have missed something so wanted to ask for comments before doing so.

The section on reference types contains this sentence:

" Soft references are much like weak references, but the JVM will not deallocate softly-referenced objects until the memory is actually needed."

But the cardinal rule of garbage collection (at least as I understand R/C#/Java) is that memory is only de-allocated/garbage-collected when memory is needed, never before. As such, I don't understand the distinction from a weak reference, and think the table should be condensed.

Anyone object (or see the error?)

Cheers, N Evolvedmicrobe (talk) 04:28, 1 November 2013 (UTC)[reply]

Language history and evolution -outright bias

This section is terrible, and terribly unencylopedic. Java comes off as the George Orwell "Animal Farm" of computing, while C# sounds like the tyrant with operational efficiency. I think framing the historical perspective is very important, but it comes off so biased I think deleting it entirely would add to the article. An alternative would be to cut any post-2000 (the debut of C#) reference from the article. Would anyone be opposed to this? Evolvedmicrobe (talk) 04:40, 1 November 2013 (UTC)[reply]

I'm a little tired of seeing accusations of 'bias' here; as far as I can see, the Java section is just sloppy, and the claims made there can be substantiated with references or deleted. However it would be good to avoid creating complete version histories of both and refer to Java version history, Java (software_platform)#History, C Sharp (programming_language)#History, and .NET Framework version history for details instead. Rp (talk) 10:16, 1 November 2013 (UTC)[reply]

Agreed! 132.183.101.106 (talk) 22:04, 1 November 2013 (UTC)[reply]

Arbitrary size decimals

C# offers BigInteger that fits the description. Consider changing "no" to "yes"