【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计

【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计

本地演示视频(手机版貌似看不到,在codelab里也没法直接看到,只有网页版的项目预览可以看到)

       

视频传送门

gitee仓库

一、项目背景

社区是城市的关键组成部分,社区治理是围绕社区场景下的人、地、物、情、事的管理与服务。

随着城市化的快速推进及人口流动的快速增加,传统社区治理在人员出入管控、安防巡逻、车辆停放管理等典型场景下都面临着人力不足、效率低下、响应不及时等诸多难题。而人工智能技术代替人力,实现人、车、事的精准治理,大幅降低人力、物质、时间等成本,以最低成本发挥最强大的管理效能,有效推动城市治理向更“数字化、自动化、智慧化”的方向演进。

传统社区视频监控80%都依靠人工实现,随着摄像头在社区中的大规模普及,日超千兆的视频图像数据、人员信息的日渐繁杂已远超人工的负荷。

1.1 技术实现

为解决以上问题,我们灵活应用飞桨行人分析PP-Human中的行人检测和属性分析模型,实时识别行人的性别、年龄、衣着打扮等26种属性并记录统计。

其中,属性分析包含26种不同属性:

- 性别:男、女- 年龄:小于18、18-60、大于60- 朝向:朝前、朝后、侧面- 配饰:眼镜、帽子、无- 正面持物:是、否- 包:双肩包、dan肩包、shou提包- 上衣风格:带条纹、带logo、带格子、拼接风格- 下装风格:带条纹、带图案- 短袖上衣:是、否- 长袖上衣:是、否- 长外套:是、否- 长裤:是、否- 短裤:是、否- 短裙&裙子:是、否- 穿靴:是、否

       【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计 - 创想鸟
街道人员属性识别

PP-Human是基于飞桨深度学习框架的业界首个开源的实时行人分析工具,具有功能丰富,应用广泛和部署高效三大优势。PP-Human 支持图片/单镜头视频/多镜头视频多种输入方式,功能覆盖多目标跟踪、属性识别和行为分析。能够广泛应用于智慧交通、智慧社区、工业巡检等领域。支持服务器端部署及TensorRT加速,T4服务器上可达到实时。

【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计 - 创想鸟        

详细文档可参考:https://github.com/PaddlePaddle/PaddleDetection/tree/develop/deploy/pphuman

1.2 技术方案

在本项目中,我们基于PP-HUMAN实现一套行人客流和人员属性统计系统,可以通过数据库查询,有可视化统计页面。

【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计 - 创想鸟        

1.2.1.识别:使用PP-HUMAN的行人属性检测方案,对于视频流的行人属性识别需要用到MOT(多目标跟踪)模型和ATTR(行人属性识别)模型,由MOT模型识别并跟踪行人,由ATTR模型进行多分类识别行人属性。

1.2.2.后端:

Flask是一个轻量级的可定制框架,使用Python语言编写,较其他同类型框架更为灵活、轻便、安全且容易上手。它可以很好地结合MVC模式进行开发,开发人员分工合作,小型团队在短时间内就可以完成功能丰富的中小型网站或Web服务的实现。另外,Flask还有很强的定制性,用户可以根据自己的需求来添加相应的功能,在保持核心功能简单的同时实现功能的丰富与扩展,其强大的插件库可以让用户实现个性化的网站定制,开发出功能强大的网站。(百度百科) 总而言之flask用python编写,对于技术栈还不够全面和足够熟练的新手小队实现起来方便一些。

1.2.3.前端:

1.2.3.1.Ajax:

Asynchronous Javascript And XML(异步JavaScript和XML)是一种web数据交互方式,使用Ajax技术网页应用能够快速地将增量更新呈现在用户界面上,而不需要重载(刷新)整个页面,这使得程序能够更快地回应用户的操作。用来实时刷新数据。

1.2.3.2.ECharts:

ECharts是一款基于JavaScript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。

1.2.4.数据库:

SQLite是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它的设计目标是嵌入式的,而且已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。技术成熟、资源占用少并且可以直接在python中import直接使用,有SQL知识基础的小伙伴上手很快。

