我正在编写一个用于反序列化数据的库。我有像这样的结构定义:
#ifndef SEARCHRESULTS_H
#define SEARCHRESULTS_H
typedef struct {
char *url;
} SearchResult;
typedef struct {
int count;
SearchResult *searchResults;
} SearchResults;
#endif
由于 C 缺乏反射,所有函数都必须手动编写,但我相信应该有一种很好的方法来解析标题、查找struct
名称和字段并生成函数(伪 C):
#include "SearchResults.h"
#include "pdata_serialization.h"
void SearchResult_parse(pdata *data, SearchResult *obj) {
obj->url = strdup(data->values["url"]);
}
void SearchResult_free(SearchResult *obj) {
free(obj->url);
free(obj);
}
void SearchResults_parse(pdata *data, SearchResults *obj) {
obj->count = data->values["count"];
obj->searchResults = malloc(sizeof(SearchResult) * obj->count);
for (int i = 0; i < obj->count; i++)
SearchResult_parse(data->values["searchResults"][i], &obj->searchResults[i]);
}
void SearchResults_free(SearchResults *obj) {
for (int i = 0; i < obj->count; i++)
SearchResult_free(&obj->searchResults[i]);
free(obj);
}
我不是在寻找一个完整的解决方案,而是一个理智和最小的想法和一个小例子。