- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我用C编写了一个应用程序,我想将以下struct
数据通过网络套接字发送给另一个进程。我的结构定义如下所示:
typedef struct __attribute__((__packed__)) Matrix {
uint32_t rows;
uint32_t cols;
char * matrix;
} matrix_s;
typedef struct __attribute__((__packed__)) RequestPacket {
uint32_t request_code;
matrix_s * mat;
} request_packet_s;
RequestPacket
/
send
通过网络发送
write
,但是我不确定如何处理数组指针。如果我在结构中使用静态数组将没有问题,但是它必须是动态的,因为我不会提前知道
rows
和
cols
。此外,指针无法由其他进程解释,因此我需要通过套接字发送原始数据。
__packed__
属性,以消除填充。很好,但是如果我需要先将所有数据倒入线性缓冲区中然后再发送,那又有什么用呢?
最佳答案
性能良好的代码应使副本最少。下面的方法在用户代码中不执行任何复制,也不重写数据,并且可以采用从网络卡直接复制到应用程序内存的零复制路径。
这两个结构以及字符数组构成一棵树。对象是树节点,指向对象的指针是树边缘。
要传输树,您需要以某种顺序遍历它。只要发送方和接收方都同意该顺序,是宽度优先,深度优先还是其他顺序取决于您。
按遍历顺序发送结构,无需进行任何更改。接收器忽略指针,并利用遍历顺序将指针重写为接收端的正确位置。
例如-假设阻止了代码,并编写了safe_write
来正确处理信号(大多数使用裸write
而没有包装的代码都在做错-众所周知,POSIX API很难正确使用;因为它们看起来很有效,它们会让您自满-直到他们不会)。
我们还要确定我们的API将正确处理NULL指针-它将跳过NULL指针,并且如果接收到NULL指针,接收方将不会期望发送任何内容。
您尚 Unresolved 问题是版本控制:实际上,您定义的大多数对象都没有大小,因此将来无法扩展。可以通过向每个结构添加显式长度字段来解决此问题,以便接收器可以正确地对其进行构图。只需忽略其他字段即可。
类型
结构定义已可移植到32位和64位平台之间。
typedef unsigned char BOOL;
enum { FALSE, TRUE };
#define PTR(type, name) union { type *name; uint64_t name##_; }
#define MAX_MATRIX_SIZE 128*128
typedef struct __attribute__((__packed__)) Matrix {
uint32_t rows;
uint32_t cols;
PTR(char, matrix);
} matrix_s;
typedef struct __attribute__((__packed__)) RequestPacket {
uint32_t request_code;
PTR(matrix_s, mat);
PTR(matrix_s, opt_kernel);
} request_packet_s;
#undef PTR
BOOL safe_write(int fd, void *buf, size_t length) {
// Returns TRUE if buf is NULL or if writing had succeeded, FALSE on error
if (!buf) return TRUE;
assert(length);
// TODO
return FALSE;
}
BOOL sendBytes(int fd, char *bytes, size_t length) {
if (!bytes) return TRUE;
assert(length); // Sending a non-NULL pointer for a zero-sized block
// we shall declare to be a protocol error. Since
// this is the send side, this is a bug.
return safe_write(fd, bytes, length);
}
BOOL sendMatrix(int fd, matrix_s *mat) {
if (!mat) return TRUE;
if (!safe_write(fd, mat, sizeof(*mat))) return FALSE;
return sendBytes(fd, mat->matrix, mat->rows * mat->cols);
}
BOOL sendRequestPacket(int fd, request_packet_s *req) {
if (!req) return TRUE;
if (!safe_write(fd, req, sizeof(*req))) return FALSE;
if (!sendMatrix(fd, req->mat)) return FALSE;
return sendMatrix(fd, req->opt_kernel);
}
BOOL safe_read(int fd, void *buf, size_t length) {
// Returns TRUE if reading had succeeded, FALSE on error
if (!buf) return TRUE;
if (!length) return FALSE; // Protocol error on receive: this is a
// data validation failure, and must be handled
// like any other error.
// TODO
return FALSE;
}
static inline BOOL free_read(void **const ptr) {
free(*ptr);
*ptr = NULL;
return FALSE;
}
BOOL malloc_read(int fd, void **const buf, size_t length) {
// This should be using an arena allocator, really.
if (!*buf) return TRUE;
if (!length) return FALSE;
*buf = malloc(length);
if (!*buf) return FALSE;
if (!safe_read(fd, *buf, length)) return free_read(buf);
return TRUE;
}
BOOL recvMatrix(int fd, matrix_s **const mat) {
if (!malloc_read(fd, mat, sizeof(**mat))) return FALSE;
size_t size = (*mat)->rows * (*mat)->cols;
if (size > MAX_MATRIX_SIZE) goto error;
if (size)
if (!malloc_read(fd, &(*mat)->matrix, size)) goto error;
return TRUE;
error:
return free_read(mat);
}
BOOL recvRequestPacket(int fd, request_packet_s **const req) {
if (!malloc_read(fd, req, sizeof(**req))) return FALSE;
if (!recvMatrix(fd, &(*req)->mat)) goto error1;
if (!recvMatrix(fd, &(*req)->opt_kernel)) goto error2;
return TRUE;
error2:
free_read(&(*req)->mat);
error1:
return free_read(req);
}
关于c - 套接字上具有数据数组的C结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60672318/
我目前正在尝试基于哈希表构建字典。逻辑是:有一个名为 HashTable 的结构,其中包含以下内容: HashFunc HashFunc; PrintFunc PrintEntry; CompareF
如果我有一个指向结构/对象的指针,并且该结构/对象包含另外两个指向其他对象的指针,并且我想删除“包含这两个指针的对象而不破坏它所持有的指针”——我该怎么做这样做吗? 指向对象 A 的指针(包含指向对象
像这样的代码 package main import "fmt" type Hello struct { ID int Raw string } type World []*Hell
我有一个采用以下格式的 CSV: Module, Topic, Sub-topic 它需要能够导入到具有以下格式的 MySQL 数据库中: CREATE TABLE `modules` ( `id
通常我使用类似的东西 copy((uint8_t*)&POD, (uint8_t*)(&POD + 1 ), back_inserter(rawData)); copy((uint8_t*)&PODV
错误 : 联合只能在具有兼容列类型的表上执行。 结构(层:字符串,skyward_number:字符串,skyward_points:字符串)<> 结构(skyward_number:字符串,层:字符
我有一个指向结构的指针数组,我正在尝试使用它们进行 while 循环。我对如何准确初始化它并不完全有信心,但我一直这样做: Entry *newEntry = malloc(sizeof(Entry)
我正在学习 C,我的问题可能很愚蠢,但我很困惑。在这样的函数中: int afunction(somevariables) { if (someconditions)
我现在正在做一项编程作业,我并没有真正完全掌握链接,因为我们还没有涉及它。但是我觉得我需要它来做我想做的事情,因为数组还不够 我创建了一个结构,如下 struct node { float coef;
给定以下代码片段: #include #include #define MAX_SIZE 15 typedef struct{ int touchdowns; int intercepti
struct contact list[3]; int checknullarray() { for(int x=0;x<10;x++) { if(strlen(con
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Empty “for” loop in Facebook ajax what does AJAX call
我刚刚在反射器中浏览了一个文件,并在结构构造函数中看到了这个: this = new Binder.SyntaxNodeOrToken(); 我以前从未见过该术语。有人能解释一下这个赋值在 C# 中的
我经常使用字符串常量,例如: DICT_KEY1 = 'DICT_KEY1' DICT_KEY2 = 'DICT_KEY2' ... 很多时候我不介意实际的文字是什么,只要它们是独一无二的并且对人类读
我是 C 的新手,我不明白为什么下面的代码不起作用: typedef struct{ uint8_t a; uint8_t* b; } test_struct; test_struct
您能否制作一个行为类似于内置类之一的结构,您可以在其中直接分配值而无需调用属性? 前任: RoundedDouble count; count = 5; 而不是使用 RoundedDouble cou
这是我的代码: #include typedef struct { const char *description; float value; int age; } swag
在创建嵌套列表时,我认为 R 具有对列表元素有用的命名结构。我有一个列表列表,并希望应用包含在任何列表中的每个向量的函数。 lapply这样做但随后剥离了列表的命名结构。我该怎么办 lapply嵌套列
我正在做一个用于学习目的的个人组织者,我从来没有使用过 XML,所以我不确定我的解决方案是否是最好的。这是我附带的 XML 文件的基本结构:
我是新来的 nosql概念,所以当我开始学习时 PouchDB ,我找到了这个转换表。我的困惑是,如何PouchDB如果可以说我有多个表,是否意味着我需要创建多个数据库?因为根据我在 pouchdb
我是一名优秀的程序员,十分优秀!