使用 Golang 创建文件ID描述符
在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是Golang学习者,那么本文《使用 Golang 创建文件ID描述符》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!
问题内容我正在尝试在 golang 中创建这个结构 -
typedef struct file_id_descriptor {
dword dwsize;
file_id_type type;
union {
large_integer fileid;
guid objectid;
file_id_128 extendedfileid;
} dummyunionname;
} file_id_descriptor, *lpfile_id_descriptor;
正如您所看到的,这取决于三个的并集,其中未知的是 file_id_128
和另一个名为 file_id_type
的结构,所以我偶然发现了这一点,即 file_id_128
s 和 _file_id_type
结构在这里和这里
typedef enum _FILE_ID_TYPE {
FileIdType,
ObjectIdType,
ExtendedFileIdType,
MaximumFileIdType
} FILE_ID_TYPE, *PFILE_ID_TYPE;
在做了一些研究之后,我发现 enum 在 go 中是 const,但是在 go 中,我们不能有一个命名的 const,所以也许 struct(?) 和 union 是字节切片。但我找不到 maximumfileidtype
的含义以及如何在 go 中实现它。提前致谢。
另外,请参考我正在关注的内容。
解决方案
这里是准备使用的代码(取自 here,应用了修复:在存储库中设置了结构的磨损大小,这会导致 invalid prameter (87)
错误):
type ID [16]byte
func (id ID) Descriptor() Descriptor {
var structType uint32
if id.IsInt64() {
structType = FileType
} else {
structType = ExtendedFileIDType
}
return Descriptor{
Size: 24, // (1)
Type: structType,
Data: id.LittleEndian(),
}
}
func (id ID) IsInt64() bool {
upper := int64(id[0])<<56 | int64(id[1])<<48 | int64(id[2])<<40 | int64(id[3])<<32 | int64(id[4])<<24 | int64(id[5])<<16 | int64(id[6])<<8 | int64(id[7])
return upper == 0
}
func (id ID) LittleEndian() (value [16]byte) {
for i := 0; i < 16; i++ {
value[i] = id[15-i]
}
return
}
type Descriptor struct {
Size uint32
Type uint32
Data [16]byte
}
const (
FileType = iota
ObjectIDType
ExtendedFileIDType
)
一些解释:
(1) 大小始终必须为 24,因为它必须等于 sizeof(file_id_descriptor)
,其计算如下:
sizeof(dword) + sizeof(enum) + sizeof(union)
由于 dword
是 uint32
,因此 sizeof(dword)
是 4 个字节;在 c++ 中,枚举也表示为 uint32
; sizeof(union)
等于联合体最大成员的大小,在我们的例子中是 file_id_128
。 128位值的大小是16字节。
因此上面的表达式可以替换为:
4 + 4 + 16 = 24
终于介绍完啦!小伙伴们,这篇关于《使用 Golang 创建文件ID描述符》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~编程网公众号也会发布Golang相关知识,快来关注吧!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341