Variables.Unlock Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Libera os bloqueios na coleção de variáveis e sinaliza o estado da coleção de variáveis como inválido ou desconhecido.
public:
void Unlock();
public void Unlock ();
member this.Unlock : unit -> unit
Public Sub Unlock ()
Exemplos
O exemplo de código a seguir bloqueia a coleção de variáveis quando GetVariables é chamada. Em seguida, o exemplo verifica se a coleção está bloqueada e, nesse caso, chama Unlock.
using System;
using System.Collections.Generic;
using System.Text;
using Microsoft.SqlServer.Dts.Runtime;
namespace Microsoft.SqlServer.SSIS.Sample
{
class Program
{
static void Main(string[] args)
{
Package pkg = new Package();
Variables vars = null;
VariableDispenser variableDispenser = pkg.VariableDispenser;
variableDispenser.LockForRead("System::PackageName");
variableDispenser.LockForRead("System::OfflineMode");
variableDispenser.LockForWrite("System::InteractiveMode");
variableDispenser.GetVariables(ref vars);
// Determine whether the variable collection is locked before unlocking.
Boolean isLocked = vars.Locked;
// Verify the value of vars.Locked. If the lock failed,
// call Reset.
if (isLocked)
{
vars.Unlock();
}
else
{
variableDispenser.Reset();
}
}
}
}
Imports System
Imports System.Collections.Generic
Imports System.Text
Imports Microsoft.SqlServer.Dts.Runtime
Namespace Microsoft.SqlServer.SSIS.Sample
Class Program
Shared Sub Main(ByVal args() As String)
Dim pkg As Package = New Package()
Dim vars As Variables = Nothing
Dim variableDispenser As VariableDispenser = pkg.VariableDispenser
variableDispenser.LockForRead("System::PackageName")
variableDispenser.LockForRead("System::OfflineMode")
variableDispenser.LockForWrite("System::InteractiveMode")
variableDispenser.GetVariables( vars)
' Determine whether the variable collection is locked before unlocking.
Dim isLocked As Boolean = vars.Locked
' Verify the value of vars.Locked. If the lock failed,
' call Reset.
If isLocked = True Then
vars.Unlock()
Else
variableDispenser.Reset()
End If
End Sub
End Class
End Namespace
Comentários
Esse método é usado para desbloquear variáveis que foram bloqueadas usando a VariableDispenser classe. Quando VariableDispenser distribui uma coleção de variáveis, ela mantém o controle da coleção em uma lista. Quando a tarefa que chamou o dispensador de variável termina de ser executada, todas as coleções dispensadas são desbloqueadas automaticamente. Portanto, se o desbloqueio automático for adequado para suas finalidades e se o desbloqueio automático ocorrer quando a tarefa for concluída, você não precisará chamar o Unlock método. No entanto, às vezes é desejável desbloquear variáveis o mais rápido possível por motivos de desempenho. Uma chamada explícita a esse Unlock método desbloqueia as variáveis.
A Locked propriedade retorna um valor de indicação de false
que uma coleção dispensada já foi desbloqueada. Um valor de true
indica que a coleção de variáveis ainda está bloqueada. Chamar Unlock duas vezes causa um erro; portanto, em determinadas situações, você pode ter que verificar o valor dessa propriedade antes de decidir se deseja chamar Unlock.