什么是UUID及其实现代码

UUID及其实现代码

UUID含义是通用唯一识别码(Universally Unique Identifier),这是一个软件建构的标准,也是被开源软件基金会的组织应用在分布式计算环境 (Distributed Computing Environment, DCE) 领域的一部份。

 

作用

UUID 的目的,是让分布式系统中的所有元素,都能有唯一的辨识资讯,而不需要透过中央控制端来做辨识资讯的指定。如此一来,每个人都可以建立不与其它人冲突的 UUID。在这样的情况下,就不需考虑数据库建立时的名称重复问题。目前最广泛应用的 UUID,即是微软的 Microsoft's Globally Unique Identifiers (GUIDs),而其他重要的应用,则有Linux ext2/ext3 档案系统、LUKS 加密分割区、GNOME、KDE、Mac OS X 等等。

 

组成

UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成的API。UUID由以下几部分的组合:

(1)当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。

  (2)时钟序列。

(3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。

UUID的唯一缺陷在于生成的结果串会比较长。

应用

使用UUID的好处在分布式的软件系统中(比如:DCE/RPC, COM+,CORBA)就能体现出来,它能保证每个节点所生成的标识都不会重复,并且随着WEB服务等整合技术的发展,UUID的优势将更加明显。根据使用的特定机制,UUID不仅需要保证是彼此不相同的,或者最少也是与公元3400年之前其他任何生成的通用唯一标识符有非常大的区别。


实现代码

以下是一段在C++Builder中实现的生成UUID代码(是本人的师兄之作我也不太懂):

String __fastcall TFrmParent::UUIDGenerator()

{

  TADOQuery* uuidQry=new  TADOQuery(NULL);

 uuidQry->Connection=FrmDataModule->ADOConnect;

  uuidQry->SQL->Clear();

 uuidQry->SQL->Text="select uuid()";

  uuidQry->Open();

  StringuuidStr=uuidQry->FieldByName("uuid()")->AsString;

  delete uuidQry;

  uuidQry=NULL;

  return uuidStr;

}

你可能感兴趣的:(uuid)