This documentation is archived and is not being maintained.

OpCodes.Ckfinite Field

Throws ArithmeticException if value is not a finite number.

Namespace: System.Reflection.Emit
Assembly: mscorlib (in mscorlib.dll)

public static readonly OpCode Ckfinite
public static final OpCode Ckfinite
public static final var Ckfinite : OpCode
Not applicable.

The following table lists the instruction's hexadecimal and Microsoft Intermediate Language (MSIL) assembly format, along with a brief reference summary:

Format

Assembly Format

Description

C3

ckfinite

throw ArithmeticException if value is not a finite number.

The stack transitional behavior, in sequential order, is:

  1. value is pushed onto the stack..

  2. value is popped from the stack and the ckfinite instruction is performed on it.

  3. value is pushed back onto the stack if no exception is thrown.

The ckfinite instruction throws ArithmeticException if value (a floating-point number) is either a "not a number" value (NaN) or a +- infinity value. Ckfinite leaves the value on the stack if no exception is thrown. Execution is unspecified if value is not a floating-point number.

ArithmeticException is thrown if value is not a 'normal' number.

Note that a special exception or a derived class of ArithmeticException may be more appropriate, passing the incorrect value to the exception handler.

The following Emit method overload can use the ckfinite opcode:

  • ILGenerator.Emit(OpCode)

Windows 98, Windows Server 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition

The Microsoft .NET Framework 3.0 is supported on Windows Vista, Microsoft Windows XP SP2, and Windows Server 2003 SP1.

.NET Framework

Supported in: 3.0, 2.0, 1.1, 1.0
Show: