tags:

views:

81

answers:

1

Why does C# define Byte+Byte=Int32 instead of Byte+Byte=Byte like VB?

+1  A: 

Because adding two very large bytes can overflow, and that's not normally what you want to happen.

Joel Coehoorn
yeah, but adding two ints also can overflow, yet int+int = int, not long.
SWeko
Bytes are much more likely to overflow than integers
Matt Greer
@SWeko - it can, but only for unusually large magnitude integers. Probabilistically, C# makes a good guess at where bugs are likely to be caught.
Daniel Earwicker
@SWeko: Good point. Though you can do checked arithmetic. Not sure why the automatic byte arithmetic conversion would be on by default, rather than requiring you do a "checked" block, and only detecting an overflow, without converting types.
Merlyn Morgan-Graham
@Daniel, actually sum of two bytes can go up to 2*byte.MaxValue, and sum of two ints can go to 2*int.MaxValue, so the probability is about the same :)
SWeko
@SWeko - only theoretically. Practically, it's much rarer to have ints that approach MaxValue. Also, the corresponding check for int (int+int=long) would cause all kinds of conversion problems in most programs that byte doesn't run into. If you're doing sums with bytes, a lot of the time you assign the result to an int anyway. If you're doing sums with ints, you usually still expect an int.
Joel Coehoorn
In real world, of course that it's more common to have 250 of something and get 10 more (byte overflow) than to have 2147483640 and add 10. There is a similar logic that proves that about 1/4 of the numbers start with 1. However, that does not change the probabilities :) Moreover, I seldom work with bytes, but when I do, I'm well aware of their range, so my personal preference would be for operations on bytes to result in a byte, not in an int.
SWeko
If you were really concerned about overflows, then why doesn't it widen to a Int16 instead of jumping all the way to an Int32?
Jonathan Allen
@Joel, the only time I ever do sums of bytes is when working with an API that expects a byte. I can't imagine using it any other time.
Jonathan Allen
*"However, that does not change the probabilities :)"* - In that case, the "probabilities" you're talking about seem to be unrelated to the real world. Ask yourself what would be most helpful given our commonsense prior knowledge about the distribution of integer values in most real programs. All language features are chosen in that way: assuming what is *most likely* to help. Most `int` values (say, discrete measurements in pixels, or counters) are way smaller than a billion, whereas `byte` values can be expected to span the available range much more evenly.
Daniel Earwicker