1.3 数据集介绍

PETA (PEdesTrian Attribute)数据集包含了8705个行人,共19000张图像(分辨率跨度范围大,从17×39到169×365的大小都有)。每个行人标注了61个二值的和4个多类别的属性。

二、配置运行环境

环境要求: PaddleDetection版本 >= release/2.4 或 develop

通过以下命令获取PaddleDetection套件代码

git clone https://gitee.com/paddlepaddle/PaddleDetection.git

       在这个项目中,我们预先准备了项目代码的压缩包,可以通过直接解压代替git clone的过程。In [ ]

%cd /home/aistudio/# 克隆PaddleDetection仓库# !git clone https://gitee.com/paddlepaddle/PaddleDetection.git!unzip PaddleDetection.zip

   In [ ]

# 安装其他依赖%cd PaddleDetection!pip install -r requirements.txt

   In [ ]

# 可选,安装paddledet!python setup.py install

   

更换为修改过的pphuman文件夹

该zip中包含flask后端代码app.py、前端数据可视化代码index.html、前端js库以及整合适配后的推理相关代码。

In [ ]

#更换为修改过的pphuman文件夹!rm -rf /home/aistudio/PaddleDetection/deploy/pphuman!unzip /home/aistudio/pphuman.zip -d /home/aistudio/PaddleDetection/deploy/pphuman

   

三、如何构建模型

PPHuman中实现整个行人分析的工具和部署流程,包括检测、多目标跟踪、跨镜头跟踪、关键点检测、行为识别等多个模块。在这一部分中, 我们以关键点模型为例,展示将dark_hrnet_w32_256x192这一个模型从训练到导出至部署可用的模型的全流程。详细细节可以参考我们的Github文档。

3.1 模型训练

训练模型主要包括准备训练数据以及启动训练命令,可以按照下面的命令执行。

这里由于完整COCO数据集的训练耗时较长,我们准备了一个样例数据集,供执行流程参考使用。

In [ ]

# 准备我们的样例训练数据%cd /home/aistudio/PaddleDetection/!wget https://bj.bcebos.com/v1/paddledet/data/keypoint/coco_val_person_mini.tar!tar -xf coco_val_person_mini.tar -C ./dataset/!mv ./dataset/coco_val_person_mini/* ./dataset/coco!cp ./dataset/coco/annotations/instances_train2017.json ./dataset/coco/annotations/person_keypoints_train2017.json!cp ./dataset/coco/annotations/instances_val2017.json ./dataset/coco/annotations/person_keypoints_val2017.json

   In [ ]

#训练模型, 如果是CPU环境,请加上 -o use_gpu=False%cd /home/aistudio/PaddleDetection/!python tools/train.py -c configs/keypoint/hrnet/dark_hrnet_w32_256x192.yml

   

完成训练后,我们的模型默认保存在output/dark_hrnet_w32_256x192/。

3.2 模型评估

在训练模型以后,我们可以通过运行评估命令来得到模型的精度,以确认训练的效果。评估可以参考以下命令执行。

这里使用了我们已经训练好的模型。如希望使用自己训练的模型,请对应将weights=后的值更改为对应模型.pdparams文件的存储路径。

In [ ]

!python tools/eval.py -c configs/keypoint/hrnet/dark_hrnet_w32_256x192.yml   -o weights=https://paddledet.bj.bcebos.com/models/keypoint/dark_hrnet_w32_256x192.pdparams

   

3.3 模型导出

.pdparams只包括了模型的参数数据,实际部署还需要执行导出步骤。导出步骤可以参考下面列举的步骤:

注意,这里使用了我们已经训练好的模型。如希望使用自己训练的模型,请对应将weights=后的值更改为对应模型.pdparams文件的存储路径。如果没有指定–output_dir,那么导出的模型将默认存储在output_inference/路径下。

In [ ]

!python tools/export_model.py -c configs/keypoint/hrnet/dark_hrnet_w32_256x192.yml   --output_dir inference_models/   -o weights=https://paddledet.bj.bcebos.com/models/keypoint/dark_hrnet_w32_256x192.pdparams

   

