Sie können auch String UUID = Guid.NewGuid (). ToString ()
Justin
10
GUID und UUID sind alle gleich?
Uma Shankar Subramani
17
@Uma Shankar Subramani: GUID = Global Unique Identifier, UUID = Universally Unique Identifier. Unterschiedliche Wörter für das gleiche Konzept.
Tudor
1
Wenn Sie die GUID als eine Zeichenfolge formatieren möchten, die sich von der Standardzeichenfolge unterscheidet, können Sie die ToString(string format)Überladung verwenden, die einen von mehreren Formatspezifizierern akzeptiert.
Michiel van Oosterhout
7
Sie sollten dies wahrscheinlich tun, System.Guid.NewGuid().ToString("B").ToUpper()wenn Sie mit einigen MS Build-Tools kompatibel sein möchten, die UUIDs in Kleinbuchstaben nicht verstehen. Beispielsweise haben vdprojSetup-Projekte UUIDs in Großbuchstaben und lösen eine Ausnahme aus, wenn Sie sie in Kleinbuchstaben angeben.
Mark Lakata
43
Seien Sie vorsichtig: Während die Zeichenfolgendarstellungen für .NET Guid und (RFC4122) UUID identisch sind, ist das Speicherformat nicht identisch . .NET handelt in den ersten drei GuidTeilen mit Little-Endian-Bytes .
Wenn Sie die Bytes übertragen (z. B. als base64), können Sie sie nicht einfach verwenden Guid.ToByteArray()und codieren. Sie benötigen Array.Reversedie ersten drei Teile (Daten1-3).
Ich mache es so:
var rfc4122bytes =Convert.FromBase64String("aguidthatIgotonthewire==");Array.Reverse(rfc4122bytes,0,4);Array.Reverse(rfc4122bytes,4,2);Array.Reverse(rfc4122bytes,6,2);var guid =newGuid(rfc4122bytes);
Bearbeiten : Dank an Jeff Walker, Code Ranger, für den Hinweis, dass die Interna für das Format des Byte-Arrays, das in den Byte-Array-Konstruktor und ein- und ausgeht, nicht relevant sind ToByteArray().
Hinweis: Mir ist klar, dass das OP wahrscheinlich gemeint ist Guid(da es für eine IDL vorgesehen ist), aber ich bin gerade darauf gestoßen. Also los, Binger und Googler.
Ben Mosher
1
Ich kann das nicht testen, aber sind Sie sicher, dass Sie den BitConverter.IsLittleEndian überprüfen sollten, anstatt nur immer umzukehren. In den Dokumenten für Guid.ToByteArray () wird die Bytereihenfolge als Little Endian aufgerufen und angegeben, dass der Konstruktor übereinstimmt. Die Spezifikation für GUID ist Little Endian. Ich würde denken, dass dies unabhängig von der Maschinenbyte-Reihenfolge sein sollte.
Jeff Walker Code Ranger
@ JeffWalkerCodeRanger: von Eric Lippert, vor langer
Ben Mosher
Ich sehe nicht, wie der Eric Lippert-Link die Frage beantwortet. Wenn ich mir den Mono-Code unter github.com/mono/mono/blob/master/mcs/class/corlib/System/… ansehe , sehe ich immer davon aus, dass die Bytes unabhängig von der nativen Endianness in Little-Endian-Reihenfolge vorliegen. Das passt zu meinem Verständnis, dass es, wenn es von der Plattform abhängt, nicht der Semantik der MS-API oder der Spezifikation entspricht. Wenn man sich die zerlegte mscorelib ansieht, scheint man anzunehmen, dass die Bytes im Array ebenfalls in Little-Endian-Reihenfolge vorliegen.
Jeff Walker Code Ranger
Sieht so aus, als hättest du recht. Während das interne Speicherformat endianness-sensitiv ist, sind der Konstruktor und ToByteArraynicht; Sie sind immer lil'endian. Eingehende bearbeiten.
Ben Mosher
3
Hier ist eine clientseitige "sequentielle Guid" -Lösung.
using System;
using System.Runtime.InteropServices;
namespace MyCompany.MyTechnology.Framework.CrossDomain.GuidExtend{publicstaticclassGuid{/*
Original Reference for Code:
http://www.pinvoke.net/default.aspx/rpcrt4/UuidCreateSequential.html
*/[DllImport("rpcrt4.dll",SetLastError=true)]staticexternintUuidCreateSequential(outSystem.Guid guid);publicstaticSystem.GuidNewGuid(){returnCreateSequentialUuid();}publicstaticSystem.GuidCreateSequentialUuid(){constint RPC_S_OK =0;System.Guid g;int hr =UuidCreateSequential(out g);if(hr != RPC_S_OK)thrownewApplicationException("UuidCreateSequential failed: "+ hr);return g;}/*
Text From URL above:
UuidCreateSequential (rpcrt4)
Type a page name and press Enter. You'll jump to the page if it exists, or you can create it if it doesn't.
To create a page in a module other than rpcrt4, prefix the name with the module name and a period.
. Summary
Creates a new UUID
C# Signature:
[DllImport("rpcrt4.dll", SetLastError=true)]
static extern int UuidCreateSequential(out Guid guid);
VB Signature:
Declare Function UuidCreateSequential Lib "rpcrt4.dll" (ByRef id As Guid) As Integer
User-Defined Types:
None.
Notes:
Microsoft changed the UuidCreate function so it no longer uses the machine's MAC address as part of the UUID. Since CoCreateGuid calls UuidCreate to get its GUID, its output also changed. If you still like the GUIDs to be generated in sequential order (helpful for keeping a related group of GUIDs together in the system registry), you can use the UuidCreateSequential function.
CoCreateGuid generates random-looking GUIDs like these:
92E60A8A-2A99-4F53-9A71-AC69BD7E4D75
BB88FD63-DAC2-4B15-8ADF-1D502E64B92F
28F8800C-C804-4F0F-B6F1-24BFC4D4EE80
EBD133A6-6CF3-4ADA-B723-A8177B70D268
B10A35C0-F012-4EC1-9D24-3CC91D2B7122
UuidCreateSequential generates sequential GUIDs like these:
19F287B4-8830-11D9-8BFC-000CF1ADC5B7
19F287B5-8830-11D9-8BFC-000CF1ADC5B7
19F287B6-8830-11D9-8BFC-000CF1ADC5B7
19F287B7-8830-11D9-8BFC-000CF1ADC5B7
19F287B8-8830-11D9-8BFC-000CF1ADC5B7
Here is a summary of the differences in the output of UuidCreateSequential:
The last six bytes reveal your MAC address
Several GUIDs generated in a row are sequential
Tips & Tricks:
Please add some!
Sample Code in C#:
static Guid UuidCreateSequential()
{
const int RPC_S_OK = 0;
Guid g;
int hr = UuidCreateSequential(out g);
if (hr != RPC_S_OK)
throw new ApplicationException
("UuidCreateSequential failed: " + hr);
return g;
}
Sample Code in VB:
Sub Main()
Dim myId As Guid
Dim code As Integer
code = UuidCreateSequential(myId)
If code <> 0 Then
Console.WriteLine("UuidCreateSequential failed: {0}", code)
Else
Console.WriteLine(myId)
End If
End Sub
*/}}
Die UUID kann wie in Java aus den niedrigsten und höchstwertigen Bits erstellt werden. Es macht sie auch sichtbar. Die Implementierung hat eine explizite Konvertierung in eine GUID und eine implizite Konvertierung von einer GUID.
Guid.NewGuid()
?Antworten:
Sie suchen wahrscheinlich
System.Guid.NewGuid()
.quelle
ToString(string format)
Überladung verwenden, die einen von mehreren Formatspezifizierern akzeptiert.System.Guid.NewGuid().ToString("B").ToUpper()
wenn Sie mit einigen MS Build-Tools kompatibel sein möchten, die UUIDs in Kleinbuchstaben nicht verstehen. Beispielsweise habenvdproj
Setup-Projekte UUIDs in Großbuchstaben und lösen eine Ausnahme aus, wenn Sie sie in Kleinbuchstaben angeben.Seien Sie vorsichtig: Während die Zeichenfolgendarstellungen für .NET Guid und (RFC4122) UUID identisch sind, ist das Speicherformat nicht identisch . .NET handelt in den ersten drei
Guid
Teilen mit Little-Endian-Bytes .Wenn Sie die Bytes übertragen (z. B. als base64), können Sie sie nicht einfach verwenden
Guid.ToByteArray()
und codieren. Sie benötigenArray.Reverse
die ersten drei Teile (Daten1-3).Ich mache es so:
In dieser Antwort finden Sie die spezifischen Details zur .NET-Implementierung.
Bearbeiten : Dank an Jeff Walker, Code Ranger, für den Hinweis, dass die Interna für das Format des Byte-Arrays, das in den Byte-Array-Konstruktor und ein- und ausgeht, nicht relevant sind
ToByteArray()
.quelle
Guid
(da es für eine IDL vorgesehen ist), aber ich bin gerade darauf gestoßen. Also los, Binger und Googler.ToByteArray
nicht; Sie sind immer lil'endian. Eingehende bearbeiten.Hier ist eine clientseitige "sequentielle Guid" -Lösung.
http://www.pinvoke.net/default.aspx/rpcrt4.uuidcreate
Schlüsselwörter: CreateSequentialUUID SequentialUUID
quelle
Ich weiß nichts über Methoden; Der Typ zur GUID kann jedoch über Folgendes erfolgen:
http://msdn.microsoft.com/en-us/library/system.runtime.interopservices.marshal.generateguidfortype.aspx
quelle
Ich habe einen GitHub Gist mit einer Java-ähnlichen UUID-Implementierung in C #: https://gist.github.com/rickbeerendonk/13655dd24ec574954366
Die UUID kann wie in Java aus den niedrigsten und höchstwertigen Bits erstellt werden. Es macht sie auch sichtbar. Die Implementierung hat eine explizite Konvertierung in eine GUID und eine implizite Konvertierung von einer GUID.
quelle