RegistryKeyPermissionCheck Enumeração

Definição

Especifica se são realizadas verificações de segurança ao abrir chaves de registo e aceder aos seus pares nome/valor.

public enum class RegistryKeyPermissionCheck
public enum RegistryKeyPermissionCheck
type RegistryKeyPermissionCheck = 
Public Enum RegistryKeyPermissionCheck
Herança
RegistryKeyPermissionCheck

Campos

Name Valor Description
Default 0

A chave de registo herda o modo do seu pai. Verificações de segurança são realizadas ao tentar aceder a subchaves ou valores, a menos que o pai tenha sido aberto com ReadSubTree o modo or ReadWriteSubTree .

ReadSubTree 1

Não são realizadas verificações de segurança ao aceder a subchaves ou valores. É realizada uma verificação de segurança ao tentar abrir a chave atual, a menos que o pai tenha sido aberto com ReadSubTree ou ReadWriteSubTree.

ReadWriteSubTree 2

Não são realizadas verificações de segurança ao aceder a subchaves ou valores. É realizada uma verificação de segurança ao tentar abrir a chave atual, a menos que o pai tenha sido aberto com ReadWriteSubTree.

Exemplos

O seguinte exemplo de código cria uma subchave contendo 100 pares chave/valor e fecha-a. O exemplo abre a subchave com Default e regista o tempo que demora a ler todos os valores. Depois, o exemplo abre a subchave com o ReadSubTree e regista o tempo que demora a ler todos os valores. Por fim, o exemplo calcula e mostra a percentagem de melhoria.

using System;
using Microsoft.Win32;
using System.Diagnostics;

public class Example
{
    public static void Main()
    {
        const int LIMIT = 100;
        RegistryKey cu = Registry.CurrentUser;
        const string testKey = "RegistryKeyPermissionCheckExample";

        Console.WriteLine("Generating {0} key/value pairs.", LIMIT);
        RegistryKey rk = cu.CreateSubKey(testKey);
        for (int i = 0; i < LIMIT; i++)
        {
            rk.SetValue("Key" + i, i);
        }

        rk.Close();

        Stopwatch s = new Stopwatch();

        // On the default setting, security is checked every time
        // a key/value pair is read.
        rk = cu.OpenSubKey(testKey, RegistryKeyPermissionCheck.Default);

        s.Start();
        for (int i = 0; i < LIMIT; i++)
        {
            rk.GetValue("Key" + i, i);
        }
        s.Stop();
        rk.Close();
        long delta1 = s.ElapsedTicks;

        s.Reset();

        // When the key is opened with ReadSubTree, security is
        // not checked when the values are read.
        rk = cu.OpenSubKey(testKey, RegistryKeyPermissionCheck.ReadSubTree);

        s.Start();
        for (int i = 0; i < LIMIT; i++)
        {
            rk.GetValue("Key" + i, i);
        }
        s.Stop();
        rk.Close();
        long delta2 = s.ElapsedTicks;

        double faster = (double) (delta1 - delta2) / (double) delta1;
        Console.WriteLine("ReadSubTree is {0}% faster for {1} values.",
            (faster * 100).ToString("0.0"), LIMIT);

        cu.DeleteSubKey(testKey);
    }
}

/* This code example produces output similar to the following:

Generating 100 key/value pairs.
ReadSubTree is 23.4% faster for 100 values.
 */
Imports Microsoft.Win32
Imports System.Diagnostics

Public Class Example
    
    Public Shared Sub Main() 

        Const LIMIT As Integer = 100
        Dim cu As RegistryKey = Registry.CurrentUser
        Const testKey As String = "RegistryKeyPermissionCheckExample"
        
        Console.WriteLine("Generating {0} key/value pairs.", LIMIT)
        Dim rk As RegistryKey = cu.CreateSubKey(testKey)

        For i As Integer = 0 To LIMIT
            rk.SetValue("Key" & i, i)
        Next i
        
        rk.Close()
        
        Dim s As New Stopwatch()
        
        ' On the default setting, security is checked every time
        ' a key/value pair is read.
        rk = cu.OpenSubKey(testKey, _
            RegistryKeyPermissionCheck.Default)
        
        s.Start()
        For i As Integer = 0 To LIMIT
            rk.GetValue("Key" & i, i)
        Next i
        s.Stop()
        rk.Close()
        Dim delta1 As Long = s.ElapsedTicks
        
        s.Reset()
        
        ' When the key is opened with ReadSubTree, security is 
        ' not checked when the values are read.
        rk = cu.OpenSubKey(testKey, _
            RegistryKeyPermissionCheck.ReadSubTree)
        
        s.Start()
        For i As Integer = 0 To LIMIT
            rk.GetValue("Key" & i, i)
        Next i
        s.Stop()
        rk.Close()
        Dim delta2 As Long = s.ElapsedTicks
        
        Dim faster As Double = _
            CDbl(delta1 - delta2) * 100.0 / CDbl(delta1)
        Console.WriteLine("ReadSubTree is {0}% faster for {1} values.", _
            faster.ToString("0.0"), LIMIT)
        
        cu.DeleteSubKey(testKey)
    
    End Sub 
End Class 

' This code example produces output similar to the following:
'
'Generating 100 key/value pairs.
'ReadSubTree is 23.4% faster for 100 values.
'

Observações

Quando uma aplicação guarda ou recupera um grande número de definições do registo a partir de um conjunto de subchaves, são realizadas inúmeras verificações redundantes de segurança. Esta enumeração especifica quando verificações de segurança numa chave devem ser omitidas.

A tabela seguinte mostra quando são realizadas verificações de segurança, com base na forma como a chave principal e a chave atual são abertas.

Chave parental aberta com Chave atual aberta com Result
Default Default Uma verificação de segurança é realizada ao aceder a qualquer valor na chave atual, ou ao tentar aceder a uma subchave. Este é o comportamento nas versões 1.0 e 1.1 do .NET Framework.
Default ReadSubTree É realizada uma verificação de segurança ao tentar abrir a chave atual.
Default ReadWriteSubTree É realizada uma verificação de segurança ao tentar abrir a chave atual.
ReadSubTree Default ou ReadSubTree Não são realizadas verificações de segurança ao abrir a chave atual ou os seus valores.
ReadSubTree ReadWriteSubTree É realizada uma verificação de segurança ao tentar abrir a chave atual.
ReadWriteSubTree Qualquer Não são realizadas verificações de segurança ao abrir a chave atual ou os seus valores.

Aplica-se a