问题详情:
如何实现将ArkTS的HashMap转换至Native侧。
解决措施:
-
方案一:传递数组。
将HashMap的key、value作为数组取出,将两个数组传递至Native侧并组装成Map。
ArkTS侧传递数组。
let hashMap: HashMap<string, number> = new HashMap();
hashMap.set("Abc", 123);
hashMap.set("Bcd", 234)
hashMap.set("Cde", 345);
let keysArray: Array<string> = Array.from(hashMap.keys());
let valuesArray: Array<number> = Array.from(hashMap.values());
testNapi.tsPutMap(keysArray, valuesArray, hashMap.length);
在Native侧组装Map。
// 将value转成字符串返回
std::string HashMap::value2String(napi_env env, napi_value value) {
size_t stringSize = 0;
napi_get_value_string_utf8(env, value, nullptr, 0, &stringSize); // 获取字符串长度
std::string valueString;
valueString.resize(stringSize + 1);
napi_get_value_string_utf8(env, value, &valueString[0], stringSize + 1, &stringSize); // 根据长度转换成字符串
return valueString;
}
napi_value HashMap::TsPutMap(napi_env env, napi_callback_info info) {
std::map<std::string, int> myMap;
size_t argc = 3;
napi_value args[3] = {nullptr};
napi_get_cb_info(env, info, &argc, args, nullptr, nullptr);
napi_value mapKey = args[0]; // key
napi_value mapVal = args[1]; // value
napi_value mapNum = args[2]; // length
uint32_t mapCNum = 0;
napi_get_value_uint32(env, mapNum, &mapCNum);
for (uint32_t i = 0; i < mapCNum; i++) {
napi_value keyNIndex, valNIndex;
napi_get_element(env, mapKey, i, &keyNIndex);
napi_get_element(env, mapVal, i, &valNIndex);
std::string keyIndex = value2String(env, keyNIndex);
int valIndex = 0;
napi_get_value_int32(env, valNIndex, &valIndex);
myMap[keyIndex] = valIndex;
OH_LOG_Print(LOG_APP, LOG_INFO, 0x0000, "Pure", "%{public}s %{public}d", keyIndex.c_str(), myMap[keyIndex]);
}
return nullptr;
}
-
方案二:传递JSON。
将HashMap转换为Json数据传至Native侧,在Native侧反序列化用Map承接。
ArkTS侧转JSON。
- JSON.stringify不支持对HashMap操作,需要先将其转成Record
map2rec(map: HashMap<string, ESObject>): Record<string, ESObject> {
// map转Record
let Rec: Record<string, ESObject> = {};
map.forEach((value: ESObject, key: string) => {
if (value instanceof HashMap) {
//如果value是HashMap类型
let vRec: Record<string, ESObject> = this.map2rec(value);
value = vRec;
}
Rec[key] = value;
})
return Rec;
}
- 然后使用JSON.stringify序列化
let myRec: Record<string, ESObject> = this.map2rec(hashMap);
let str: string = JSON.stringify(myRec);
testNapi.mapJson(str);
Native侧反序列化。
C++没有直接反序列化的接口,需要使用三方库,本demo采用lycium交叉编译工具编译json三方库。
napi_value HashMap::MapJson(napi_env env, napi_callback_info info) {
size_t argc = 1;
napi_value args[1] = {nullptr};
napi_get_cb_info(env, info, &argc, args, nullptr, nullptr);
std::string jsonStr = value2String(env, args[0]);
std::map<std::string, int> myMap = nlohmann::json::parse(jsonStr.c_str());
OH_LOG_Print(LOG_APP, LOG_INFO, 0x0000, "Pure", "%{public}d %{public}d %{public}d", myMap["Abc"], myMap["Bcd"],
myMap["Cde"]);
return nullptr;
}
最后呢
很多开发朋友不知道需要学习那些鸿蒙技术?鸿蒙开发岗位需要掌握那些核心技术点?为此鸿蒙的开发学习必须要系统性的进行。
而网上有关鸿蒙的开发资料非常的少,假如你想学好鸿蒙的应用开发与系统底层开发。你可以参考这份资料,少走很多弯路,节省没必要的麻烦。由两位前阿里高级研发工程师联合打造的《鸿蒙NEXT星河版OpenHarmony开发文档》里面内容包含了(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(Harmony NEXT)技术知识点
如果你是一名Android、Java、前端等等开发人员,想要转入鸿蒙方向发展。可以直接领取这份资料辅助你的学习。下面是鸿蒙开发的学习路线图。
针对鸿蒙成长路线打造的鸿蒙学习文档。话不多说,我们直接看详细鸿蒙(OpenHarmony )手册(共计1236页)与鸿蒙(OpenHarmony )开发入门视频,帮助大家在技术的道路上更进一步。
- 《鸿蒙 (OpenHarmony)开发学习视频》
- 《鸿蒙生态应用开发V2.0白皮书》
- 《鸿蒙 (OpenHarmony)开发基础到实战手册》
- OpenHarmony北向、南向开发环境搭建
- 《鸿蒙开发基础》
- 《鸿蒙开发进阶》
- 《鸿蒙开发实战》
总结
鸿蒙—作为国家主力推送的国产操作系统。部分的高校已经取消了安卓课程,从而开设鸿蒙课程;企业纷纷跟进启动了鸿蒙研发。
并且鸿蒙是完全具备无与伦比的机遇和潜力的;预计到年底将有 5,000 款的应用完成原生鸿蒙开发,未来将会支持 50 万款的应用。那么这么多的应用需要开发,也就意味着需要有更多的鸿蒙人才。鸿蒙开发工程师也将会迎来爆发式的增长,学习鸿蒙势在必行! 自↓↓↓拿