Прочитать на английском

Поделиться через


DispatcherObject.CheckAccess Метод

Определение

Определяет, имеет ли вызывающий поток доступ к этому DispatcherObject.

C#
public bool CheckAccess();

Возвращаемое значение

true, если вызывающий поток имеет доступ к этому объекту; в противном случае — false.

Примеры

В следующем примере используется CheckAccess для определения того, имеет ли поток доступ к потоку, в котором Button был создан объект . Метод CheckAccess в Button вызывается для проверки доступа к потоку. Если у вызывающего потока есть доступ, Button объект обновляется путем простого доступа к членам ; в Buttonпротивном случае делегат, принимаюющий Button в качестве аргумента, размещается в элементе DispatcherButton.

C#
// Uses the DispatcherObject.CheckAccess method to determine if 
// the calling thread has access to the thread the UI object is on
private void TryToUpdateButtonCheckAccess(object uiObject)
{
    Button theButton = uiObject as Button;

    if (theButton != null)
    {
        // Checking if this thread has access to the object
        if (theButton.CheckAccess())
        {
            // This thread has access so it can update the UI thread
            UpdateButtonUI(theButton);
        }
        else
        {
            // This thread does not have access to the UI thread
            // Pushing update method on the Dispatcher of the UI thread
            theButton.Dispatcher.BeginInvoke(DispatcherPriority.Normal,
                new UpdateUIDelegate(UpdateButtonUI), theButton);
        }
    }
}

Комментарии

Доступ к объекту может получить только поток Dispatcher , созданный в DispatcherObject.

Любой поток может проверить, имеет ли он доступ к этому DispatcherObject.

Разница между CheckAccess и VerifyAccess заключается в том, что CheckAccess возвращает логическое значение, указывающее, имеет ли вызывающий поток доступ к этому DispatcherObject объекту, и VerifyAccess создает исключение, если вызывающий поток не имеет доступа к этому DispatcherObjectобъекту .

Вызов этого метода идентичен вызову CheckAccess связанного Dispatcher объекта.

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

Продукт Версии
.NET Framework 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10