What is the most common error in a .Net application?
-
You should program in Objective C where it is legal to invoke methods on nulls.
id v = nil;
NSString* valueAsString = [v description];modified on Monday, December 15, 2008 2:58 PM
Rama Krishna Vavilala wrote:
in Objective C where it is legal to invoke methods on nulls
It is legal in C++ too, and in some weird cases can be even safe :)
-
In .net it is the classic "object reference not set to an instance of an object". Speaking of bugs, I started a new position back in June. This company (not an IT company) does an amazing job of testing. The first application I did here was coded in about 4 weeks by myself and a consultant. The company used the application in test for an entire month before we rolled it out. It has been live for six weeks now without one bug or code change required. This is the first time, I have accomplished this.
I didn't get any requirements for the signature
ToddHileHoffer wrote:
The company used the application in test for an entire month before we rolled it out. It has been live for six weeks now without one bug or code change required.
If the pay is decent and they don't require you to become a manager to get a raise, you have probably died and gone to Paradise.
Jon Smith & Wesson: The original point and click interface
-
ToddHileHoffer wrote:
The company used the application in test for an entire month before we rolled it out. It has been live for six weeks now without one bug or code change required.
If the pay is decent and they don't require you to become a manager to get a raise, you have probably died and gone to Paradise.
Jon Smith & Wesson: The original point and click interface
Oakman wrote:
If the pay is decent and they don't require you to become a manager to get a raise, you have probably died and gone to Paradise.
It is not paradise, but it is a damn good job. I feel very lucky.
I didn't get any requirements for the signature
-
Last week we had a code delivery. We have been taught from the graduation days that ToString() without a null check is a bomb. Still we got it in a critical part . "Object reference not set" My vote goes for it.
modified on Monday, December 15, 2008 2:26 PM
Turning on the computer. At least, today it is for me. I'm having total brain fade, can hardly remember how to type, never mind code.:)
Henry Minute Never read Medical books. You could die of a misprint. - Mark Twain
-
well,grammer may be wrong,but I meant the same. It will instantly give error if you try to set null to an integer,right? why double standard to string where you can set it to nothing but not otherwise? :) (Just consider this as an emotional outburst. I don't really want to excuse people forgetting a null check)
jith - iii wrote:
. It will instantly give error if you try to set null to an integer,right? why double standard to string where you can set it to nothing but not otherwise?
There is no double standard. All reference types behave the same way. It is perfectly valid in many situations for a reference to be null. The compiler cannot catch logic errors, only syntax errors. System.Int32 is a value type. It is not valid ever for a value type to be null therefore the compiler can and will catch it for you.
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
-
In .net it is the classic "object reference not set to an instance of an object". Speaking of bugs, I started a new position back in June. This company (not an IT company) does an amazing job of testing. The first application I did here was coded in about 4 weeks by myself and a consultant. The company used the application in test for an entire month before we rolled it out. It has been live for six weeks now without one bug or code change required. This is the first time, I have accomplished this.
I didn't get any requirements for the signature
People whose careers actually depend on the software they use often test much better than purely IT types, after going through the blood, sweat, and tears of finding out that their careers DO depend on results of the software. I've found this time and time again over the course of my career.
-
:) ...but I don't know, ToString() is quite popular here. It's coming repeatedly everywhere. May be,people Trim() only after they polish the null refernece with ToString()
jith - iii wrote:
ToString() is quite popular here. It's coming repeatedly everywhere
Well I wish it wasn't. The number of times I've been through code written by complete Muppets who call ToString() on everything (especially on strings themselves) is depressing. I even saw someone call ToString() on an integer, pass it to a Method and for the method to Parse it back to an integer again. That method was only ever called from one place! There was no need. The quality of some code is arse-paralysingly mind blowing!
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
-
That is something I do not understand. Why ToString() can't handle the "null" automatically? It must have a good reason.
TOMZ_KV
Tomz_KV wrote:
Why ToString() can't handle the "null" automatically? It must have a good reason.
There is a very good reason. It is because the left side of the dot operator must contain an instance of an object.
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
-
add a static extension method
string string.ToString(string target)
{
return (target ?? "").ToString();
}or simply code your ToString calls as:
(target ?? "").ToString()
ahmed zahmed wrote:
add a static extension method
You break the semantics of the dot operator if you do that. Crazy Extension Method[^] But there is redemption: Crazy Extension Method (redux)[^]
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
-
jith - iii wrote:
. It will instantly give error if you try to set null to an integer,right? why double standard to string where you can set it to nothing but not otherwise?
There is no double standard. All reference types behave the same way. It is perfectly valid in many situations for a reference to be null. The compiler cannot catch logic errors, only syntax errors. System.Int32 is a value type. It is not valid ever for a value type to be null therefore the compiler can and will catch it for you.
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
OMG...I was not asking a question. I was not referring the difference between value type and reference type. I think I was having a fair idea about atleast value types and reference types. Let me clarify it was not my code which has got broken here, though I also had contributed my share of null reference exception earlier. When I said I wish null.ToString() to be handled automatically,I really don't wish to be so. Why I said is the people here who code like this have fair idea abou null reference exception and they themselves have made many. Still these type of errors creep into the code and it becomes a big issue in the managerial level. I thought it would be considered as a joke. But someone has 1 voted me down.
modified on Tuesday, December 16, 2008 12:25 PM
-
jith - iii wrote:
ToString() is quite popular here. It's coming repeatedly everywhere
Well I wish it wasn't. The number of times I've been through code written by complete Muppets who call ToString() on everything (especially on strings themselves) is depressing. I even saw someone call ToString() on an integer, pass it to a Method and for the method to Parse it back to an integer again. That method was only ever called from one place! There was no need. The quality of some code is arse-paralysingly mind blowing!
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
What about this code then which I have seen today written by someone.
Dim var1 as String=String.Format("{0}\", value1)
Dim var2 as String=String.Format("{0}\", value2)
Dim var3 as String=String.Format("{0}\", value3)
Dim var4 as String=String.Format("{0}\", value4)Dim FinalString as String=var1+var2+var3+var4
PassToFunction(FinalString)
No tester could report a bug for this code.
-
add a static extension method
string string.ToString(string target)
{
return (target ?? "").ToString();
}or simply code your ToString calls as:
(target ?? "").ToString()
ahmed zahmed wrote:
(target ?? "").ToString()
mine is VB.Net :(. This is the first time I'm touching vb.net and it irritates. in C# after intellisence if you click "enter" it would come perfectly. But here it goes to next line and cribs. so many like this.
ahmed zahmed wrote:
??
And it's .Net 2.0
modified on Tuesday, December 16, 2008 2:37 PM
-
Tomz_KV wrote:
Why ToString() can't handle the "null" automatically? It must have a good reason.
There is a very good reason. It is because the left side of the dot operator must contain an instance of an object.
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
That is a valid reason and a designed behavior. But it is arguable if it is "good" or not. Generally speaking, null should not be handled automatically since changing nothing to something could cause more problems. However, ToString() is a special case. The expected result is a "string", either empty or not empty. If the compiler sees null.ToString(), make it an empty string. This would simplify coding and reduce a lot of errors. Just a thought. :)
TOMZ_KV
-
If you can assign null to a string,why the hell they are not making null.ToString() atleast null without cribbing. I hate the concept of null considering the harm this error caused to our delivery.
I agree. I wish null exceptions were handled more friendly. They can be helpful while developing to identify potentially problematic or incorrect areas of code, but for end-user releases, they just end up getting in the way, since 90% of the time, just ignoring them is the solution anyway. Yet C# forces us to explicitly ignore them, rather than saving us the trouble. Look at WPF data binding as an example of how it can actually be helpful to default to ignoring: if you bind an object to a control in WPF and the object is null, WPF doesn't crash with a null reference exception, it just doesn't display anything.
Sad but true: 4/3 of Americans have difficulty with simple fractions. There are 10 types of people in this world: those who understand binary and those who don't. {o,o}.oO( Check out my blog! ) |)””’) http://pihole.org/ -”-”-
-
People whose careers actually depend on the software they use often test much better than purely IT types, after going through the blood, sweat, and tears of finding out that their careers DO depend on results of the software. I've found this time and time again over the course of my career.
I agree.
I didn't get any requirements for the signature
-
That is a valid reason and a designed behavior. But it is arguable if it is "good" or not. Generally speaking, null should not be handled automatically since changing nothing to something could cause more problems. However, ToString() is a special case. The expected result is a "string", either empty or not empty. If the compiler sees null.ToString(), make it an empty string. This would simplify coding and reduce a lot of errors. Just a thought. :)
TOMZ_KV
Tomz_KV wrote:
But it is arguable if it is "good" or not
Sure. Some languages that target the .NET framework, such as Oxygene[^] do allow you to call methods using a null reference in special instances. However, these special instances are clearly visisble in the code. Oxygene does it with a colon operator rather than the dot operator. The dot operator still exists with exactly the same semantics as C# but you have the option of using the colon operator if you want to perform the operation if the reference exists, or ignore it if it doesn't. At the end of the day it is just compiler trickery because the resulting code still does the check in the CIL (MSIL)
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
-
What about this code then which I have seen today written by someone.
Dim var1 as String=String.Format("{0}\", value1)
Dim var2 as String=String.Format("{0}\", value2)
Dim var3 as String=String.Format("{0}\", value3)
Dim var4 as String=String.Format("{0}\", value4)Dim FinalString as String=var1+var2+var3+var4
PassToFunction(FinalString)
No tester could report a bug for this code.
Are you calling anything on value1, value2, value3 or value4? String.Format will check if a value passed to it is null before operating on it. So, it is not really the same situation.
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
-
Tomz_KV wrote:
But it is arguable if it is "good" or not
Sure. Some languages that target the .NET framework, such as Oxygene[^] do allow you to call methods using a null reference in special instances. However, these special instances are clearly visisble in the code. Oxygene does it with a colon operator rather than the dot operator. The dot operator still exists with exactly the same semantics as C# but you have the option of using the colon operator if you want to perform the operation if the reference exists, or ignore it if it doesn't. At the end of the day it is just compiler trickery because the resulting code still does the check in the CIL (MSIL)
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
-
OMG...I was not asking a question. I was not referring the difference between value type and reference type. I think I was having a fair idea about atleast value types and reference types. Let me clarify it was not my code which has got broken here, though I also had contributed my share of null reference exception earlier. When I said I wish null.ToString() to be handled automatically,I really don't wish to be so. Why I said is the people here who code like this have fair idea abou null reference exception and they themselves have made many. Still these type of errors creep into the code and it becomes a big issue in the managerial level. I thought it would be considered as a joke. But someone has 1 voted me down.
modified on Tuesday, December 16, 2008 12:25 PM
jith - iii wrote:
I was not asking a question
I though we were having a discussion about why things are the way they are, and specifically about the semantics of the dot operator in C#.
Developer Day Scotland 2 - Free community conference Recent blog posts: *Throwing Exceptions *Training Developers * Method hiding or overriding - or the difference between new and virtual
-
I agree. I wish null exceptions were handled more friendly. They can be helpful while developing to identify potentially problematic or incorrect areas of code, but for end-user releases, they just end up getting in the way, since 90% of the time, just ignoring them is the solution anyway. Yet C# forces us to explicitly ignore them, rather than saving us the trouble. Look at WPF data binding as an example of how it can actually be helpful to default to ignoring: if you bind an object to a control in WPF and the object is null, WPF doesn't crash with a null reference exception, it just doesn't display anything.
Sad but true: 4/3 of Americans have difficulty with simple fractions. There are 10 types of people in this world: those who understand binary and those who don't. {o,o}.oO( Check out my blog! ) |)””’) http://pihole.org/ -”-”-
What is specific to this error is,people who has enough experience in .Net also carelessly makes this mistake. And just by looking at the error message any other technical person can identify that the developer has tried to perform something with null. Since this is a basic rule, the shame this error makes will sometimes be very much.