go c 通过内存原始二进制内容直接传递结构体

go c 通过内存原始二进制内容直接传递结构体

传统数据传输通常通过半结构化数据(json/yaml/xml...)来交换信息。但是go 支持 二进制数据层面支持c 结构体。带来的好处就是相较于半结构化数据类型来说更快(在go中,解析和生成json/yaml/xml...到结构体都会经过一层反射到结构体,数据单向流通会是1层反射,如果数据双向即生成又要解析那么就会用上2层反射).

而使用内存直接交换(在不涉及指针(由于指针只是一个记录硬件地址的一个地址,也叫做虚拟指针。只在单个进程中有效,到其它进程中只是一串毫无用处的占8位字节的数字uint64),字符串类型的情况下是非常快的).

此处直接书接上文[go 内存二进制数据操作]继续。类型定义不清楚的可以看那边文章.本文内存二进制数据采取直接写入和从文件中读出。若你想使用共享内存来代替,可参考我的文章[golang 操作共享内存]

go 复制代码
type SharePointer[T any] struct {
	*Pointer[T]
}

func (s *SharePointer[T]) Dump(w io.Writer) {
    _, err := w.Write(s.Bytes())
	if err != nil {
		panic("write to disk failed " + err.Error())
	}
}
//一个计数类型,占用8位字节
//在操作原始内存上推荐使用明确大小的类型.如使用int32 代替int,因为int随着系统的变换对应的位数在变动
type Count struct {
	A uint32
	B uint16
	C uint16
}

func NewSharePointer[T any]() *SharePointer[T] {
	return &SharePointer[T]{Pointer: NewPointer[T]()}
}
func main() {
	ptr := NewSharePointer[Count]()
	f, err := os.OpenFile("test.shm", os.O_CREATE|os.O_WRONLY, 0644)
	if err != nil {
		panic("open test.shm failed " + err.Error())
	}
    //修改一下数据
    ptr.Pointer.T.A = 23
	ptr.Pointer.T.B = 13
	ptr.Pointer.T.C = 23
	defer f.Close()
	ptr.Dump(f) //写入硬盘
	//从硬盘中读取
	fe, err := os.OpenFile("test.shm", os.O_RDONLY, 0640)
	if err != nil {
		panic("read test.shm failed " + err.Error())
	}
	defer fe.Close()
	_, err = fe.Read(ptr.Bytes())
	if err != nil {
		panic("read test.shm failed " + err.Error())
	}
	fmt.Println(*ptr.T)
}

c 操作

c 操作很简单,直接将结果体指针写入文件,读取也是一样

c 复制代码
#include <stdint.h>
#include <unistd.h>
struct __count{
    uint32_t a;
    uint16_t b;
    uint16_t c;
};
int main(){
    struct __count count;
    //....
    write(fd,&count,sizeof(count));
    read(fd,&count,sizeof(count));
    //....
}
相关推荐
明洞日记几秒前
【数据结构手册002】动态数组vector - 连续内存的艺术与科学
开发语言·数据结构·c++
福尔摩斯张3 分钟前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
fashion 道格5 分钟前
数据结构实战:深入理解队列的链式结构与实现
c语言·数据结构
6***37941 小时前
Java安全
java·开发语言·安全
铁手飞鹰1 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
豐儀麟阁贵1 小时前
8.1 异常概述
java·开发语言
czhc11400756632 小时前
C# 1124 接收
开发语言·c#
[J] 一坚3 小时前
深入浅出理解冒泡、插入排序和归并、快速排序递归调用过程
c语言·数据结构·算法·排序算法
司铭鸿3 小时前
祖先关系的数学重构:从家谱到算法的思维跃迁
开发语言·数据结构·人工智能·算法·重构·c#·哈希算法
wavemap3 小时前
先到先得:免费订阅一年ChatGPT Go会员
开发语言·chatgpt·golang