RegistryKey.GetValue Methode

Definitie

Haalt de waarde op die is gekoppeld aan de opgegeven naam.

Overloads

Name Description
GetValue(String, Object, RegistryValueOptions)

Haalt de waarde op die is gekoppeld aan de opgegeven naam en ophaalopties. Als de naam niet wordt gevonden, wordt de standaardwaarde geretourneerd die u opgeeft.

GetValue(String)

Haalt de waarde op die is gekoppeld aan de opgegeven naam. Retourneert null als het naam-/waardepaar niet bestaat in het register.

GetValue(String, Object)

Haalt de waarde op die is gekoppeld aan de opgegeven naam. Als de naam niet wordt gevonden, wordt de standaardwaarde geretourneerd die u opgeeft.

GetValue(String, Object, RegistryValueOptions)

Haalt de waarde op die is gekoppeld aan de opgegeven naam en ophaalopties. Als de naam niet wordt gevonden, wordt de standaardwaarde geretourneerd die u opgeeft.

public:
 System::Object ^ GetValue(System::String ^ name, System::Object ^ defaultValue, Microsoft::Win32::RegistryValueOptions options);
[System.Runtime.InteropServices.ComVisible(false)]
public object GetValue(string name, object defaultValue, Microsoft.Win32.RegistryValueOptions options);
[<System.Runtime.InteropServices.ComVisible(false)>]
member this.GetValue : string * obj * Microsoft.Win32.RegistryValueOptions -> obj
Public Function GetValue (name As String, defaultValue As Object, options As RegistryValueOptions) As Object

Parameters

name
String

De naam van de waarde die moet worden opgehaald. Deze tekenreeks is niet hoofdlettergevoelig.

defaultValue
Object

De waarde die moet worden geretourneerd als name deze niet bestaat.

options
RegistryValueOptions

Een van de opsommingswaarden waarmee optionele verwerking van de opgehaalde waarde wordt opgegeven.

Retouren

De waarde die is gekoppeld aan name, verwerkt volgens de opgegeven optionswaarde of defaultValue als name deze niet wordt gevonden.

Kenmerken

Uitzonderingen

De gebruiker beschikt niet over de vereiste machtigingen voor het lezen van de registersleutel.

De RegistryKey opgegeven waarde is gesloten (gesloten sleutels kunnen niet worden geopend).

De RegistryKey waarde die de opgegeven waarde bevat, is gemarkeerd voor verwijdering.

options is geen geldige RegistryValueOptions waarde; een ongeldige waarde wordt bijvoorbeeld omgezet in RegistryValueOptions.

De gebruiker beschikt niet over de benodigde registerrechten.

Voorbeelden

Het volgende codevoorbeeld maakt een testsleutel, voegt een waarde toe met een ingesloten omgevingsvariabele en haalt de waarde op in zowel uitgevouwen als niet-uitgevouwen formulieren.

#using <Microsoft.VisualBasic.dll>

using namespace System;
using namespace Microsoft::Win32;
using namespace Microsoft::VisualBasic;

int main()
{
    // Delete and recreate the test key.
    Registry::CurrentUser->DeleteSubKey( L"RegistryValueOptionsExample", false );
    RegistryKey ^ rk = 
        Registry::CurrentUser->CreateSubKey( L"RegistryValueOptionsExample" );
   
    // Add a value that contains an environment variable.
    rk->SetValue( L"ExpandValue", L"The path is %PATH%", 
        RegistryValueKind::ExpandString );
   
    // Retrieve the value, first without expanding the environment
    // variable and then expanding it.
    Console::WriteLine( L"Unexpanded: \"{0}\"", 
                        rk->GetValue( L"ExpandValue", 
                        L"No Value", 
                        RegistryValueOptions::DoNotExpandEnvironmentNames ) );
    Console::WriteLine( L"Expanded: \"{0}\"", rk->GetValue( L"ExpandValue" ) );
 
    return 0;
} //Main
using System;
using Microsoft.Win32;
using Microsoft.VisualBasic;

