
#include<mathh>//绝大多数数学相关的函数都在这个库里
#include<stdioh>//这个是标准输入输出库 ( standard input output)
#define pi 31415926535
int main()
{
printf("%lf", sin(pi / 2));
return 0;
}
C语言程序调用C++ 库函数方法,关键是函数名字解析问题。 其实实现起来不是很难。
使用关键字 extern \"C\" 可以使得C++ 编译器生成的函数名满足C语言的要求
例子如下:
链接库头文件:
//headh
class A
{
public:
A();
virtual ~A();
int gt();
int pt();
private:
int s;
};
cpp
//firstsocpp
#include
#include \"headh\"
A::A(){}
A::~A(){}
int A::gt()
{
s=10;
}
int A::pt()
{
std::cout< }
编译命令如下:
g++ -shared -o libmyso firstsocpp
这时候生成libmyso文件,将其拷贝到系统库里面:/usr/lib/
进行二次封装:
cpp
//secsocpp
#include
#include \"headh\"
extern \"C\"
{
int f();
int f()
{
A a;
agt();
apt();
return 0;
}
}
编译命令:
gcc -shared -o secso secsocpp -L -lmy [Page]
这时候生成第二个so文件,此时库从一个类变成了一个c的接口
拷贝到/usr/lib
下面开始调用:
//testc
#include \"stdioh\"
#include \"dlfcnh\"
#define SOFILE \"secso\"
int (f)();
int main()
{
void dp;
dp=dlopen(SOFILE,RTLD_LAZY);
f=dlsym(dp,\"f\");
f();
return 0;
}
编译命令如下:
gcc -rdynamic -s -o myapp testc
运行Z$/myapp
10
$
函数分为库函数和自定义函数,在调用库函数时只要标明头文件(所谓头文件就是一个东西,里面包括了一些函数各声明之类的,当你要调用它中的函数时就就得先向程序说明你要调用这个文件里的函数,否则有有侵权行为哦)可以在主调函数中调用这个头文件里的所有函数了,例如头文件为#include<stdioh>你就可以在主调函数中调用这个头文件里的函数:
main
{ printf("haha");/这时main函数为主调函数,printf为被调函数/
}
调用自定义函数时其实和调用库函数一样的,只不过这个函数是你自己定义的,再如:
main
{ void f();/声明 f()函数/
f(); /调用f()函数/
}
f()
{
printf("haha");/f()函数调用库函数/
}
#include<stack>
stack<int> s;
sempty() 如果栈为空返回true,否则返回false
ssize() 返回栈中元素的个数
spop() 删除栈顶元素但不返回其值
stop() 返回栈顶的元素,但不删除该元素
spush() 在栈顶压入新元素
我前面定义的是int,所以入栈和出栈都是int
VC++动态库的调用说明
首先将要调用的动态库拷贝到当前的项目中
定义将要调用动态库中的函数的函数指针
加载动态库
获得需要调用动态库中的函数的地址
使用完这个动态库时要释放这个动态库
例子:
现在有一个adddll动态库,该动态库中有一个求和函数int ADD(int a,int b)
现在一个项目程序中需要调用这个求和函数,该函数的使用步骤如下:
(1)定义一个函数指针:typedef int (Add)(int ,int);
(2)在主程序中加载动态库:
定义一个动态库句柄 HINSTANCE hDLL;
hDLL = LoadLibrary(“adddll”);
(3)获得该函数的在动态库中地址
定义一个ADD函数的函数指针Add add;
Add = (Add)GetProcAddress(hDLL,”ADD”);//获取地址
Int result = Add(a,b);//调用该函数
(4)释放动态库
FreeLibrary(hDLL);
VC++静态库的调用说明
包含库的头文件
在应用程序工程中使用
#include “file path”
file path 可以为绝对路径,也可以为相对工程所在目录的相对路径
如果头文件比较的多,可以在project>setting>c/c++>preprocessor的Additional include directories中填入你的头文件所在的目录
导入lib库
直接用project>add to project>files的方式将lib加入工程
使用#pragma comment(lib,”you lib path and name”);
与前面的头文件一样,也可以不在这里指定路径,而是在project>setting>link>input的Additional lib path 中输入lib文件所在的路径
还可以在project>setting>link>general的object/library modules中输入lib的名字。
编译执行程序,如果是静态库编译后就可直接执行。
如果是动态库,需要将dll放到可执行文件所在的目录下,或者系统目录下,如system32或者windows目录,或者其他任何一个位于环境变量PATH中的目录中。
Note:h头文件是不能编译的,所以lib文件里是不包含h文件的,如果你生成lib文件的源程序里有h文件和cpp(c)文件,除了加入lib文件(上面的三种方法,个人建议第2)种)外,你还需要手动的将h文件加入到新项目里, 如果你生成lib的源代码只有c或cpp文件,则不需要。
是网络上帮您查到的,祝您早日解决问题哦!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)