小编典典

GUID 和 UUID 之间有什么区别吗?

all

我看到这两个首字母缩写词被抛出,我想知道 GUID 和 UUID 之间是否有任何区别?


阅读 256

收藏
2022-02-28

共1个答案

小编典典

简单的 答案 是:**没有区别,它们是一样的。

2020 年 8 月 20 日更新 :虽然 GUID(由 Microsoft 使用)和 UUID(由 RFC4122
定义)看起来相似并且用于相似的目的,但存在细微但偶尔重要的差异。具体来说,一些 Microsoft GUID
文档
允许 GUID
在任何位置包含任何十六进制数字,而 RFC4122 要求versionandvariant字段具有某些值。此外,[per that same
link],GUID 应该全部大写,而 UUID应该“输出为小写字符并且在输入时不区分大小写”。这可能导致代码库之间的不兼容(例如
this
)。

(原答案如下)


将它们视为用作唯一值的 16 字节(128 位)值。在微软语言中,它们被称为 GUID,但在不使用微软语言时称它们为 UUID。

甚至 UUID 规范的作者和微软也声称它们是同义词:

  • 从IETF RFC 4122A Universally Unique IDentifier (UUID) URN Namespace ”的介绍:“UUIDs(Universally Unique IDentifier)的Uniform Resource Name namespaces,也称为GUIDs(Globally Unique IDentifier)。”

  • 来自ITU-T X.667 建议书、ISO/IEC 9834-8:2004 国际标准:“UUID 也称为全球唯一标识符 (GUID),但本建议书不使用该术语。”

  • 微软甚至声称GUID 是由 UUID RFC 指定的:“在 Microsoft Windows 编程和 Windows 操作系统中,[RFC4122] 中指定的全局唯一标识符 (GUID) 是......术语通用唯一标识符 (UUID) ) 有时在 Windows 协议规范中用作 GUID 的同义词。”

但是 正确的答案 取决于当它说“UUID”时问题的含义......

第一部分取决于提问者在说“UUID”时的想法。

Microsoft 的声明暗示所有 UUID 都是 GUID。但是所有的 GUID 都是真正的 UUID 吗?也就是说,所有 UUID 的集合只是所有
GUID 集合的适当子集,还是完全相同的集合?

查看 RFC 4122 的详细信息,UUID 有四种不同的“变体”。这主要是因为在创建 UUID 规范时将这些规范组合在一起之前使用了这样的 16
字节标识符。从RFC 4122的第 4.1.1
节,UUID的四种 变体是:

  1. 保留,网络计算系统向后兼容
  2. RFC 4122 中指定的 变体 (其中有五个子变体,称为“版本”)
  3. 保留,Microsoft Corporation 向后兼容
  4. 保留以供将来定义。

根据 RFC 4122,所有 UUID 变体 都是“真正的 UUID”,那么所有的 GUID 都是真正的 UUID。对于字面问题“GUID 和 UUID
之间是否有任何区别”,对于 RFC 4122 UUID,答案肯定是否定的: 没有区别 (但受以下第二部分的约束)。

但并非所有 GUID 都是 变体 2 UUID(例如,Microsoft COM 的 GUID 是变体 3 UUID)。如果问题是“GUID 和变体 2
UUID 之间有什么区别”,那么答案是肯定的——它们可能不同。问这个问题的人可能不知道 变体 ,当他们说“UUID”这个词时,他们可能只想到 变体
2 UUID(例如,他们隐约知道 MAC 地址+时间和 UUID 的随机数算法形式,其中都是 变体 2)的两个 版本。 在这种情况下,答案是
肯定的不同* 。 __ *

因此,答案部分取决于提问者在说出“UUID”这个词时的想法。他们是指变体 2 UUID(因为这是他们知道的唯一变体)还是所有 UUID?

第二部分取决于使用哪个规范作为 UUID 的定义。

如果您认为这令人困惑,请阅读ITU-T X.667 ISO/IEC
9834-8:2004
,它应该与RFC
4122
保持一致并在技术上完全兼容。它在第 11.2
条中有一个额外的句子说:“所有符合本建议书 | 国际标准的 UUID 应具有变体位,其中八位字节 7 的位 7 设置为 1,八位字节 7 的位 6 设置为
0”。这意味着只有 变体 2 UUID 符合该标准(这两个位值表示 变体 2)。如果这是真的,那么并非所有 GUID 都符合
ITU-T/ISO/IEC UUID,因为符合 ITU-T/ISO/IEC UUID 只能是 变体 2 值。

因此,真正的答案还取决于问题所询问的 UUID 规范。假设我们清楚地谈论所有 UUID 而不仅仅是变体 2 UUID:GUID 和 IETF 的 UUID
之间 没有区别 ,但GUID 和 符合 ITU-T/ISO/IEC 的 UUID之间是有 区别的! __

二进制编码可能不同

当以二进制编码(与人类可读的文本格式相反)时,GUID可以存储在具有以下四个不同字段的结构中。此格式与
[UUID 标准] 8的区别仅在于前 3 个字段的字节顺序。

Bits  Bytes Name   Endianness  Endianness
                   (GUID)      RFC 4122

32    4     Data1  Native      Big
16    2     Data2  Native      Big
16    2     Data3  Native      Big
64    8     Data4  Big         Big
2022-02-28