05 H5程序测试方法和not found的问题

为了方便测试程序,可以把源程序放在pc上的nfs共享目录里, 编译后,板上可以挂载此共享目录,直接执行在pc上编译出来程序了.

// test.c

#include <stdio.h>

int main(void)
{
    printf("hello arm64\n");
    return 0;
}

如果用gcc编译出x86架构的程序,在板上执行会报下面的错误信息:

./a.out: line 1: syntax error: unexpected "("
// 可以用file命令来查看程序的架构及位数.

我们需要使用aarch64-linux-gnu-gcc编译器编译板上执行的程序, 但执行时还是出现错误信息:

-/bin/sh: ./a.out: not found

//出现这个问题其实就是因为系统里缺少所需的动态库引起的.
//如果交叉编译器有提供ldd命令,可以"ldd --root=文件系统的根路径  程序名" 查看具体缺少什么动态库.
//另一种选择可以用静态编译的方法"aarch64-linux-gnu-gcc test.c -static"


为了减少程序和文件系统的体积,还是需要使用动态库。而缺的动态库应先在交叉编译器所在的目录里查找,找不到的话还得把下载所需的库源码再交叉编译来使用.

//先复制交叉编译器里的lib目录到pc的nfs共享目录里,在交叉编译器目录应先查看lib名的目录, lib目录里应当有ld-xxxx.so动态库.
cp gcc-linaro-6.3.1/aarch64-linux-gnu/libc/lib  /disk3/h5fs  -rf

//板上挂载pc的nfs共享目录后,把整个lib目录复制到/根目录. 板上命令:
mount 192.168.22.11:/disk3/h5fs /mnt -o nolock,tcp
cp /mnt/lib  / -rf
rm /lib/debug      //删除调试时使用的库
rm /lib/*.a  -f      //删除静态库

在pc再编译需要使用动态库的程序:

aarch64-linux-gnu-gcc test.c 

file a.out
a.out: ELF 64-bit LSB executable, ARM aarch64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 3.7.0 ...
//通过file命令可以看出是arm64上执行程序,需要使用动态库的.
//前面的动态库准备好后,在板上执行就不会报"not found"的问题了
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
H5 页面嵌入小程序中,可以通过使用小程序的 WebView 组件实现。具体步骤如下: 1. 在小程序的 wxml 文件中添加 WebView 组件,例如: ```html <web-view src="https://www.example.com"></web-view> ``` 2. 在小程序的 js 文件中对 WebView 进行配置,例如: ```javascript Page({ onReady: function() { this.selectComponent('#web-view').onMessage((event) => { console.log('received message from H5:', event.detail.data) this.setData({messageFromH5: event.detail.data}) }) } }) ``` 其中,onReady 方法是页面生命周期函数,在页面初次渲染完成时触发。selectComponent 方法用于获取 WebView 组件的实例,然后调用 onMessage 方法监听 H5 页面发送的消息。 3. 在 H5 页面中发送消息到小程序,例如: ```javascript const message = {name: 'Tom', age: 18} window.parent.postMessage(message, '*') ``` 其中,window.parent.postMessage 方法用于向 WebView 的父级窗口发送消息,'*' 表示接收方可以是任何窗口。 4. 在小程序中接收 H5 页面发送的消息,并进行处理。在上面的 js 文件中,我们已经定义了 onMessage 方法用于监听消息,可以在该方法中获取 H5 页面发送的消息并进行处理,例如: ```javascript Page({ onReady: function() { this.selectComponent('#web-view').onMessage((event) => { console.log('received message from H5:', event.detail.data) this.setData({messageFromH5: event.detail.data}) }) } }) ``` 在该方法中,我们通过 event.detail.data 获取 H5 页面发送的消息,并通过 setData 方法更新页面数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值