Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

C# inline checked statement does not work

I have two test methods. The first one works fine. The second one does not throw an exception, but it should. Why doesn't the second one throw a exception?

[TestMethod]
[ExpectedException(typeof(OverflowException))]
public void LongToInt_OverflowWithCheckedBlock()
{
    checked
    {
        int maxValue = 2147483647;
        long longValue = (maxValue + 1);
        int intValue = (int)longValue;
    }
}

[TestMethod]
[ExpectedException(typeof(OverflowException))]
public void LongToInt_OverflowWithCheckedStatement()
{

    int maxValue = 2147483647;
    long longValue = (maxValue + 1);
    int intValue = checked((int)longValue);     // No Exception is thrown, why?
}
like image 269
TheAnonymousModeIT Avatar asked Aug 22 '17 07:08

TheAnonymousModeIT


People also ask

What C is used for?

C programming language is a machine-independent programming language that is mainly used to create many types of applications and operating systems such as Windows, and other complicated programs such as the Oracle database, Git, Python interpreter, and games and is considered a programming foundation in the process of ...

What is the full name of C?

In the real sense it has no meaning or full form. It was developed by Dennis Ritchie and Ken Thompson at AT&T bell Lab. First, they used to call it as B language then later they made some improvement into it and renamed it as C and its superscript as C++ which was invented by Dr. Stroustroupe.

Is C language easy?

C is a general-purpose language that most programmers learn before moving on to more complex languages. From Unix and Windows to Tic Tac Toe and Photoshop, several of the most commonly used applications today have been built on C. It is easy to learn because: A simple syntax with only 32 keywords.

Is C programming hard?

C is more difficult to learn than JavaScript, but it's a valuable skill to have because most programming languages are actually implemented in C. This is because C is a “machine-level” language. So learning it will teach you how a computer works and will actually make learning new languages in the future easier.


2 Answers

The reason the first one throws and the second one doesn't is because your comparison is a bit off.

  • In the 1st method you check everything
  • In the 2nd method you only check the cast from long to int.

If you compare them like below they are equal and neither will throw:

private static void MethodA()
{
    int maxValue = 2147483647;
    long longValue = ( maxValue + 1 );
    checked
    {
        int intValue = ( int ) longValue;
    }
}

private static void MethodB()
{
    int maxValue = 2147483647;
    long longValue = ( maxValue + 1 );
    int intValue = checked( ( int ) longValue);
}

The reason for this is because this line: int intValue = checked(( int ) longValue); isn't the one that's throwing, its this line:

long longValue = ( maxValue + 1 );

If I put the checked there they will both throw:

long longValue = checked( maxValue + 1 );

Why it throws here:

It throws because ( maxValue + 1 ) is adding 1 to an int called maxValue (exception occurs here) and after that assigning it to a long, if you cast the int to a long before doing the adding 1 it will not throw:

long longValue = ( (long) maxValue + 1 );
like image 155
EpicKip Avatar answered Sep 28 '22 08:09

EpicKip


As MSDN document said,

The checked keyword is used to explicitly enable overflow checking for integral-type arithmetic operations and conversions.

The first test method is already checking if there is an overflowing value within the declared block.

enter image description here

The second test method is only checking the overflowing value this line of code only.

int intValue = checked((int)longValue); //Checked expression

enter image description here

Since the overflowing is happen before the checked expression, the CLR already converted the value. And the value of that is -2147483648 which is legal since int range is enter image description here

What is the difference?

Test Method 1 : Checked block

Test Method 2: Checked expression

like image 28
Jeric Cruz Avatar answered Sep 28 '22 08:09

Jeric Cruz