鸿蒙DevEvo Studio运行React Native生成的bundle文件遇到的一个问题

下面是运行到测试机上时的一段报错信息

bash 复制代码
Reason:Signal:SIGABRT(SI_TKILL)@0x01317b240000d29c from:53916:20020004
LastFatalMessage:█____ RNInstanceFactory.h:267> The C_API architecture also needs to be enabled on the CPP side. Have you set the RNOH_C_API_ARCH="1" environment variable, completely closed and reopened DevEco Studio and run Build > Clean Project?

这里指出的是一个环境变量,最开始时我在~/.bash_profile配置了相应的下面环境配置

bash 复制代码
PATH=$PATH:/Users/xxx/Library/OpenHarmony/Sdk/12/toolchains
export HDC_SERVER_PORT=7035
launchctl setenv HDC_SERVER_PORT $HDC_SERVER_PORT
export RNOH_C_API_ARCH=1

这样在控制台输入

bash 复制代码
echo $RNOH_C_API_ARCH

结果也是返回1的,但打开DevEvo Studio运行app还是不生效,还是报错,这是因为终端目前用的不是shell,而是zsh,像下面这样输入,可以看到终端用的是zsh

bash 复制代码
echo $SHELL

输出结果为:/bin/zsh,这是因为目前的终端用的不是shell,所以之前设置~/.bash_profile是没有用的

此时可以在zsh 的配置文件中配置引入~/.bash_profile中的环境配置

bash 复制代码
打开zsh的本地配置文件
vim ~/.zshrc

文件末尾加入下面配置
source ~/.bash_profile

保存退出后使环境生效
source ~/.zshrc

这样重启后还是不能解决之前的报错,然后打开目前鸿蒙工程的根目录,删除工程中之前构建编译产生的缓存

bash 复制代码
打开现有工程的根目录
cd /Users/xxx/Desktop/code-hm/harmonyajkproject

清空相应的缓存
rm -rf entry/build
rm -rf entry/.cxx
rm -rf build
rm -rf oh_modules/.cache

这样重启后打开DevEvo Studio还是不行,这里需要在终端打开DevEvo Studio,因为可能DevEvo Studio不会默认去读取终端里的环境配置

bash 复制代码
open /Applications/DevEco-Studio.app

如此折腾一番,还是报错,最后终极的解决办法,如下:

Cmd + Shift + F (macOS) 或 Ctrl + Shift + F (Windows)

在搜索框中输入:CMakeLists.txt,在这个CMakeLists.txt文件的开发加入下面这行配置代码:

bash 复制代码
set(RNOH_C_API_ARCH 1)

然后在菜单栏Build > Clean Project 清理项目,再重新编译运行

相关推荐
AI_零食5 小时前
开源鸿蒙跨平台Flutter开发:昼夜节律与睡眠相位-脑电波周期与最佳苏醒测绘架构
flutter·ui·华为·架构·开源·harmonyos·鸿蒙
AI_零食5 小时前
Flutter 框架跨平台鸿蒙开发 - 自定义式按钮设计应用
学习·flutter·ui·华为·harmonyos·鸿蒙
Lee川7 小时前
从零构建现代化登录界面:React + Tailwind CSS 前端工程实践
前端·react.js
Embrace9249 小时前
React Native + Realm 离线方案处理
javascript·react native·react.js·realm
samroom10 小时前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
TheRouter12 小时前
构建一个支持多模型的 AI 聊天应用:React + TheRouter API 全栈教程
前端·人工智能·react.js
yuki_uix12 小时前
面试题里的 Custom Hook 思维:从三道题总结「异步状态管理」通用模式
前端·react.js·面试
Cxiaomu13 小时前
React Native 双端一体工程,如何实现分端运行与分端打包?
javascript·react native·react.js
斌味代码14 小时前
React 开发者学 Vue3:Composition API 核心用法对照与避坑实录
javascript·vue.js·react.js
一只小阿乐14 小时前
react路由中使用context
前端·javascript·react.js·context 上下文