至此,我们就完成了关键点模型的从训练到导出的过程。可以用于PPhuman的实际部署中了。

参考以上步骤,在我们PaddleDetection套件中,除了关键点检测以外,同样可以实现检测、跟踪模型的训练、评估及导出使用。

3.4 行为识别模型

行为识别模型从训练到到导出使用的全流程介绍及对应源码,细节请参考 PP-Human 行为识别模型。

如何自定义训练行为类型

行为识别模型本质上是一个分类模型,如果用户希望训练自定义的行为类型,可以参照以下步骤执行:

数据准备按照期望实现的自定义行为准备对应的动作视频或图片序列片段使用关键点模型或人工标注的方式,将动作片段转化为关键点序列在训练/测试数据中,正确设置动作的类别配置文件修改在配置文件中,修改num_classes,通常为支持的动作类型数目 + 1可选的,当动作的类型较多时,top1可能不能完全反应模型准确率,此时可以修改评估时的top_k项来额外评估模型的准确率(例如top5)。

3.5 下载本项目需要的模型

在这一步中,逐一下载上述我们事先为大家准备的各任务的导出模型,可以直接使用。如果您希望在自己的场景上进一步迭代优化,也可以参考前述如何构建模型部分,完成对应模块模型的训练到导出流程,得到部署需要的导出模型。

In [ ]

#下载检测模型!wget https://bj.bcebos.com/v1/paddledet/models/pipeline/mot_ppyoloe_l_36e_pipeline.zip#下载属性模型!wget https://bj.bcebos.com/v1/paddledet/models/pipeline/strongbaseline_r50_30e_pa100k.zip#下载关键点模型#!wget https://bj.bcebos.com/v1/paddledet/models/pipeline/dark_hrnet_w32_256x192.zip#下载行为识别模型#!wget https://bj.bcebos.com/v1/paddledet/models/pipeline/STGCN.zip

   In [ ]

#解压至./output_inference文件夹!unzip -d output_inference mot_ppyoloe_l_36e_pipeline.zip!unzip -d output_inference strongbaseline_r50_30e_pa100k.zip#!unzip -d output_inference dark_hrnet_w32_256x192.zip#!unzip -d output_inference STGCN.zip

   

3.6 配置文件说明

PP-Human相关配置位于deploy/pphuman/config/infer_cfg.yml中,存放模型路径,完成不同功能需要设置不同的任务类型。

功能及任务类型对应表单如下:

输入类型 功能 任务类型 配置项

图片属性识别目标检测 属性识别DET ATTR单镜头视频属性识别多目标跟踪 属性识别MOT ATTR单镜头视频行为识别多目标跟踪 关键点检测 行为识别MOT KPT ACTION

本项目应用到的是:

社区人员信息留存:单镜头视频或图片输入的属性识别

3.7 执行模型预测

我们以一个视频文件来展示一下属性识别的实际使用方式。

在预测命令中,模型预测参数选择分为两部分:

功能选择:将对应参数设置为True属性识别:enable_attr行为识别:enable_action模型路径修改:设置对应任务(DET, MOT, ATTR, KPT, ACTION)的模型路径,包括两种方式修改配置文件中对应模型的路径直接在命令行中指定各模型的路径

例如,我们可以增加下列命令,指定检测模型和属性识别模型的路径:

--model_dir det=output_inference/mot_ppyoloe_l_36e_pipeline/ attr=output_inference/strongbaseline_r50_30e_pa100k/

       

行人信息留存

支持开发者根据具体情况选择视频或单帧图片输入进行属性识别。

注意事项:

–video_file or –image_dir后是输入视频or图片的路径,开发者可上传自己的数据集进行尝试In [ ]

#补充安装相关库(不然运行下面的)视频行人属性识别指令会报错缺库!pip install motmetrics!pip install lap

   In [ ]

