开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

楼主: Behavior
收起左侧

[易源码分享] 32位v8引擎优化多线程互斥竞争版

[复制链接]
结帖率:100% (6/6)
 楼主| 发表于 2026-3-3 21:02:38 | 显示全部楼层   安徽省滁州市
不苦小和尚 发表于 2026-3-3 19:33
javascript ,我想获取console.log打印的值,你这个获取不到,RSV8可以

const ffi = require('ffi-napi');

// 1. 同样先定义 DLL
const hcEngine = ffi.Library('Hc_Engine', {
    'SetJSEx': ['string', ['string', 'string', 'string']]
});

const jsCode = `
    function Chengine2(val) { return 'Hello World! ' + val + ' (from DLL)'; }
`;

// --- 方案 A:使用标准的回调函数 (Async Callback) ---
console.log("开始异步请求 (Callback)...");
hcEngine.SetJSEx.async(jsCode, "Chengine2", "你好", (err, res) => {
    if (err) throw err;
    console.log("回调结果:", res);
});
console.log("我是非阻塞的,我会先显示!");


// --- 方案 B:封装成 Promise (推荐 async/await) ---
function setJSExAsync(code, func, args) {
    return new Promise((resolve, reject) => {
        hcEngine.SetJSEx.async(code, func, args, (err, res) => {
            if (err) return reject(err);
            resolve(res);
        });
    });
}

async function run() {
    try {
        console.log("等待 DLL 返回...");
        const result = await setJSExAsync(jsCode, "Chengine2", "异步参数");
        console.log("Promise 结果:", result);
    } catch (e) {
        console.error("出错:", e);
    }
}

run();    C:\Users\45646\Desktop\111>node nc.js
开始异步请求 (Callback)...
我是非阻塞的,我会先显示!
等待 DLL 返回...
回调结果: Hello World! ��� (from DLL)
Promise 结果: Hello World! �첽���� (from DLL)
回复 支持 反对

使用道具 举报

结帖率:100% (6/6)

签到天数: 18 天

 楼主| 发表于 2026-3-3 19:35:04 | 显示全部楼层   安徽省滁州市
不苦小和尚 发表于 2026-3-3 19:33
javascript ,我想获取console.log打印的值,你这个获取不到,RSV8可以

认真的? 都用JavaScript  不用node?
回复 支持 反对

使用道具 举报

结帖率:60% (15/25)

签到天数: 18 天

发表于 2026-3-3 19:33:56 | 显示全部楼层   江苏省苏州市
Behavior 发表于 2026-3-3 19:31
停。。。大哥用啥语言? 异步?

javascript ,我想获取console.log打印的值,你这个获取不到,RSV8可以
回复 支持 反对

使用道具 举报

结帖率:100% (6/6)

签到天数: 18 天

 楼主| 发表于 2026-3-3 19:31:14 | 显示全部楼层   安徽省滁州市
不苦小和尚 发表于 2026-3-3 19:30
怎么获取里面console.log打印的内容呢

停。。。大哥用啥语言? 异步?
回复 支持 反对

使用道具 举报

结帖率:60% (15/25)

签到天数: 18 天

发表于 2026-3-3 19:30:00 | 显示全部楼层   江苏省苏州市

怎么获取里面console.log打印的内容呢
回复 支持 反对

使用道具 举报

结帖率:100% (6/6)

签到天数: 18 天

 楼主| 发表于 2026-3-3 19:25:32 | 显示全部楼层   安徽省滁州市
不苦小和尚 发表于 2026-3-3 17:58
速度挺快,请问怎么支持异步

直接的异步调
回复 支持 反对

使用道具 举报

结帖率:100% (6/6)

签到天数: 18 天

 楼主| 发表于 2026-3-3 19:16:47 | 显示全部楼层   安徽省滁州市
不苦小和尚 发表于 2026-3-3 17:58
速度挺快,请问怎么支持异步

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace AsynDemo
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        [DllImport("Hc_Engine.dll",CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
        private static extern string SetJSEx(string jscode,string func,string args);
        private void Form1_Load(object sender, EventArgs e)
        {
            
        }

        private async void  button1_Click(object sender, EventArgs e)
        {
            Console.WriteLine("主线程开始,ID:" + Thread.CurrentThread.ManagedThreadId);
            try
            {
                // 3. 异步调用 DLL 方法(核心:用 Task.Run 包装同步 DLL 调用)
                var task1 = CallDllAsync(10);
                var task2 = CallDllAsync(20);

                // 4. 等待所有异步调用完成(非阻塞主线程)
                var results = await Task.WhenAll(task1, task2);

                // 输出结果
                Console.WriteLine($"调用结果1:{results[0]},调用结果2:{results[1]}");
            }
            catch (Exception ex)
            {
                Console.WriteLine($"调用出错:{ex.Message}");
            }

            Console.WriteLine("主线程结束,ID:" + Thread.CurrentThread.ManagedThreadId);
            Console.ReadLine();
        }
        /// <summary>
        /// 异步调用 DLL 方法的封装
        /// </summary>
        /// <param name="input">传入 DLL 的参数</param>
        /// <param name="cancellationToken">取消令牌(可选)</param>
        /// <returns>DLL 方法的返回值</returns>
        private static async Task<string> CallDllAsync(int input, CancellationToken cancellationToken = default)
        {
            // 关键:将同步的 DLL 调用放到 Task.Run 中,交给线程池执行
            return await Task.Run(() =>
            {
                Console.WriteLine($"DLL 调用执行线程:{Thread.CurrentThread.ManagedThreadId}");

                // 检查是否取消(可选,提升可控性)
                cancellationToken.ThrowIfCancellationRequested();
                string jscode = "function Chengine() {\r\n    return 'Hello World! 你好Chengine!';\r\n}\r\nfunction Chengine2(val) {\r\n    return 'Hello World! ' + val + ' Chengine2!';\r\n}\r\nfunction add(a,b) {\r\n    return parseInt(a)+parseInt(b);\r\n}\r\n";
                // 调用 DLL 方法(核心逻辑)
                var result = SetJSEx(jscode, "Chengine2","你好");

                // 托管 DLL 调用示例:
                // var result = ManagedDllLongRunningTask(input);

                return result;
            }, cancellationToken);
        }
    }
}
C# 异步
回复 支持 反对

使用道具 举报

签到天数: 13 天

发表于 2026-3-3 18:27:38 | 显示全部楼层   江西省抚州市
谢谢分享
回复 支持 反对

使用道具 举报

结帖率:60% (15/25)

签到天数: 18 天

发表于 2026-3-3 17:58:40 | 显示全部楼层   江苏省苏州市
速度挺快,请问怎么支持异步
回复 支持 反对

使用道具 举报

签到天数: 14 天

发表于 2026-3-3 17:50:57 | 显示全部楼层   广东省东莞市
谢谢分享
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备2025452707号) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表