public class Example
{
    public static void Main()
    {
        // Delete and recreate the test key.
        Registry.CurrentUser.DeleteSubKey("RegistryValueOptionsExample", false);
        RegistryKey rk =
            Registry.CurrentUser.CreateSubKey("RegistryValueOptionsExample");

        // Add a value that contains an environment variable.
        rk.SetValue("ExpandValue", "The path is %PATH%", RegistryValueKind.ExpandString);

        // Retrieve the value, first without expanding the environment
        // variable and then expanding it.
        Console.WriteLine("Unexpanded: \"{0}\"",
            rk.GetValue("ExpandValue", "No Value",
            RegistryValueOptions.DoNotExpandEnvironmentNames));
        Console.WriteLine("Expanded: \"{0}\"", rk.GetValue("ExpandValue"));
    } //Main
} //Example
Imports Microsoft.Win32

Public Class Example
    Public Shared Sub Main()
        ' Delete and recreate the test key.
        Registry.CurrentUser.DeleteSubKey("RegistryValueOptionsExample", False)
        Dim rk As RegistryKey = _
            Registry.CurrentUser.CreateSubKey("RegistryValueOptionsExample")

        ' Add a value that contains an environment variable.
        rk.SetValue("ExpandValue", "The path is %PATH%", _
            RegistryValueKind.ExpandString)

        ' Retrieve the value, first without expanding the environment 
        ' variable and then expanding it.
        Console.WriteLine("Unexpanded: ""{0}""", _
            rk.GetValue("ExpandValue", "No Value", _
            RegistryValueOptions.DoNotExpandEnvironmentNames))
        Console.WriteLine("Expanded: ""{0}""", rk.GetValue("ExpandValue"))
    End Sub
End Class

Opmerkingen

Gebruik deze overbelasting om speciale verwerking van de opgehaalde waarde op te geven. U kunt bijvoorbeeld opgeven RegistryValueOptions.DoNotExpandEnvironmentNames wanneer u een registerwaarde van het type RegistryValueKind.ExpandString ophaalt om de tekenreeks op te halen zonder ingesloten omgevingsvariabelen uit te vouwen.

Gebruik de defaultValue parameter om de waarde op te geven die moet worden geretourneerd als name deze niet bestaat.

Note

Een registersleutel kan één waarde hebben die niet is gekoppeld aan een naam. Wanneer deze niet-benoemde waarde wordt weergegeven in de registereditor, wordt de tekenreeks (standaard) weergegeven in plaats van een naam. Als u deze niet-benoemde waarde wilt ophalen, geeft u null een van de lege tekenreeksen ("") op voor name.

GetValue biedt geen ondersteuning voor het lezen van waarden van het type REG_NONE of REG_LINK. In beide gevallen wordt de standaardwaarde (null) geretourneerd in plaats van de werkelijke waarde.

Zie ook

Van toepassing op

GetValue(String)

Haalt de waarde op die is gekoppeld aan de opgegeven naam. Retourneert null als het naam-/waardepaar niet bestaat in het register.

public:
 System::Object ^ GetValue(System::String ^ name);
public object GetValue(string name);
member this.GetValue : string -> obj
Public Function GetValue (name As String) As Object

Parameters

name
String

De naam van de waarde die moet worden opgehaald. Deze tekenreeks is niet hoofdlettergevoelig.

Retouren

De waarde die is gekoppeld aan name, of null als name deze niet is gevonden.

Uitzonderingen

De gebruiker beschikt niet over de vereiste machtigingen voor het lezen van de registersleutel.

De RegistryKey opgegeven waarde is gesloten (gesloten sleutels kunnen niet worden geopend).

De RegistryKey waarde die de opgegeven waarde bevat, is gemarkeerd voor verwijdering.

De gebruiker beschikt niet over de benodigde registerrechten.

Voorbeelden

In het volgende codevoorbeeld wordt een testsleutel gemaakt en worden waarden van verschillende gegevenstypen aan de sleutel toegevoegd. In het voorbeeld worden vervolgens de naam-/waardeparen gelezen en weergegeven in de console, met behulp van de GetValueKind methode om de bijbehorende registergegevenstypen op te halen.

