WorkflowApplication.Persist Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Сохраняет экземпляр рабочего процесса в хранилище экземпляров.
Перегрузки
Persist() |
Сохраняет экземпляр рабочего процесса в хранилище экземпляров. |
Persist(TimeSpan) |
Сохраняет экземпляр рабочего процесса в хранилище экземпляров с использованием указанного интервала времени ожидания. |
Комментарии
В экземпляре рабочего процесса, ранее загруженного из сохраняемости, для загрузки процесса используется тот же InstanceStore, что и для загрузки рабочего процесса. Если рабочий процесс создан и еще не сохранен, то InstanceStore должен быть настроен перед вызовом этого метода, в противном случае во время его вызова возникнет исключение InvalidOperationException.
Persist()
Сохраняет экземпляр рабочего процесса в хранилище экземпляров.
public:
void Persist();
public void Persist ();
member this.Persist : unit -> unit
Public Sub Persist ()
Примеры
В следующем примере вызывается метод Persist для сохранения экземпляра рабочего процесса перед запуском рабочего процесса.
WorkflowApplication application = new WorkflowApplication(activity);
application.InstanceStore = instanceStore;
//returning IdleAction.Unload instructs the WorkflowApplication to persists application state and remove it from memory
application.PersistableIdle = (e) =>
{
return PersistableIdleAction.Unload;
};
application.Unloaded = (e) =>
{
instanceUnloaded.Set();
};
//This call is not required
//Calling persist here captures the application durably before it has been started
application.Persist();
id = application.Id;
application.Run();
instanceUnloaded.WaitOne();
Комментарии
Если операция сохранения не завершается в течение 30 секунд, то вызывается исключение TimeoutException.
В экземпляре рабочего процесса, ранее загруженного из сохраняемости, для загрузки процесса используется тот же InstanceStore, что и для загрузки рабочего процесса. Если рабочий процесс создан и еще не сохранен, то InstanceStore должен быть настроен перед вызовом этого метода, в противном случае во время его вызова возникнет исключение InvalidOperationException.
Применяется к
Persist(TimeSpan)
Сохраняет экземпляр рабочего процесса в хранилище экземпляров с использованием указанного интервала времени ожидания.
public:
void Persist(TimeSpan timeout);
public void Persist (TimeSpan timeout);
member this.Persist : TimeSpan -> unit
Public Sub Persist (timeout As TimeSpan)
Параметры
- timeout
- TimeSpan
Период времени, в течение которого операция сохранения должна быть завершена, прежде чем она будет отменена с формированием исключения TimeoutException.
Примеры
В следующем примере вызывается метод Persist для сохранения экземпляра рабочего процесса перед запуском рабочего процесса.
WorkflowApplication application = new WorkflowApplication(activity);
application.InstanceStore = instanceStore;
//returning IdleAction.Unload instructs the WorkflowApplication to persists application state and remove it from memory
application.PersistableIdle = (e) =>
{
return PersistableIdleAction.Unload;
};
application.Unloaded = (e) =>
{
instanceUnloaded.Set();
};
//This call is not required
//Calling persist here captures the application durably before it has been started
application.Persist();
id = application.Id;
application.Run();
instanceUnloaded.WaitOne();
Комментарии
В экземпляре рабочего процесса, ранее загруженного из сохраняемости, для загрузки процесса используется тот же InstanceStore, что и для загрузки рабочего процесса. Если рабочий процесс создан и еще не сохранен, то InstanceStore должен быть настроен перед вызовом этого метода, в противном случае во время его вызова возникнет исключение InvalidOperationException.