草庐IT

native-sdk

全部标签

c++ - webrtc native 应用程序中的每个对等点是否需要单独的 rtc::Runnable 线程和 PeerConnectionFactory 对象?

我正在尝试使用WebRTCnativeAPIs创建native应用程序.对于第一个对等节点,我创建了一个rtc::Runnable对象,并在其Run方法中创建了PeerConnectionFactory对象。然后我从那个对象创建一个peerconnection对象并创建报价并继续设置本地和远程描述以及ICE配置等,一切顺利。现在我想了解我应该为同一进程中的第二个对等方做什么。我是否需要创建另一个rtc::Runnable线程,或者我是否可以重用它及其对等连接工厂对象来创建一个单独的对等连接对象?它可能在文档中的某处,但我找不到它。很明显,我需要为每个对等点建立一个单独的对等连接,并为每

Java native 接口(interface) - C++ 不等待 java 函数完成

我希望用java编写的StanfordCoreNLP的功能可以在C++中使用。为此,我使用了Javanative接口(interface)。我有一个Java对象,它以一种更容易从C++调用的方式包装了多个函数。但是,当我确实调用这些函数时,C++不会等待函数完成后再转到下一个函数。Java对象有一个我用于测试的Main函数,它调用所有适当的函数来进行测试。当只运行Java时,它工作得很好。注解等待设置完成(这确实需要一段时间),获取依赖项的函数等待注解函数完成。完全预期和正确的行为。当我开始从C++调用java函数时,问题就来了。部分java函数将运行,但它会在某些点退出并返回到C++

c++ - 在 Qt Creator 中使用 Windows SDK 7.1

我有一个我正在处理的个人项目,它需要MicrosoftSAPI5--文本到语音和语音识别。我已经构建了很多应用程序,但我决定切换并尝试学习Qt框架,因为它会使很多事情变得更加简单。项目无法构建,因为它无法从WindowsSDK中找到头文件。我不知道我哪里出错了。我已尽力编辑我的.pro文件。除了下面的内容,我还尝试了一个明确列出头文件的版本,但仍然找不到该文件。错误:sapi.h:没有那个文件或目录speech.h中包含:#include#include我的.pro文件:QT+=coreguiTARGET=QT_RiverTEMPLATE=appINCLUDEPATH+="C:\Pro

c# - 如何从 native C(++) DLL 调用 .NET (C#) 代码?

我有一个C#app.exe和一个C#my.dll。my.dll.NET项目链接到nativeC++DLL(mynat.dll)(外部CDLL接口(interface)),并且从C#调用C++DLL没有问题。(通过使用[DllImport("mynat.dll",CharSet=CharSet.Unicode,CallingConvention=CallingConvention.Cdecl)]属性。)我现在需要添加的是让C#dll提供一些C++代码可以调用的回调函数。理想情况下,mynat.dllC++代码将使用LoadLibrary("my.dll")来加载C#dll,然后使用Get

c++ - 托管 C++ dll 的加载程序锁定错误,静态链接到 native C++ 库

我有一个托管的c++dll,其中包含几个托管类,这些托管类依次调用库中的nativec++代码,我已静态链接到该dll。但是,如果我尝试在dll上运行RegAsm.exe,该工具会正确报告“我们没有注册任何类型”,但随后挂起。我很确定这是loaderlock问题,当RegAsm尝试加载它时我的dll挂起。我使用的是VisualStudio2008速成版。让我感到困惑的是,将native代码放入dll时一切正常,但从库中静态链接时却不行。我知道这篇文章类似于thisquestion但我的dll中没有没有DllMain,因此我没有从DllMain运行MSIL代码的风险。此外,遵循对单个文件

c++ - 在自定义 const native C++ 容器类上支持 "for each"

我想实现一个简单的nativeC++固定容量数组模板类,为了方便起见支持基于范围的“foreach”语法,开销最小。我在const实例上支持它时遇到问题。有了这个实现:templateclassList{public:List(){mSize=0;}constT*begin()const{returnmItems;}constT*end()const{returnmItems+mSize;}T*begin(){returnmItems;}T*end(){returnmItems+mSize;}private:size_tmSize;TmItems[Capacity];};和这种用法:c

c++ - Android 调试 native 代码

我正在使用ndk-r9,我正在努力让ndk-gdb为我工作。我已经启动了一个名为“LittlestAndroid”的小型Android应用程序,它对返回硬编码字符串的nativeC++方法进行了简单调用。该应用程序构建/安装/运行得很好。现在我正在重新调整应用程序的用途以了解ndk-gdb。我在list中设置了debuggable="true"。我在我的make中设置了这些环境变量:APP_OPTIM=debugLOCAL_CFLAGS:=-g我已经破解了$NDK_HOME/build/core/build-binary.mk文件,使用以下命令有条件地去除调试符号:$(LOCAL_IN

C++ LZMA SDK : Uncompress function for LZMA2 compressed file

我正在尝试创建一个解压缩LZAM2压缩数据的函数。我的灵感来自thistutorial这对LZMA非常有效,我尝试将其改编为LZMA2。我成功地为LZMA2创建了压缩函数,但我没有成功创建解压缩函数。这里是压缩函数:staticvoidCompress2Inc(std::vector&outBuf,conststd::vector&inBuf){CLzma2EncHandleenc=Lzma2Enc_Create(&SzAllocForLzma,&SzAllocForLzma2);assert(enc);CLzma2EncPropsprops;Lzma2EncProps_Init(&p

FPGA----Vivado SDK创建并使用静态链接库(C/C++代码移植)

1、在进行SoC开发时,PS端的C/C++代码可能涉及到核心算法需要移植操作,为此,本文讲述了如何将C/C++代码打包为.a文件供程序调用2、文章以我的程序为例,逐步讲述代码生成静态链接库并调用的方法。下面是我程序的目录结构,Util调用了Eigen矩阵运算库。load_circuit_from_case调用了xilffs(SD卡读取功能包)以及Util。circuit_sim调用了load_circuit_from_case。emtp_start调用了circuit_sim。default_main调用了emtp_start以及output_data。其中,load_circuit_from

c++ - 将函数指针实现替换为 std::function 以在 PlayFab SDK 中使用 lambda

我目前正在尝试包含PlayFabC++SDK进入我的应用程序。该SDK主要针对游戏引擎Cocos2d-x,但基本上可以用于任何C++应用。它只是普通的REST,因此您向他们的服务器发送请求并等待响应。这非常适合使用lambda。他们声明了这个回调,当请求成功时调用:templateusingProcessApiCallback=void(*)(constResType&result,void*userData);不幸的是,他们没有使用std::function,而是一个函数指针。这样就不能使用捕获变量的lambda。因此,我想我可以简单地用std::function回调替换这个函数指针