using namespace System;
using namespace Microsoft::Win32;
int main()
{
   
   // Delete and recreate the test key.
   Registry::CurrentUser->DeleteSubKey( "RegistryValueKindExample", false );
   RegistryKey ^ rk = Registry::CurrentUser->CreateSubKey( "RegistryValueKindExample" );
   
   // Create name/value pairs.
   // This overload supports QWord (long) values. 
   rk->SetValue( "QuadWordValue", 42, RegistryValueKind::QWord );
   
   // The following SetValue calls have the same effect as using the
   // SetValue overload that does not specify RegistryValueKind.
   //
   rk->SetValue( "DWordValue", 42, RegistryValueKind::DWord );
   rk->SetValue( "MultipleStringValue", gcnew array<String^>{
      "One","Two","Three"
   }, RegistryValueKind::MultiString );
   rk->SetValue( "BinaryValue", gcnew array<Byte>{
      10,43,44,45,14,255
   }, RegistryValueKind::Binary );
   rk->SetValue( "StringValue", "The path is %PATH%", RegistryValueKind::String );
   
   // This overload supports setting expandable string values. Compare
   // the output from this value with the previous string value.
   rk->SetValue( "ExpandedStringValue", "The path is %PATH%", RegistryValueKind::ExpandString );
   
   // Display all the name/value pairs stored in the test key, with the
   // registry data type in parentheses.
   //
   array<String^>^valueNames = rk->GetValueNames();
   System::Collections::IEnumerator^ myEnum = valueNames->GetEnumerator();
   while ( myEnum->MoveNext() )
   {
      String^ s = safe_cast<String^>(myEnum->Current);
      RegistryValueKind rvk = rk->GetValueKind( s );
      switch ( rvk )
      {
         case RegistryValueKind::MultiString:
         {
            array<String^>^values = (array<String^>^)rk->GetValue( s );
            Console::Write( "\r\n {0} ({1}) =", s, rvk );
            for ( int i = 0; i < values->Length; i++ )
            {
               if (i != 0) Console::Write(",");
               Console::Write( " \"{0}\"", values[ i ] );

            }
            Console::WriteLine();
            break;
         }
         case RegistryValueKind::Binary:
         {
            array<Byte>^bytes = (array<Byte>^)rk->GetValue( s );
            Console::Write( "\r\n {0} ({1}) =", s, rvk );
            for ( int i = 0; i < bytes->Length; i++ )
            {
               
               // Display each byte as two hexadecimal digits.
               Console::Write( " {0:X2}", bytes[ i ] );

            }
            Console::WriteLine();
            break;
         }
         default:
            Console::WriteLine( "\r\n {0} ({1}) = {2}", s, rvk, rk->GetValue( s ) );
            break;
      }
   }
}
/*

This code example produces the following output:
 QuadWordValue (QWord) = 42

 DWordValue (DWord) = 42

 MultipleStringValue (MultiString) =, "One", "Two", "Three"

 BinaryValue (Binary) = 0A 2B 2C 2D 0E FF

 StringValue (String) = The path is %PATH%

 ExpandedStringValue (ExpandString) = The path is C:\Program Files\Microsoft.NET\SDK\v2.0\Bin;
 [***The remainder of this output is omitted.***]

*/
using System;
using Microsoft.Win32;

