Bookmark Bookmark Bookmark Bookmark Class

Определение

Представляет точку, в которой рабочий процесс или действие может пассивно ожидать возобновления.Represents a point at which a workflow or activity can passively wait to be resumed.

public ref class Bookmark : IEquatable<System::Activities::Bookmark ^>
[System.Runtime.Serialization.DataContract]
public class Bookmark : IEquatable<System.Activities.Bookmark>
type Bookmark = class
    interface IEquatable<Bookmark>
Public Class Bookmark
Implements IEquatable(Of Bookmark)
Наследование
BookmarkBookmarkBookmarkBookmark
Атрибуты
Реализации

Примеры

В следующем примере создается действие ReadLine.In the following example, a ReadLine activity is created. При выполнении действие ReadLine создает Bookmark, регистрирует обратный вызов и ждет возобновления чтения с закладки Bookmark.When executed, the ReadLine activity creates a Bookmark, registers a callback, and then waits for the Bookmark to be resumed. После возобновления чтения с закладки действие ReadLine присваивает данные, переданные с закладкой Bookmark, своему аргументу Result.When it is resumed, the ReadLine activity assigns the data that was passed with the Bookmark to its Result argument.

public sealed class ReadLine : NativeActivity<string>  
{  
    [RequiredArgument]  
    public  InArgument<string> BookmarkName { get; set; }  

    protected override void Execute(NativeActivityContext context)  
    {  
        // Create a Bookmark and wait for it to be resumed.  
        context.CreateBookmark(BookmarkName.Get(context),   
            new BookmarkCallback(OnResumeBookmark));  
    }  

    // NativeActivity derived activities that do asynchronous operations by calling   
    // one of the CreateBookmark overloads defined on System.Activities.NativeActivityContext   
    // must override the CanInduceIdle property and return true.  
    protected override bool CanInduceIdle  
    {  
        get { return true; }  
    }  

    public void OnResumeBookmark(NativeActivityContext context, Bookmark bookmark, object obj)  
    {  
        // When the Bookmark is resumed, assign its value to  
        // the Result argument.  
        Result.Set(context, (string)obj);  
    }  
}  

В следующем примере создается рабочий процесс, использующий ReadLine действия для получения имени пользователя и его отображения в окне консоли.In the following example, a workflow is created that uses the ReadLine activity to gather the user's name and display it to the console window. Ведущее приложение выполняет действительную работу по сбору входных данных и передает их в рабочий процесс, возобновляя закладку Bookmark.The host application performs the actual work of gathering the input and passes it to the workflow by resuming the Bookmark.

Variable<string> name = new Variable<string>  
{  
    Name = "name"  
};  

Activity wf = new Sequence  
{  
    Variables =  
    {  
        name  
    },  
    Activities =  
    {  
        new WriteLine()  
        {  
            Text = "What is your name?"  
        },  
        new ReadLine()  
        {  
            BookmarkName = "UserName",  
            Result = name  
        },  
        new WriteLine()  
        {  
            Text = new InArgument<string>((env) => "Hello, " + name.Get(env))  
        }  
    }  
};  

AutoResetEvent syncEvent = new AutoResetEvent(false);  

// Create the WorkflowApplication using the desired  
// workflow definition.  
WorkflowApplication wfApp = new WorkflowApplication(wf);  

// Handle the desired lifecycle events.  
wfApp.Completed = delegate(WorkflowApplicationCompletedEventArgs e)  
{  
    // Signal the host that the workflow is complete.  
    syncEvent.Set();  
};  

// Start the workflow.  
wfApp.Run();  

// Collect the user's name and resume the bookmark.  
// Bookmark resumption only occurs when the workflow  
// is idle. If a call to ResumeBookmark is made and the workflow  
// is not idle, ResumeBookmark blocks until the workflow becomes  
// idle before resuming the bookmark.  
wfApp.ResumeBookmark("UserName", Console.ReadLine());  

// Wait for Completed to arrive and signal that  
// the workflow is complete.  
syncEvent.WaitOne();  

При выполнении действие ReadLine создает закладку Bookmark с именем UserName и ждет возобновления чтения с этой закладки.When the ReadLine activity is executed, it creates a Bookmark named UserName and then waits for the bookmark to be resumed. Узел собирает необходимые данные и возобновляет чтение с закладки Bookmark.The host collects the desired data and then resumes the Bookmark. Рабочий процесс возобновляется, отображает имя и затем завершается.The workflow resumes, displays the name, and then completes. Следует заметить, что для возобновления закладки не требуется наличие кода синхронизации.Note that no synchronization code is required with regard to resuming the bookmark. Закладка Bookmark может быть возобновлена только при простое рабочего процесса; если рабочий процесс не простаивает, вызов ResumeBookmark блокируется, пока рабочий процесс не перейдет в состояние простоя.A Bookmark can only be resumed when the workflow is idle, and if the workflow is not idle, the call to ResumeBookmark blocks until the workflow becomes idle.

Комментарии

Когда действие создает объект Bookmark, оно переходит в режим ожидания возобновления Bookmark.When an activity creates a Bookmark, it becomes idle and waits for the Bookmark to be resumed. Если параллельно с действием, создавшим объект Bookmark, выполняются другие действия, то они будут запланированы для выполнения.If there are other activities in parallel with the activity that created the Bookmark, they will be scheduled for execution.

Закладки могут возобновляться ведущим приложением с использованием одного из перегруженных методов ResumeBookmark.Bookmarks can be resumed by the host application using one of the ResumeBookmark overloads.

Дополнительные сведения о закладках см. в разделе использование WorkflowInvoker и WorkflowApplication, закладкии закладки [ образцы WF] и Ожидания для входных данных действия [образцы WF] примеры.For more information about bookmarks, see Using WorkflowInvoker and WorkflowApplication, Bookmarks, and the Bookmarks [ WF Samples] and Wait For Input Activity [WF Samples] samples.

Конструкторы

Bookmark(String) Bookmark(String) Bookmark(String) Bookmark(String)

Инициализирует новый экземпляр класса Bookmark с использованием указанного имени.Initializes a new instance of the Bookmark class using the specified name.

Свойства

Name Name Name Name

Возвращает имя закладки.Gets the bookmark name.

Методы

Equals(Bookmark) Equals(Bookmark) Equals(Bookmark) Equals(Bookmark)

Определяет, ссылаются ли текущий объект Bookmark и указанный объект Bookmark на одну точку продолжения в рабочем процессе.Determines whether the current Bookmark and the specified Bookmark refer to the same continuation point in a workflow.

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Определяет, ссылаются ли текущий объект Bookmark и указанный объект на одну точку продолжения в рабочем процессе.Determines whether the current Bookmark and the specified object refer to the same continuation point in a workflow.

GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Возвращает уникальный идентификатор для этого экземпляра Bookmark.Returns a unique identifier for this Bookmark instance.

GetType() GetType() GetType() GetType()

Возвращает объект Type для текущего экземпляра.Gets the Type of the current instance.

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Создает неполную копию текущего объекта Object.Creates a shallow copy of the current Object.

(Inherited from Object)
ToString() ToString() ToString() ToString()

Возвращает имя для именованной закладки или идентификатор для безымянной закладки.Returns the bookmark name for a named bookmark or the bookmark ID for an unnamed bookmark.

Применяется к