GUID=変数があり、その値をテキストファイル内に書き込みたい。GUID定義は:
typedef struct _GUID { // size is 16
DWORD Data1;
Word Data2;
Word Data3;
BYTE Data4[8];
} GUID;
しかし、私はその値を次のように書きたいです:
CA04046D-0000-0000-0000-504944564944
私はそれを観察しました:
Data1
はCA04046Dの10進数値を保持しますData2
は、0の10進数値を保持しますData3
は、次の0の10進数値を保持しますしかし、他の人はどうですか?
出力を得るためにこの値を解釈する必要がありますか、またはそのような変数を印刷するより直接的な方法がありますか?
StringFromCLSID 関数を使用して文字列に変換します
例えば。:
GUID guid;
CoCreateGuid(&guid);
OLECHAR* guidString;
StringFromCLSID(guid, &guidString);
// use guidString...
// ensure memory is freed
::CoTaskMemFree(guidString);
Data4の説明については、 GUIDのMSDN定義 も参照してください。これは、GUIDの最後の8バイトを含む配列です。
時々、独自にロールするのに便利です。私はfdioffの答えが好きでしたが、まったく正しくありません。サイズの異なる要素が11個あります。
printf("Guid = {%08lX-%04hX-%04hX-%02hhX%02hhX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX}",
guid.Data1, guid.Data2, guid.Data3,
guid.Data4[0], guid.Data4[1], guid.Data4[2], guid.Data4[3],
guid.Data4[4], guid.Data4[5], guid.Data4[6], guid.Data4[7]);
Output: "Guid = {44332211-1234-ABCD-EFEF-001122334455}"
GUIDレイアウトについては、Guiddef.hを参照してください。
同じ、メソッドとして:
void printf_guid(GUID guid) {
printf("Guid = {%08lX-%04hX-%04hX-%02hhX%02hhX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX}",
guid.Data1, guid.Data2, guid.Data3,
guid.Data4[0], guid.Data4[1], guid.Data4[2], guid.Data4[3],
guid.Data4[4], guid.Data4[5], guid.Data4[6], guid.Data4[7]);
}
このメソッドにCLSIDを渡すこともできます。
コードでATL/MFCを使用する場合、 CComBSTR::CComBSTR(REFGUID guid)
from atlbase.h
:
GUID guid = ...;
const CComBSTR guidBstr(guid); // Converts from binary GUID to BSTR
const CString guidStr(guidBstr); // Converts from BSTR to appropriate string, ANSI or Wide
変換とメモリのクリーンアップが自動的に行われます。
C++の方法を好む場合
std::ostream& operator<<(std::ostream& os, REFGUID guid){
os << std::uppercase;
os.width(8);
os << std::hex << guid.Data1 << '-';
os.width(4);
os << std::hex << guid.Data2 << '-';
os.width(4);
os << std::hex << guid.Data3 << '-';
os.width(2);
os << std::hex
<< static_cast<short>(guid.Data4[0])
<< static_cast<short>(guid.Data4[1])
<< '-'
<< static_cast<short>(guid.Data4[2])
<< static_cast<short>(guid.Data4[3])
<< static_cast<short>(guid.Data4[4])
<< static_cast<short>(guid.Data4[5])
<< static_cast<short>(guid.Data4[6])
<< static_cast<short>(guid.Data4[7]);
os << std::nouppercase;
return os;
}
使用法:
static const GUID guid =
{ 0xf54f83c5, 0x9724, 0x41ba, { 0xbb, 0xdb, 0x69, 0x26, 0xf7, 0xbd, 0x68, 0x13 } };
std::cout << guid << std::endl;
出力:
F54F83C5-9724-41BA-BBDB-6926F7BD6813
StringFromGUID2()を使用して、特別な文字列の割り当て/割り当て解除の必要性を排除できます。
GUID guid = <some-guid>;
// note that OLECHAR is a typedef'd wchar_t
wchar_t szGUID[64] = {0};
StringFromGUID2(&guid, szGUID, 64);
JustinB の答えに触発された
#define GUID_FORMAT "%08lX-%04hX-%04hX-%02hhX%02hhX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX"
#define GUID_ARG(guid) guid.Data1, guid.Data2, guid.Data3, guid.Data4[0], guid.Data4[1], guid.Data4[2], guid.Data4[3], guid.Data4[4], guid.Data4[5], guid.Data4[6], guid.Data4[7]
その後
printf("Int = %d, string = %s, GUID = {" GUID_FORMAT "}\n", myInt, myString, GUID_ARG(myGuid));
googleのbreakpad プロジェクトの礼儀:
std::string ToString(GUID *guid) {
char guid_string[37]; // 32 hex chars + 4 hyphens + null terminator
snprintf(
guid_string, sizeof(guid_string),
"%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x",
guid->Data1, guid->Data2, guid->Data3,
guid->Data4[0], guid->Data4[1], guid->Data4[2],
guid->Data4[3], guid->Data4[4], guid->Data4[5],
guid->Data4[6], guid->Data4[7]);
return guid_string;
}
UUID guid = {0};
UuidCreate(&guid);
std::cout << GUIDToString(&guid);
私は質問がかなり古いことを知っていますが、これは多分うまくいくでしょうか?
inline std::ostream& operator <<(std::ostream& ss,GUID const& item) {
OLECHAR* bstrGuid;
::StringFromCLSID(item, &bstrGuid);
ss << bstrGuid;
::CoTaskMemFree(bstrGuid);
return ss;
}
idToString 関数を使用してGUID=文字列に変換します。この関数はGUIDのtypedefであるUUIDタイプを受け入れます。
std::string
GuidToString(const GUID& guid, bool lower = false)
{
const char* hexChars = lower ? "0123456789abcdef" : "0123456789ABCDEF";
auto f = [hexChars](char* p, unsigned char v)
{
p[0] = hexChars[v >> 4];
p[1] = hexChars[v & 0xf];
};
char s[36];
f(s, static_cast<unsigned char>(guid.Data1 >> 24));
f(s + 2, static_cast<unsigned char>(guid.Data1 >> 16));
f(s + 4, static_cast<unsigned char>(guid.Data1 >> 8));
f(s + 6, static_cast<unsigned char>(guid.Data1));
s[8] = '-';
f(s + 9, static_cast<unsigned char>(guid.Data2 >> 8));
f(s + 11, static_cast<unsigned char>(guid.Data2));
s[13] = '-';
f(s + 14, static_cast<unsigned char>(guid.Data3 >> 8));
f(s + 16, static_cast<unsigned char>(guid.Data3));
s[18] = '-';
f(s + 19, guid.Data4[0]);
f(s + 21, guid.Data4[1]);
s[23] = '-';
f(s + 24, guid.Data4[2]);
f(s + 26, guid.Data4[3]);
f(s + 28, guid.Data4[4]);
f(s + 30, guid.Data4[5]);
f(s + 32, guid.Data4[6]);
f(s + 34, guid.Data4[7]);
return std::string(s, 36);
}