public class Example
{
    public static void Main()
    {
        // Delete and recreate the test key.
        Registry.CurrentUser.DeleteSubKey("RegistryValueKindExample", false);
        RegistryKey rk = Registry.CurrentUser.CreateSubKey("RegistryValueKindExample");

        // Create name/value pairs.

        // This overload supports QWord (long) values.
        rk.SetValue("QuadWordValue", 42, RegistryValueKind.QWord);

        // The following SetValue calls have the same effect as using the
        // SetValue overload that does not specify RegistryValueKind.
        //
        rk.SetValue("DWordValue", 42, RegistryValueKind.DWord);
        rk.SetValue("MultipleStringValue", new string[] {"One", "Two", "Three"}, RegistryValueKind.MultiString);
        rk.SetValue("BinaryValue", new byte[] {10, 43, 44, 45, 14, 255}, RegistryValueKind.Binary);
        rk.SetValue("StringValue", "The path is %PATH%", RegistryValueKind.String);

        // This overload supports setting expandable string values. Compare
        // the output from this value with the previous string value.
        rk.SetValue("ExpandedStringValue", "The path is %PATH%", RegistryValueKind.ExpandString);

        // Display all name/value pairs stored in the test key, with each
        // registry data type in parentheses.
        //
        string[] valueNames = rk.GetValueNames();
        foreach (string s in valueNames)
        {
            RegistryValueKind rvk = rk.GetValueKind(s);
            switch (rvk)
            {
                case RegistryValueKind.MultiString :
                    string[] values = (string[]) rk.GetValue(s);
                    Console.Write("\r\n {0} ({1}) =", s, rvk);
                    for (int i = 0; i < values.Length; i++)
                    {
                        if (i != 0) Console.Write(",");
                        Console.Write(" \"{0}\"", values[i]);
                    }
                    Console.WriteLine();
                    break;

                case RegistryValueKind.Binary :
                    byte[] bytes = (byte[]) rk.GetValue(s);
                    Console.Write("\r\n {0} ({1}) =", s, rvk);
                    for (int i = 0; i < bytes.Length; i++)
                    {
                        // Display each byte as two hexadecimal digits.
                        Console.Write(" {0:X2}", bytes[i]);
                    }
                    Console.WriteLine();
                    break;

                default :
                    Console.WriteLine("\r\n {0} ({1}) = {2}", s, rvk, rk.GetValue(s));
                    break;
            }
        }
    }
}
/*

This code example produces the following output:
 QuadWordValue (QWord) = 42

 DWordValue (DWord) = 42

 MultipleStringValue (MultiString) =, "One", "Two", "Three"

 BinaryValue (Binary) = 0A 2B 2C 2D 0E FF

 StringValue (String) = The path is %PATH%

 ExpandedStringValue (ExpandString) = The path is C:\Program Files\Microsoft.NET\SDK\v2.0\Bin;
 [***The remainder of this output is omitted.***]

*/
Imports Microsoft.Win32

Public Class Example
    Public Shared Sub Main()
        ' Delete and recreate the test key.
        Registry.CurrentUser.DeleteSubKey("RegistryValueKindExample", False)
        Dim rk As RegistryKey = Registry.CurrentUser.CreateSubKey("RegistryValueKindExample")

        ' Create name/value pairs.
        ' This overload supports QWord (long) values.
        rk.SetValue("QuadWordValue", 42, RegistryValueKind.QWord)

        ' The following SetValue calls have the same effect as using the
        ' SetValue overload that does not specify RegistryValueKind.
        '
        rk.SetValue("DWordValue", 42, RegistryValueKind.DWord)
        rk.SetValue("MultipleStringValue", New String() {"One", "Two", "Three"}, RegistryValueKind.MultiString)
        rk.SetValue("BinaryValue", New Byte() {10, 43, 44, 45, 14, 255}, RegistryValueKind.Binary)
        rk.SetValue("StringValue", "The path is %PATH%", RegistryValueKind.String)

        ' This overload supports setting expandable string values. Compare
        ' the output from this value with the previous string value.
        rk.SetValue("ExpandedStringValue", "The path is %PATH%", RegistryValueKind.ExpandString)


        ' Display all name/value pairs stored in the test key, with each
        ' registry data type in parentheses.
        '
        Dim valueNames As String() = rk.GetValueNames()
        Dim s As String
        For Each s In  valueNames
            Dim rvk As RegistryValueKind = rk.GetValueKind(s)
            Select Case rvk
                Case RegistryValueKind.MultiString
                    Dim values As String() = CType(rk.GetValue(s), String())
                    Console.Write(vbCrLf & " {0} ({1}) =", s, rvk)
                    For i As Integer = 0 To values.Length - 1
                        If i <> 0 Then Console.Write(",")
                        Console.Write(" ""{0}""", values(i))
                    Next i
                    Console.WriteLine()

                Case RegistryValueKind.Binary
                    Dim bytes As Byte() = CType(rk.GetValue(s), Byte())
                    Console.Write(vbCrLf & " {0} ({1}) =", s, rvk)
                    For i As Integer = 0 To bytes.Length - 1
                        ' Display each byte as two hexadecimal digits.
                        Console.Write(" {0:X2}", bytes(i))
                    Next i
                    Console.WriteLine()

                Case Else
                    Console.WriteLine(vbCrLf & " {0} ({1}) = {2}", s, rvk, rk.GetValue(s))
            End Select
        Next s
    End Sub