#视频行人属性识别#pipeline.py里的attr_res是视野里识别出的标签#处理结果可在/home/aistudio/PaddleDetection/output/ 中查看!python deploy/pphuman/pipeline.py     --config deploy/pphuman/config/infer_cfg.yml     --model_dir mot=output_inference/mot_ppyoloe_l_36e_pipeline/ attr=output_inference/strongbaseline_r50_30e_pa100k/     --video_file=/home/aistudio/属性.mp4     --enable_attr=True     --device=gpu

   

预测效果

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计 - 创想鸟        

In [ ]

#图片行人属性识别#处理结果可在/home/aistudio/PaddleDetection/output/ 中查看!python deploy/pphuman/pipeline.py     --config deploy/pphuman/config/infer_cfg.yml     --model_dir det=output_inference/mot_ppyoloe_l_36e_pipeline/ attr=output_inference/strongbaseline_r50_30e_pa100k/     --image_dir=/home/aistudio/photodemo     --enable_attr=True     --device=gpu

   

使用TensorRT加速预测

NVIDIA TensorRT是一个高性能的深度学习预测库。PP-Human同样支持了使用TensorRT加速模型的预测,并且整个步骤十分简单快速。您可以参考以下步骤实现:

安装适配TensorRT的Paddle, 通过下载链接直接下载对应环境的Paddle whl包进行安装。或是参照指导文档使用docker或自编译方式准备适配TensorRT的Paddle环境。在上述两个场景的Python预测命令中,直接增加–run_mode=trt_fp16即可。

四、部署踩坑指南:

(记录了一些踩的坑,菜菜遇到坑只会搜索)

1.: cannot connect to X server !

原因:在BML CodeLab中没有允许实时显示可视化视频的权限,故在BML CodeLab中只能注释掉PaddleDetection/deploy/pphuman/pipeline.py里的(已经注释掉,本地使用建议解开注释)

#在BML CodeLab中无法实时显示,故注释下面三行cv2.imshow('PPHuman', im)if cv2.waitKey(1) & 0xFF == ord('q'):    break

       

ctrl+f搜索,将两个位置的上面三行注释后再次运行即可运行对视频的检测。(本地的打开显示预测处理结果是没有问题的)

2.重新annaconda配置环境

3.遇到报错ERROR: Failed building wheel for pycocotools

4.发现系统没有cudnn,配置教程

5.cudnn库报错缺dll文件

6.mysql主键唯一键重复插入解决方法

7.视频流传输

五、运行后端服务

In [ ]

! python /home/aistudio/PaddleDetection/deploy/pphuman/app.py# 这个在BML CodeLab目前同样无法查看,后端起的服务在环境本地,从我们的浏览器CodeLab访问不了,部署到本地是可以看到的。

   

本地服务效果如图【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计 - 创想鸟【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计 - 创想鸟        

以上就是【校园AI Day-AI workshop】基于PP-HUMAN的客流及属性统计的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/53960.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 13:01:56
下一篇 2025年11月9日 13:02:28

