TransactedReceiveScope 類別
定義
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
活動,範圍為接收之訊息所啟始的交易存留期。 交易可能會流動至初始訊息上的工作流程,或是在接收到訊息時由發送器所建立。
public ref class TransactedReceiveScope sealed : System::Activities::NativeActivity
[System.Windows.Markup.ContentProperty("Body")]
public sealed class TransactedReceiveScope : System.Activities.NativeActivity
[<System.Windows.Markup.ContentProperty("Body")>]
type TransactedReceiveScope = class
inherit NativeActivity
Public NotInheritable Class TransactedReceiveScope
Inherits NativeActivity
- 繼承
- 屬性
範例
下列範例將示範如何使用 TransactedReceiveScope 活動中的 Sequence 類別。
return new Sequence
{
Activities =
{
new WriteLine { Text = "Service workflow begins." },
new System.ServiceModel.Activities.TransactedReceiveScope
{
Variables = { requestMessage, replyMessage },
Request = receive,
Body = new Sequence
{
Activities =
{
new WriteLine { Text = new InArgument<string>("Server side: Receive complete.") },
new WriteLine { Text = new InArgument<string>(new VisualBasicValue<string>() { ExpressionText = "\"Server side: Received = '\" + requestString.toString() + \"'\"" }) },
new PrintTransactionInfo(),
new Assign<string>
{
Value = new InArgument<string>("Server side: Sending reply."),
To = new OutArgument<string>(replyMessage)
},
new WriteLine { Text = new InArgument<string>("Server side: Begin reply.") },
new SendReply
{
Request = receive,
Content = SendContent.Create(new InArgument<string>(replyMessage)),
},
new WriteLine { Text = new InArgument<string>("Server side: Reply sent.") },
},
},
},
new WriteLine { Text = "Server workflow ends." },
},
};
備註
TransactedReceiveScope 活動可讓您控制流動異動的存留期。
警告
對於起始 TransactedReceiveScope 活動 (TransactedReceiveScope 包含 Receive 設定為 true
) 的活動 CanCreateInstance ,會在執行時間開始執行 TransactedReceiveScope 活動之前建立交易。 此異動不是工作流程活動層的環境異動,而是基礎保存層中的環境異動。 如果執行工作流程時先遇到 Persist 活動再遇到 TransactedReceiveScope 活動,則執行階段會嘗試保存在環境交易之下。 這個行為會導致封鎖,直到交易完成為止。 由於工作流程執行尚未達到 Body 區段,因此,異動無法完成。 此死結會導致工作流程停止回應,直到交易逾時為止。當交易逾時時,新建立的實例就會中止。
重要
每當您使用 TransactedReceiveScope 時,建議您將工作流程中的所有 Receive 放在 TransactedReceiveScope 活動內。
重要
如果使用 TransactedReceiveScope 而且訊息按照錯誤的順序送達,工作流程就會在嘗試傳送第一則順序錯誤的訊息時中止。 當工作流程閒置時,您必須確定工作流程永遠位於一致的停止點。 萬一工作流程已中止,這樣做可讓您從上一個保存點重新啟動工作流程。
建構函式
TransactedReceiveScope() |
初始化 TransactedReceiveScope 類別的新執行個體。 |
屬性
Body |
取得或設定 Activity,它會標記 TransactedReceiveScope 活動的主體。 |
CacheId |
取得工作流程定義範圍內的唯一快取識別碼。 (繼承來源 Activity) |
CanInduceIdle |
取得或設定值,這個值指出此活動是否會造成工作流程變為閒置。 (繼承來源 NativeActivity) |
Constraints |
取得 Constraint 活動的集合,這些活動可以設定為提供 Activity 的驗證。 (繼承來源 Activity) |
DisplayName |
取得或設定選擇性的易記名稱,這個名稱會用於偵錯、驗證、例外狀況處理及追蹤。 (繼承來源 Activity) |
Id |
取得工作流程定義範圍內的唯一識別碼。 (繼承來源 Activity) |
Implementation |
活動的執行邏輯。 (繼承來源 NativeActivity) |
ImplementationVersion |
取得或設定活動的實作版本。 (繼承來源 NativeActivity) |
Request |
取得或設定與這個 Receive 活動相關聯的 TransactedReceiveScope 活動。 |
Variables |
取得與這個 Variable 相關聯之 TransactedReceiveScope 的集合。 |