End Class

'
'This code example produces the following output (some output is omitted):
'
' QuadWordValue (QWord) = 42
'
' DWordValue (DWord) = 42
'
' MultipleStringValue (MultiString) = "One", "Two", "Three"
'
' BinaryValue (Binary) = 0A 2B 2C 2D 0E FF
'
' StringValue (String) = The path is %PATH%
'
' ExpandedStringValue (ExpandString) = The path is C:\Program Files\Microsoft.NET\SDK\v2.0\Bin;
' [***The remainder of this output is omitted.***]

Opmerkingen

Note

Een registersleutel kan één waarde hebben die niet is gekoppeld aan een naam. Wanneer deze niet-benoemde waarde wordt weergegeven in de registereditor, wordt de tekenreeks (standaard) weergegeven in plaats van een naam. Als u deze niet-benoemde waarde wilt ophalen, geeft u null een van de lege tekenreeksen ("") op voor name.

Wanneer de GetValue methode uitbreidbare tekenreekswaarden ophaalt (RegistryValueKind.ExpandString), worden omgevingsreeksen uitgebreid met behulp van gegevens uit de lokale omgeving. Als u uitbreidbare tekenreekswaarden wilt ophalen uit het register op een externe computer, gebruikt u de overbelasting van de GetValue(String, Object, RegistryValueOptions) methode om op te geven dat u geen omgevingsreeksen wilt uitbreiden.

Note

Als een waarde met uitbreidbare verwijzingen naar omgevingsvariabelen is opgeslagen als een tekenreeks (RegistryValueKind.String), in plaats van als een uitbreidbare tekenreeks (RegistryValueKind.ExpandString), GetValue wordt deze niet uitgebreid. U kunt een dergelijke tekenreeks uitvouwen nadat deze is opgehaald door de methode aan te ExpandEnvironmentVariables roepen.

Note

De aanbevolen manier om gegevens op te halen uit de sleutel is het gebruik van de PerformanceDataPerformanceCounter klasse in plaats van de RegistryKey.GetValue methode.

GetValue biedt geen ondersteuning voor het lezen van waarden van het type REG_NONE of REG_LINK. In beide gevallen wordt de standaardwaarde (null) geretourneerd in plaats van de werkelijke waarde.

Zie ook

Van toepassing op

GetValue(String, Object)

Haalt de waarde op die is gekoppeld aan de opgegeven naam. Als de naam niet wordt gevonden, wordt de standaardwaarde geretourneerd die u opgeeft.

public:
 System::Object ^ GetValue(System::String ^ name, System::Object ^ defaultValue);
public object GetValue(string name, object defaultValue);
member this.GetValue : string * obj -> obj
Public Function GetValue (name As String, defaultValue As Object) As Object

Parameters

name
String

De naam van de waarde die moet worden opgehaald. Deze tekenreeks is niet hoofdlettergevoelig.

defaultValue
Object

De waarde die moet worden geretourneerd als name deze niet bestaat.

Retouren

De waarde die is gekoppeld aan name, met eventuele ingesloten omgevingsvariabelen, is niet uitgevouwen of defaultValue als name deze niet wordt gevonden.

Uitzonderingen

De gebruiker beschikt niet over de vereiste machtigingen voor het lezen van de registersleutel.

De RegistryKey opgegeven waarde is gesloten (gesloten sleutels kunnen niet worden geopend).

De RegistryKey waarde die de opgegeven waarde bevat, is gemarkeerd voor verwijdering.

De gebruiker beschikt niet over de benodigde registerrechten.

Voorbeelden