相关推荐

  • Go语言中结构体声明:命名类型与匿名类型的区别与选择

    Go语言中,结构体声明有两种主要方式:使用type关键字定义命名结构体类型,以及直接通过var或:=声明匿名结构体。本文将深入探讨这两种声明方式的本质区别,包括类型重用性、可见性及其在实际编程中的应用场景,帮助开发者理解何时选择命名结构体,何时使用匿名结构体,以编写更清晰、更可维护的代码。 在go语…

    2025年12月15日
    000
  • 深入理解Go语言结构体:type关键字与var关键字的声明差异

    本文深入探讨Go语言中结构体的两种常见声明方式:使用type关键字定义命名结构体,以及通过var关键字直接声明匿名结构体变量。文章将详细阐述这两种方式在类型复用、可见性及实际应用场景上的核心差异,并通过代码示例帮助读者理解如何根据需求选择合适的结构体声明策略,以提升代码的结构性与可维护性。 在Go语…

    2025年12月15日
    000
  • Go语言中命名结构体与匿名结构体的声明与使用解析

    本文深入探讨Go语言中两种声明结构体的方式:使用type关键字定义命名结构体和直接使用var或:=声明匿名结构体。我们将详细分析它们在类型复用、方法定义以及适用场景上的关键差异,并通过代码示例阐明各自的优势与局限性,帮助开发者根据实际需求选择合适的结构体声明方式。 在go语言中,结构体(struct…

    2025年12月15日
    000
  • Go语言中命名结构体与匿名结构体的声明与使用

    本文深入探讨Go语言中命名结构体与匿名结构体声明方式的异同。命名结构体通过type关键字定义,提供类型复用性与清晰的类型识别,适用于复杂或需共享的数据模型。匿名结构体则通过var或直接初始化声明,其类型在声明时即确定且无法通过名称复用,适用于临时、一次性的数据封装,理解两者区别有助于编写更高效、可维…

    2025年12月15日
    000
  • Go语言:利用反射机制校验interface{}参数是否为指针

    本文探讨了在Go语言中,当函数参数类型为interface{}时,如何强制或校验传入的实参必须是指针类型。由于*interface{}并非有效解决方案,文章详细介绍了如何利用Go的reflect包在运行时进行类型检查,以确保参数是指针,并提供了相应的代码示例和注意事项,帮助开发者编写更健谨的代码。 …

    2025年12月15日
    000
  • Go语言:使用反射机制强制 interface{} 函数参数为指针类型

    在Go语言中,当函数参数类型为 interface{} 时,编译器无法强制要求传入的是值类型还是指针类型。本文将详细介绍如何利用Go的 reflect 包,在运行时检查 interface{} 参数的底层类型是否为指针,从而实现对函数参数的类型约束,确保传入的是指向具体值的指针,同时讨论了 unsa…

    2025年12月15日
    000
  • 为 Geany 添加 Go 语言支持:语法高亮与编译配置教程

    本文旨在指导您如何在 Geany 编辑器中配置 Go 语言支持,包括语法高亮和编译选项。通过简单的步骤,您将能够充分利用 Geany 的强大功能,提升 Go 语言的开发效率。本文将详细介绍配置过程,并提供必要的示例文件和注意事项。 1. 下载并安装 Geany 首先,确保您已经安装了 Geany 编…

    2025年12月15日
    000
  • 在Geany中配置Go语言开发环境

    本教程旨在指导用户如何在Geany集成开发环境中配置Go语言支持,实现代码语法高亮、编译、构建和运行功能。通过修改Geany的配置文件,您可以为Go语言项目提供一个高效且定制化的开发环境,从而提升开发效率。 引言 geany是一款轻量级但功能强大的集成开发环境,以其快速启动和灵活配置而受到许多开发者…

    2025年12月15日
    000
  • 使用 Go 执行外部命令:exec.Run 的正确用法

    本文旨在帮助开发者理解并正确使用 Go 语言中的 exec.Run 函数执行外部命令。通过分析常见错误和提供正确示例,帮助读者避免陷阱,成功实现外部命令的调用和控制。 Go 语言的 exec 包提供了执行外部命令的能力。然而,不当的使用可能导致程序行为异常甚至无法执行。本文将深入探讨 exec.Ru…

    2025年12月15日
    000
  • Geany 集成 Go 语言支持指南

    本文旨在提供在轻量级集成开发环境 Geany 中配置 Go 语言开发环境的详细指南。内容涵盖如何启用 Go 语言的语法高亮、配置编译和运行命令,以及利用 Geany 的项目管理功能,帮助开发者高效地在 Geany 中编写、调试和执行 Go 语言代码,从而提升开发效率。 1. 引言 Geany 是一款…

    2025年12月15日
    000
  • Go 语言中的函数类型与函数变量:实现类似“函数指针”的功能

    Go 语言不直接支持C语言风格的函数指针,但通过将函数视为一等公民,允许将函数赋值给变量。本文将详细介绍如何在 Go 中定义和使用函数类型,以及如何声明和操作函数变量,从而实现类似函数指针的功能,并提供代码示例和注意事项,帮助读者理解 Go 中函数处理的独特机制。 在 go 语言中,函数被视为一等公…

    2025年12月15日
    000
  • Geany Go 语言支持配置指南

    本教程旨在指导用户如何在 Geany 集成开发环境中配置 Go 语言支持。文章将详细阐述如何设置 Go 语言文件的语法高亮、配置编译和执行命令,以及优化开发流程。通过遵循这些步骤,Go 开发者可以有效地利用 Geany 的轻量级特性,构建一个高效、舒适的 Go 编程环境,提升代码编写与调试的效率。 …

    2025年12月15日
    000
  • 构建Go语言DOCX文件处理API:XML解析器核心功能指南

    本文旨在指导Go语言开发者构建DOCX文件处理API,重点介绍开发过程中XML解析器的关键功能。我们将深入探讨XML解析器必须具备的核心特性,以及在处理DOCX文件时,哪些XML标准和功能是至关重要的。通过本文,开发者可以构建一个高效、可靠的XML解析器,为DOCX文件处理提供坚实的基础。 在Go语…

    2025年12月15日
    000
  • 构建Go语言DOM XML解析器的关键要素

    本文旨在指导开发者构建一个基础的Go语言DOM XML解析器。针对处理DOCX文件这类特定场景,我们聚焦于核心功能,避免不必要的复杂性。文章将详细阐述XML解析器必须具备的关键特性,以及一些后续可能需要的扩展功能,助你打造一个高效、实用的XML处理工具。 构建一个DOM XML解析器,尤其是在Go语…

    2025年12月15日
    000
  • 构建Go语言DOM XML解析器:核心功能与注意事项

    本文旨在指导Go语言开发者构建一个基本的DOM XML解析器。我们将探讨实现XML解析器所需的核心功能,包括字符实体处理、编码处理、结构验证、CDATA处理以及错误报告机制。此外,还会提及一些后期可能需要添加的实用功能,例如命名空间处理和字符有效性检查,帮助开发者构建一个可靠且高效的XML处理工具。…

    2025年12月15日
    000
  • 构建高性能XMPP服务器:libxml2 vs Expat XML解析器选择指南

    本文旨在帮助开发者在构建高性能XMPP服务器时,选择合适的XML解析器。通过对比libxml2和Expat在性能和内存使用方面的表现,并结合实际应用场景,推荐使用libxml2的SAX解析器,同时提醒开发者关注平台可用性等其他重要因素。 在构建XMPP服务器时,XML解析是至关重要的环节。XMPP协…

    2025年12月15日
    000
  • 构建高性能XMPP服务器:libxml2与Expat XML解析器的选择

    在构建高性能XMPP服务器时,XML解析器的选择至关重要。XMPP协议基于XML,服务器需要处理大量的XML流,因此解析器的性能直接影响服务器的整体性能和资源消耗。libxml2 和 Expat 是两个常见的XML解析器,本文将对它们进行比较,并给出选择建议。 如上文摘要所述,在构建高性能XMPP服…

    2025年12月15日
    000
  • Go语言中的观察者模式实现

    本文将介绍如何在Go语言中实现观察者模式,利用Go语言的channel特性,我们可以轻松构建发布者-订阅者模型,实现对象间的事件通知。文章提供了代码示例,展示了如何创建发布者、订阅者,以及如何进行订阅和发布消息,并强调了使用channel进行并发处理的重要性。 观察者模式是一种行为设计模式,它定义了…

    2025年12月15日
    000
  • 初学者如何用Golang操作Redis 使用go-redis客户端库示例

    使用golang操作redis需掌握安装客户端、建立连接、执行基本命令及处理复杂数据结构。1. 安装go-redis库并导入;2. 使用redis.newclient配置连接参数并测试连通性;3. 通过set、get、del进行键值操作,注意处理redis.nil错误;4. 使用hset、hget等…

    2025年12月15日 好文分享
    000
  • Go语言中集成C/C++信号处理库的策略

    本文探讨了在Go语言中进行音频信号处理时,如何克服原生库缺失的挑战。针对Go语言缺乏成熟的信号处理包的现状,文章详细介绍了两种主要的解决方案:利用SWIG#%#$#%@%@%$#%$#%#%#$%@_20dc++e2c6fa909a5cd62526615fe2788a集成C++库,以及通过cgo手动…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信