Export (0) Print
Expand All
Expand Minimize
This topic has not yet been rated - Rate this topic

OpCodes.Brtrue Field

Transfers control to a target instruction if value is true, not null, or non-zero.

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

public static readonly OpCode Brtrue
public static final OpCode Brtrue
public static final var Brtrue : OpCode

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

3A < int32 >

brtrue target

brinst target

Branch to a target instruction at the specified offset if non-zero (true).

The stack transitional behavior, in sequential order, is:

  1. value is pushed onto the stack by a previous operation.

  2. value is popped from the stack; if value is true, branch to target.

The brtrue instruction transfers control to the specified target instruction if value (type natural int) is nonzero (true). If value is zero (false) execution continues at the next instruction.

If value is an object reference (type O) then brinst (an alias for brtrue) transfers control if it represents an instance of an object (for example, if it is not the null object reference; see Ldnull).

The target instruction is represented as a 4-byte signed offset from the beginning of the instruction following the current instruction.

Control can only be transferred to the first of these prefixes if the target instruction has one or more prefix codes. Control transfers into and out of try, catch, filter, and finally blocks cannot be performed by this instruction.

The following Emit method overload can use the brtrue opcode:

  • ILGenerator.Emit(OpCode, Label)

Windows 98, Windows 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 .NET Framework does not support all versions of every platform. For a list of the supported versions, see System Requirements.

.NET Framework

Supported in: 2.0, 1.1, 1.0
Did you find this helpful?
(1500 characters remaining)
Thank you for your feedback

Community Additions

ADD
Show:
© 2014 Microsoft. All rights reserved.