In het volgende codevoorbeeld wordt een testsleutel gemaakt met een waarde en wordt die waarde opgehaald. In het voorbeeld wordt vervolgens geprobeerd een niet-bestaande waarde op te halen uit de sleutel; in dit geval retourneert de GetValue methode de opgegeven standaardwaarde.

using namespace System;
using namespace Microsoft::Win32;

public ref class RegGetDef
{
public:
    static void Main()
    {
        // Create a reference to a valid key.  In order for this code to
        // work, the indicated key must have been created previously.
        // The key name is not case-sensitive.
        RegistryKey^ rk = Registry::LocalMachine->OpenSubKey("Software\\myTestKey", false);
        // Get the value from the specified name/value pair in the key.
        String^ valueName = "myTestValue";

        Console::WriteLine("Retrieving registry value ...");
        Console::WriteLine();
        Object^ o = rk->GetValue(valueName);
        Console::WriteLine("Object Type = " + o->GetType()->FullName);
        Console::WriteLine();
        switch (rk->GetValueKind(valueName))
        {
            case RegistryValueKind::String:
            case RegistryValueKind::ExpandString:
                Console::WriteLine("Value = " + o);
                break;
            case RegistryValueKind::Binary:
                for each (Byte^ b in (array<Byte^>^)o)
                {
                    Console::Write("{0:x2} ", b);
                }
                Console::WriteLine();
                break;
            case RegistryValueKind::DWord:
                Console::WriteLine("Value = " + Convert::ToString((Int32^)o));
                break;
            case RegistryValueKind::QWord:
                Console::WriteLine("Value = " + Convert::ToString((Int64^)o));
                break;
            case RegistryValueKind::MultiString:
                for each (String^ s in (array<String^>^)o)
                {
                    Console::Write("[{0:s}], ", s);
                }
                Console::WriteLine();
                break;
            default:
                Console::WriteLine("Value = (Unknown)");
                break;
        }

        // Attempt to retrieve a value that does not exist; the specified
        // default value is returned.
        String^ def = (String^)rk->GetValue("notavalue", "The default to return");
        Console::WriteLine();
        Console::WriteLine(def);
        
        rk->Close();
    }
};

int main()
{
    RegGetDef::Main();
}
/*
Output:
Retrieving registry value ...

Object Type = System.String

Value = testData

The default to return
*/
using System;
using Microsoft.Win32;

class RegGetDef
{
    public static void Main()
    {
        // Create a reference to a valid key.  In order for this code to
        // work, the indicated key must have been created previously.
        // The key name is not case-sensitive.
        RegistryKey rk = Registry.LocalMachine.OpenSubKey("Software\\myTestKey", false);
        // Get the value from the specified name/value pair in the key.

        string valueName = "myTestValue";

        Console.WriteLine("Retrieving registry value ...");
        Console.WriteLine();
        object o = rk.GetValue(valueName);
        Console.WriteLine("Object Type = " + o.GetType().FullName);
        Console.WriteLine();
        switch (rk.GetValueKind(valueName))
        {
            case RegistryValueKind.String:
            case RegistryValueKind.ExpandString:
                Console.WriteLine("Value = " + o);
                break;
            case RegistryValueKind.Binary:
                foreach (byte b in (byte[])o)
                {
                    Console.Write("{0:x2} ", b);
                }
                Console.WriteLine();
                break;
            case RegistryValueKind.DWord:
                Console.WriteLine("Value = " + Convert.ToString((int)o));
                break;
            case RegistryValueKind.QWord:
                Console.WriteLine("Value = " + Convert.ToString((Int64)o));
                break;
            case RegistryValueKind.MultiString:
                foreach (string s in (string[])o)
                {
                    Console.Write("[{0:s}], ", s);
                }
                Console.WriteLine();
                break;
            default:
                Console.WriteLine("Value = (Unknown)");
                break;
        }

        // Attempt to retrieve a value that does not exist; the specified
        // default value is returned.
        string def = (string)rk.GetValue("notavalue", "The default to return");
        Console.WriteLine();
        Console.WriteLine(def);

        rk.Close();
    }
}
/*
Output:
Retrieving registry value ...

Object Type = System.String

Value = testData

The default to return
*/
Imports Microsoft.Win32

