<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > Delphi中比較GUID是否相等

          Delphi中比較GUID是否相等

          作者: 時間:2011-06-27 來源:網(wǎng)絡(luò) 收藏

          1、CompareMem(@guid1, @guid2, SizeOf(T))
          最開始時想到的方法。
          查看中T的定義可以看到T實際上是一個結(jié)構(gòu)。對于結(jié)構(gòu)的來說最方便的就是內(nèi)存直接了。
          TGUID = packed record
          D1: LongWord;
          D2: Word;
          D3: Word;
          D4: array[0..7] of Byte;
          end;

          本文引用地址:http://www.ex-cimer.com/article/150560.htm

          2、SysUtils.IsEqualGUID(const guid1, guid2: TGUID)
          經(jīng)人提醒后發(fā)現(xiàn)在SysUtils單元已經(jīng)有了一個這樣專門GUID的函數(shù)。查看SysUtils的源碼可以看到,在Windows下直接調(diào)用ole32.dll的函數(shù)IsEqualGUID,在Linux下將GUID轉(zhuǎn)換成整型數(shù)組然后比較數(shù)組中的每個元素。效果和上面的CompareMem一樣。
          {$IFDEF MSWINDOWS}
          function IsEqualGUID; external 'ole32.dll' name 'IsEqualGUID';
          {$ENDIF MSWINDOWS}
          {$IFDEF LINUX}
          function IsEqualGUID(const guid1, guid2: TGUID): Boolean;
          var
          a, b: PIntegerArray;
          begin
          a := PIntegerArray(@guid1);
          b := PIntegerArray(@guid2);
          Result := (a^[0] = b^[0]) and (a^[1] = b^[1]) and (a^[2] = b^[2]) and (a^[3] = b^[3]);
          end;
          {$ENDIF LINUX}
          當(dāng)然,我們可以一次比較TGUID中的字段D1、D2、D3、D4,但這種方法顯然就沒有轉(zhuǎn)成數(shù)組后比較那么簡潔了。

          上面提到的兩種方法都可以用,并且在效率上也差不多。不過出于通用性的考慮,建議用封裝的函數(shù)SysUtils.IsEqualGUID更好。



          關(guān)鍵詞: 相等 是否 GUID 比較 Delphi

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();