如何为其他程序提供一个函数来调用它
How to provide a function for the other program to call it?
假设我在Linux中使用C++程序来维护队列,并对队列中的数据做一些事情,现在我想在后台运行它并提供一个函数,因此其他程序可以简单地调用它将数据拉入我的队列
最好的方法是什么?
如果您的程序作为两个独立的进程运行,您不能直接调用其他进程中的函数,您将需要进程间通信机制(IPC)来在两个进程之间进行通信。
通常,操作如下:
要与之通信的进程提供客户端库。要与该进程通信的进程或应用程序链接到此客户端库。这个客户端库提供了简单的函数调用,调用进程/应用程序可以直接调用这些函数。客户端库实现了与远程进程通信所需的IPC机制。
我所理解的是,您需要一个封装与队列通信的客户端API。
您需要创建一个单独的库来包含和导出API,并将其包含在想要使用它的程序中
class Communicator
{
public:
bool putData(Data* data);
bool getData(Data*& data);
};
Communicator
的实现通过IPC与队列进行实际通信,但您将该层抽象出来。
有多种机制可以做到这一点,从创建自己的服务器,到使用IPC、RPC、CORBA等等。
至于最好的,这取决于各种因素。
在您提到的OP中,您想要一个由一个进程处理的队列——也许使用共享内存和互斥是一个简单的解决方案,使用一个库来访问两个进程的队列。
相关文章:
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何仅为一个函数添加延迟
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 我需要将多个函数组合为一个函数
- 在C++中声明一个函数时,它需要有函数本身的参数吗
- 如何创建一个函数来计算并返回平均值、最大值和最小值
- 一个函数,用于查找字符串1包含字符串2 c++的次数
- 如何将一个类的函数作为另一个类的另一个函数的参数传递
- 编写一个函数以使用 n 百分比的 CPU 使用率
- 将 N-arg 函数包装到另一个函数中
- 如何封装一个函数,以便它只能由同一类中的一个其他函数调用?
- C++(.cpp文件和.h文件)拆分代码并添加一个函数,提取 - 这很容易吗?
- C++从另一个函数退出函数
- 编写一个函数来删除单链表中的节点(尾部除外),仅授予对该节点的访问权限
- 视觉我希望一个函数在另一个函数C++中进行计算
- C ++如何在原始抽象类中创建一个函数,该函数接受派生类的输入
- 在另一个函数 (c++) 中调用变量
- 如何在另一个函数中使用返回值作为参数?
- 如何包装一个函数以适应另一个函数的所需类型
- 创建一个函数的 Python 绑定,返回指向带有 boost 的向量的指针