Public Class RegGetDef
    Public Shared Sub Main()
        ' Create a reference to a valid key.  In order for this code to
        ' work, the indicated key must have been created previously.
        ' The key name is not case-sensitive.
        Dim rk As RegistryKey = Registry.LocalMachine.OpenSubKey("Software\myTestKey", false)

        ' Get the value from the specified name/value pair in the key.
        Dim valueName As String = "myTestValue"

        Console.WriteLine("Retrieving registry value ...")
        Console.WriteLine()
        Dim o As Object = rk.GetValue(valueName)
        Console.WriteLine("Object Type = " + o.GetType().FullName)
        Console.WriteLine()
        Select Case rk.GetValueKind(valueName)
            Case RegistryValueKind.String
            Case RegistryValueKind.ExpandString
                Console.WriteLine("Value = " + o)
            Case RegistryValueKind.Binary
                For Each b As Byte In CType(o,Byte())
                    Console.Write("{0:x2} ", b)
                Next b
                Console.WriteLine()
            Case RegistryValueKind.DWord
                Console.WriteLine("Value = " + Convert.ToString(CType(o,Int32)))
            Case RegistryValueKind.QWord
                Console.WriteLine("Value = " + Convert.ToString(CType(o,Int64)))
            Case RegistryValueKind.MultiString
                For Each s As String In CType(o,String())
                    Console.Write("[{0:s}], ", s)
                Next s
                Console.WriteLine()
            Case Else
                Console.WriteLine("Value = (Unknown)")
        End Select

        ' Attempt to retrieve a value that does not exist; the specified
        ' default value is returned.
        Dim Def As String = rk.GetValue("notavalue", "The default to return")
        Console.WriteLine()
        Console.WriteLine(def)

        rk.Close()
    End Sub
End Class
'
' Output:
' Retrieving registry value ...
'
' Object Type = System.String
'
' Value = testData
'
'The default to return

Opmerkingen

Gebruik deze overbelasting om GetValue de case af te handelen waarin nog geen naam bestaat, bijvoorbeeld de eerste keer dat uw toepassing wordt uitgevoerd. Wanneer u deze overbelasting aanroept, gebruikt u de defaultValue parameter om de waarde op te geven die moet worden geretourneerd als name deze niet bestaat.

Note

Een registersleutel kan één waarde hebben die niet is gekoppeld aan een naam. Wanneer deze niet-benoemde waarde wordt weergegeven in de registereditor, wordt de tekenreeks (standaard) weergegeven in plaats van een naam. Als u deze niet-benoemde waarde wilt ophalen, geeft u null een van de lege tekenreeksen ("") op voor name.

Wanneer de GetValue methode uitbreidbare tekenreekswaarden ophaalt (RegistryValueKind.ExpandString), worden omgevingsreeksen uitgebreid met behulp van gegevens uit de lokale omgeving. Als u uitbreidbare tekenreekswaarden wilt ophalen uit het register op een externe computer, gebruikt u de GetValue overbelasting om op te geven dat u niet wilt dat omgevingsreeksen worden uitgevouwen.

Note

Als een waarde met uitbreidbare verwijzingen naar omgevingsvariabelen is opgeslagen als een tekenreeks (RegistryValueKind.String), in plaats van als een uitbreidbare tekenreeks (RegistryValueKind.ExpandString), wordt deze niet door de GetValue methode uitgebreid. U kunt een dergelijke tekenreeks uitvouwen nadat deze is opgehaald door de methode aan te ExpandEnvironmentVariables roepen.

Note

De aanbevolen manier om gegevens op te halen uit de sleutel is het gebruik van de PerformanceDataPerformanceCounter klasse in plaats van de RegistryKey.GetValue methode.

GetValue biedt geen ondersteuning voor het lezen van waarden van het type REG_NONE of REG_LINK. In beide gevallen wordt de standaardwaarde (null) geretourneerd in plaats van de werkelijke waarde.

Zie ook

Van toepassing op