- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
Sometimes, the version of the language they are using didn't have the functionality available when it was written.
I don't really see anything wrong with this code. Maybe some spaces between casts. e.g.
Admin
Not quite. As has been said, the former is necessary if the assembly containing AxxxxMxxxxBxxxx is loaded at runtime. However, if it's referenced at compile time, then the second is the way to go. It will not generate false positives because it will only compile if there are no ambiguous type names referenced. If there are, you'll have either to explicitly state the namespace when using them or define an alias for them at the top of the file.
Admin
Also, the former is an absolute nightmare when it comes to maintainability/refactoring.
Admin
What? Do I detect some bitterness about C#? :)
You also need to KNOW that there's a DateDiff method in DateTime. Have you ever heard of something called documentation? How are overloaded operators a pain? How do they make coding a language "dangerous"? What's wrong with explicit conversions?
What could be more clear and intuitive than subtracting one date from another? There's only one thing it could possibly give you: the difference between them. Why bloat the class with unnecessary static methods? You do of course have to use them carefully, but used in moderation they're incredibly useful. Imagine you're writing a program to simulate physics: you have classes for vectors, matrices etc. Would you rather use Vector.Add(vector1, vector2), or vector1 + vector2? Or comparing assembly versions: Version.Compare(version1, version2) (which would have to return an integer or something) is horribly messy in comparison to version1 < version2 or version1 == version2.
Also, why the Christ would you use strings to tell a method what to do? Not only does it introduce the problem of validation, but it makes it very unclear as to what the string needs to contain (you'd have to trawl through the method's documentation to find out what strings are valid). If you use enumerations, however, it removes the necessity for validation (the program won't even compile if you don't pass the method a valid argument), but (with a good IDE, and something like IntelliSense, there's no need to look up the valid arguments to be used; they're already there in front of you.
Admin
Hah!!! Outstanding. Made my day. Thanks!
Hill
Admin
LOL what C# n00b wrote this one?
is not equal to
cause the first one checks for type equality while the second one checks if you can cast the object to the type
so the "corrected" code introduces a possible regression (in case you have castable classes that must be treated differently in the method)
Damn, the one who wrote this forum software must be publically executed, this f*cking POS requires users to loose their browsers' security settings to submit a f*cking piece of text
Admin
Not to mention that it's slow to access. I wouldn't be surprised if there weren't a few WTFs in the forums themselves.
Admin
Good point there Superlexx; I missed that hangs head in shame. Though in this case I'd be surprised if there were subclasses to deal with, you are entirely correct.
p.GetType() == typeof(Cxxxx.Cxxxx.Cxxxx.Wxxxx.AxxxxMxxxxBxxxx)
would be a better way to do it though, a string comparison against a constant is ugly.Admin
Not all languages support enums. Perhaps with a good IDE it will put help you put in the enums, but some of us don't like to shell out god knows how much money for Visual Studio. I agree that it's better to catch these types of errors at compile time, rather then run time, so that makes sense.
In ColdFusion for example, we can use CFEClipse (a free plugin to the open source Eclipse editor), which gives us the valid arguments to use for the string argument to DateDiff. It would be nice to catch issues at compile time, but coldfusion code is not compiled until it's run, so that's out anyway.
All I know is that ColdFusion could be coded in notepad, but I don't think you can say the same about ASP.NET for example. Maybe the express version of visual studio is enought to code ASP.NET pages, I don't know. But the language is unnesessarily complex
Admin
First ALL LANGUAGES are written in a text editors of some sort. No one would use them if they couldn't. The days of using punch cards is over m'friend. (So, yes ASP.NET can be coded using notepad. I've done it. It's a pain for anything more than Hello World but it can be done).
Second, .NET is not a scripted or interpreted language in the same way that Cold Fusion is. .NET code (C#, VB.NET, etc) when it is compiled it is really translated into an intermediate language (aka IL or MSIL). When that library or executable is first run, the IL is then compiled into binary if has not already been compiled. This is a big reason why .NET code is substantially faster than classic ASP or Cold Fusion: it is actually compiled binary code running and not being reinterpreted on each execution.
(Does anyone still develop real commerical sites in Cold Fusion any more? I thought it was totally defunct.)
Admin
XXX XXX XXX X X X X X X X X X X XXXXX XXX XXXXX