当前位置: 首页 > news >正文

营销网站建设维护深圳公司网站设计哪家好

营销网站建设维护,深圳公司网站设计哪家好,wordpress好还是dz好,发布悬赏任务的推广平台DevecoStudio使用Native 今天,给大家带来的是关于DevecoStudio中使用Native进行开发 个人拙见:为什么要使用Native?无论是JS还是TS在复杂的情况下运行速度,肯定不如直接操作内存的C/C的运行速度快,所以,会选择使用Native;这里面的过程是什么?通过映射转化,使用napi提供的接口…

DevecoStudio使用Native

今天,给大家带来的是关于DevecoStudio中使用Native进行开发

个人拙见:为什么要使用Native?无论是JS还是TS在复杂的情况下运行速度,肯定不如直接操作内存的C/C++的运行速度快,所以,会选择使用Native;这里面的过程是什么?通过映射转化,使用napi提供的接口调用CMake后的C/C++的函数

个人代码–点我

第一步-建立Native项目

image-20241126104203994

第二步-去建立自己的demo

  1. 找到该路径src/main/cpp,再该路径下建一个demo

  2. demo包下依次建立include包,src包,CMakeLists.txt文件

  3. 准备一些测试文件

    1. include目录–存放.h头文件

      #ifndef _HEAD_H
      #define _HEAD_H
      // 加法
      int add(int a, int b);
      // 减法
      int subtract(int a, int b);
      // 乘法
      int multiply(int a, int b);
      // 除法
      double divide(int a, int b);
      #endif
      
    2. src目录–存放.cpp文件

      #include <iostream>
      #include "../include/head.h"using namespace std;int add(int a,int b){return a+b;
      }#include <iostream>
      #include "../include/head.h"using namespace std;double divide(int a, int b) { return a / b; }#include <iostream>
      #include "../include/head.h"using namespace std;int main() {int a = 20;int b = 12;printf("a = %d, b = %d\n", a, b);printf("a + b = %d\n", add(a, b));printf("a - b = %d\n", subtract(a, b));printf("a * b = %d\n", multiply(a, b));printf("a / b = %f\n", divide(a, b));return 0;
      }#include <iostream>
      #include "../include/head.h"using namespace std;int multiply(int a, int b) { return a * b; }#include <iostream>
      #include "../include/head.h"using namespace std;int subtract(int a, int b) { return a - b; }    
      
  4. 编写CMakeLists.txt

    cmake_minimum_required(VERSION 3.5.0)
    project(demo1)
    # 添加头文件搜索路径,包括当前目录和 include 子目录
    include_directories(${CMAKE_CURRENT_SOURCE_DIR}
    ${CMAKE_CURRENT_SOURCE_DIR}/include)
    # 收集 src 目录下所有的 .cpp 文件,存储到 SRC_LIST 变量中
    file(GLOB SRC_LIST ${CMAKE_CURRENT_SOURCE_DIR}/src/*.cpp)
    # 添加库文件搜索路径
    link_directories(${CMAKE_CURRENT_SOURCE_DIR}/lib)
    # 使用收集到的源文件创建一个名为 calc 的共享库
    add_library(calc SHARED ${SRC_LIST})
    

第三步-在ets文件中运行自己的demo接口

在上面,我们已经写好了自己的demo接口,下面,就去看如何运行这个demo的接口

  1. 找到napi_init.cpp文件

    1. image-20241126105355420

    2. 文件修改如下

      #include "napi/native_api.h"
      #include "demo/include/head.h" // demo头文件
      static napi_value Add(napi_env env, napi_callback_info info) {size_t argc = 2;napi_value args[2] = {nullptr};napi_get_cb_info(env, info, &argc, args, nullptr, nullptr);napi_valuetype valuetype0;napi_typeof(env, args[0], &valuetype0);napi_valuetype valuetype1;napi_typeof(env, args[1], &valuetype1);double value0;napi_get_value_double(env, args[0], &value0);double value1;napi_get_value_double(env, args[1], &value1);napi_value sum;napi_create_double(env, add(value0, value1), &sum);return sum;
      }
      // demo接口
      static napi_value NAPI_Global_sub(napi_env env, napi_callback_info info) {// TODO: implements the code;// 声明接受两个参数size_t argc = 2;napi_value args[2] = {nullptr}; // 用在存放JS对象在内存中的位置  类似于*void// testNapi.sub(2, 3)napi_get_cb_info(env, info, &argc, args, nullptr, nullptr);// get的方法都是用来把js类型转换成C++数据类型double value0;napi_get_value_double(env, args[0], &value0);double value1;napi_get_value_double(env, args[1], &value1);// value0 + value1 这里是C++里面的类型// create方法都是用来创建JS数据类型napi_value sub;napi_create_double(env, subtract(value0, value1), &sub);return sub;
      }
      EXTERN_C_START
      static napi_value Init(napi_env env, napi_value exports) {napi_property_descriptor desc[] = {{"add", nullptr, Add, nullptr, nullptr, nullptr, napi_default, nullptr},{"sub", nullptr, NAPI_Global_sub, nullptr, nullptr, nullptr, napi_default, nullptr}}; // 定义导出的demo函数napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);return exports;
      }
      EXTERN_C_ENDstatic napi_module demoModule = {.nm_version = 1,.nm_flags = 0,.nm_filename = nullptr,.nm_register_func = Init,.nm_modname = "entry",.nm_priv = ((void *)0),.reserved = {0},
      };extern "C" __attribute__((constructor)) void RegisterEntryModule(void) { napi_module_register(&demoModule); }
      
    3. 找到与demo同级目录下的CMakeLists.txt文件

      1. image-20241126105626623

      2. 添加demo子目录到构建系统,并连接demo生成的库文件calc

        # the minimum version of CMake.
        cmake_minimum_required(VERSION 3.5.0)
        project(NativeDemo)# 设置变量 NATIVERENDER_ROOT_PATH 为当前源代码目录的路径
        set(NATIVERENDER_ROOT_PATH ${CMAKE_CURRENT_SOURCE_DIR})if(DEFINED PACKAGE_FIND_FILE)include(${PACKAGE_FIND_FILE})
        endif()include_directories(${NATIVERENDER_ROOT_PATH}${NATIVERENDER_ROOT_PATH}/include)# 创建一个名为 entry 的共享库,源文件是 napi_init.cpp
        add_library(entry SHARED napi_init.cpp)
        # 添加 demo 子目录到构建系统
        add_subdirectory(demo)
        # 将 libace_napi.z.so 和 calc 库链接到 entry 库
        target_link_libraries(entry PUBLIC libace_napi.z.so calc)
        
    4. 接下来修改,暴露出的接口Index.d.ts文件

      1. image-20241126105907878

      2. 添加我们在napi_init.cpp中添加的接口(演示的话,为了方便只添加一个)

        export const add: (a: number, b: number) => number;
        export const sub: (a: number, b: number) => number;
        
    5. 大家可以尝试运行一下了–以下是成功运行情况

image-20241126110943133

  1. 调用

    import { hilog } from '@kit.PerformanceAnalysisKit';
    import DemoNapi from 'libentry.so'; // 包名自定义,没有影响@Entry
    @Component
    struct Index {@State a:number = 0@State b:number = 0@State result1:number = 0@State result2:number = 0build() {Column({space:10}) {Row(){Text('NAPI初体验-四则运算器').textAlign(TextAlign.Center).fontSize(25)}.width("100%").justifyContent(FlexAlign.Center)Row({space:10}){TextInput({placeholder:'请输入第一个数'}).onChange((value)=>{this.a = parseInt(value)}).type(InputType.Number).width(100)TextInput({placeholder:'请输入第二个数'}).onChange((value)=>{this.b = parseInt(value)}).type(InputType.Number).width(100)}.width('100%').justifyContent(FlexAlign.Center)Button('计算').onClick(()=>{this.result1 = DemoNapi.add(this.a,this.b)this.result2 = DemoNapi.sub(this.a,this.b)hilog.info(0x0000, 'testTag', 'Test NAPI 2 + 3 = %{public}d', DemoNapi.add(2, 3));hilog.info(0x0000, 'testTag', 'Test NAPI 2 - 3 = %{public}d', DemoNapi.sub(2, 3));})Text(`加法结果为:${this.result1}`).fontSize(30).fontWeight(FontWeight.Bold)Text(`减法结果为:${this.result2}`).fontSize(30).fontWeight(FontWeight.Bold)}.width('100%').height('100%')}
    }
    

总结

以上,大家就可以简单的使用Native了,关于CMakeLists.txt的话,建议大家去记住一些常用的就行了,对于同一效果的命令有好几条,记住自己顺眼的一条就行

http://www.yayakq.cn/news/188107/

相关文章:

  • 网站的建设与运营专业水果商城网站制作多少钱
  • 网站承建建筑工程造价信息网
  • 邹城网站定制室内效果图用什么软件做最好
  • 排名好的昆明网站建设wordpress用户前台投稿
  • 网站手机自动跳转宁波高新区做网站的公司
  • 什么是vi设计?广东seo网站设计营销工具
  • 建e网室内设计网 模型昆明网站搜索引擎优化
  • 网站建设技术中心锦州电脑网站建设
  • 郓城微信网站建设郑州中原区建设局网站
  • 公司网站建设 公司简介怎么写新乡市做网站
  • 可以去非菲律宾做游戏网站吗企业网站手机端跳转设置
  • 盛成广告传媒做网站的小型企业的网站建设论文
  • dede网站地图样式修改x wordpress theme
  • 学院实验室建设网站的好处做旅行社网站
  • 新乡网站建设联系方式怎么把电脑网站做服务器吗
  • 成品网站1688网页网站建设与网站开发
  • 制作一个网站平台需要多少钱wordpress调用支付宝
  • 企业网站个人备案wordpress首页如何增加模块
  • 视频上传网站源码android开发工具有哪些
  • 河南代做网站网站营销的重要价值
  • 网站维护电话红色旅游网站页面建设
  • 猪八戒网可以做网站吗饿了吗网站建设思路
  • 杭州市建设局网站wordpress返回上一个页面
  • 网站正在建设中 免费网站 名词解释
  • 做网站用什么浏览器园林绿化效果图制作
  • 做家居的网站特价锦州网站建设
  • 找素材的网站杭州网站模板建站
  • wordpress制作大型网站网站建设合优
  • 常见的网站开发工具个人学做网站
  • 做艺术品的网站网站建设大致分哪几块