首页 > 编程语言 >《c++dll篇》VS2015生成dll及调用

《c++dll篇》VS2015生成dll及调用

时间:2024-01-16 10:22:46浏览次数:29  
标签:CaculatorDLL Caculator double VS2015 c++ dll include PORT

VS2015生成dll及调用

原文链接:https://blog.csdn.net/qq_20792765/article/details/109801411

创建DLL文件

创建的DLL文件包括三个文件(.h/.dll/.lib),
1、打开VS新建一个项目。
image
2、选择DLL,附加选项选择空项目
image
3、在头文件和源文件下分别添加如下文件
image
4、在头文件CaculatorDLL.h中添加如下代码(具体可以自己定义代码),最上面的宏定义判断何时用外部接口,何时用内部接口,实在不理解的照着用就好了。哈哈!

#ifdef PORT_STYLE
#else
#define PORT_STYLE _declspec(dllimport)//当编译时,头文件不参加编译,所以.cpp文件中先定义,后头文件被包含进来,因此外部使用时,为dllexport,而在内部编译时,则为dllimport
#endif

//绝对值加法
double PORT_STYLE AbsAdd(double add1, double add2);

//Caculator类
class PORT_STYLE Caculator
{
public:
	//创建一个Cacualtor对象
	Caculator();
	//创建一个Cacualtor对象
	Caculator(double x, double y);
	//析构Cacualtor对象
	~Caculator();
	//加法
	double Add(double x, double y);
	//减法
	double Sub(double x, double y);
	//乘法
	double Mult(double x, double y);
	//除法
	double Divi(double x, double y);

private:
	double num1;
	double num2;
};

5、在源文件CaculatorDLL.cpp中添加如下代码

#define PORT_STYLE _declspec(dllexport)

#include"CaculatorDLL.h"

double PORT_STYLE AbsAdd(double add1, double add2)
{
	return add1 + add2;
}

Caculator::Caculator()
{
}

Caculator::Caculator(double x, double y)
{
	num1 = x;
	num2 = y;
}

Caculator::~Caculator()
{
}

double Caculator::Add(double x, double y)
{
	return x + y;
}

double Caculator::Sub(double x, double y)
{
	return x - y;
}

double Caculator::Mult(double x, double y)
{
	return x*y;
}

double Caculator::Divi(double x, double y)
{
	return x / y;
}

6、按照下图生成文件
image

7、在项目的Debug文件中生成如下文件
image

创建测试项目

1、打开VS创建一个新项目
image

image

image

2、生成一下项目,然后在项目所在文件夹内创建一个include文件夹,将1.7中CaculatorDLL.dll和CaculatorDLL.lib以及CaculatorDLL.h放入include文件夹内。

image

image

3、在将CaculatorDLL.dll文件放到TestDLL项目的Debug文件夹中。
image

4 配置环境,打开TestDLL项目的属性。
4.1 配置包含路径
image

image

4.2 配置库目录
image

image

4.3 配置附加依赖项

image

image

5 在TestDLL.cpp中添加如下代码

// TestDLL.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include"include\CaculatorDLL.h"

#include<iostream>

using namespace std;


int main()
{
	Caculator myCaculator;
	cout << AbsAdd(-1.23, 3.12) << endl;
	cout << myCaculator.Add(1.2, 2.1) << endl;
	cout << myCaculator.Sub(1.2, 2.1) << endl;
	cout << myCaculator.Mult(1.2, 2.1) << endl;
	cout << myCaculator.Divi(1.2, 2.1) << endl;

	getchar();
	return 0;
}

6 按F5得到如下结果,完毕!
image

标签:CaculatorDLL,Caculator,double,VS2015,c++,dll,include,PORT
From: https://www.cnblogs.com/fusio/p/17967050

相关文章

  • 《c++dll篇》VS2008生成dll及调用
    VS2008生成dll及调用原文链接:https://www.cnblogs.com/Ich-Sun/p/6593703.html生成dlladd.h里面的代码:#ifndefDlladd_H_#defineDlladd_H_#ifdefMYLIB#defineMYLIBextern"c"_declspec(dllimport)#else#defineMYLIBextern"C"_declspec(dllexport)#e......
  • C++零碎知识点
    目录RTTI运行时类型信息RTTI运行时类型信息在C++中,RTTI(Run-TimeTypeInformation,运行时类型信息)是一种机制,允许在程序执行期间确定对象的类型。RTTI是为了解决许多类库供应商自行实现此功能而导致的不兼容性问题而添加到C++语言中的。RTTI的主要目的是允许在运行时获取对象......
  • Qt/C++中英输入法/嵌入式输入法/小数字面板/简繁切换/特殊字符/支持Qt456
    一、前言在嵌入式板子上由于没有系统层面的输入法支持,所以都绕不开一个问题,那就是在需要输入的UI软件中,必须提供一个输入法来进行输入,大概从Qt5.7开始官方提供了输入法的源码,作为插件的形式加入到Qt中,这里需要特别提示的是,该源码是gpl的,商业应用对这个比较不感冒,可能更愿意自己基......
  • c++的文件读写
    #define_CRT_SECURE_NO_WARNINGS#include<iostream>#include<stdexcept>#include<algorithm>//1引入头文件#include<fstream>#include<string>//把磁盘信息输入到缓冲区然后读到程序中(读文件)voidtest02(){std::ifstreamifs;ifs.open("t......
  • C++U5-第01课-深度优先搜索1
    在全排列问题中,使用深度优先搜索(DFS)的思想体现在以下几个方面:递归结构:在解决全排列问题的函数中,我们使用了递归调用的方式。通过递归地处理每个位置上的数字,然后继续递归地处理下一个位置上的数字,最终得到完整的排列结果。选择与回溯:在每次递归调用中,我们需要做出选择并标记......
  • C++基础 -20- 基类覆盖父类
    ———————基类覆盖父类——————— ......
  • 用C/C++(Win32API)写软件修改键位
    title:用C/C++(Win32API)写软件修改键位date:2021-06-25categories:编程tags:-键盘-注册表-C/C++-Windows前言紧接上篇《Windows用注册表修改键盘映射(扫描码)》,用起来会发现处处不协调,除了需要熟悉新键位以外,最重要的是原本的快捷键也被拆散了,如原本都在左下角的Ct......
  • C#与C++代码的互操作方式
    title:C#与C++代码的互操作方式date:2024-01-10categories:编程tags:-C#-.NET-C++-COM-平台调用大致介绍在写C#程序时经常有与本地代码(C/C++)代码交互的需求。微软提供了许多种方式供我们选择,最常用的有以下三种(A->B指A可以引用B):flowchartLRA--P/Invoke......
  • C++U6-02-最短路算法1-dijkstra迪杰斯特拉最短路径
    学习目标 最短路径的基本概念  练习1 最短路的定义 本节课迪杰斯特拉dijkstra最短路算法 算法流程:以下是Dijkstra最短路径算法的逐步计算松弛的过程:初始化起始节点的距离为0,其他节点的距离为无穷大。选择当前距离最小且未被访问的节点作为当前节点。......
  • 为什么C++ 单例局部static初始化是线程安全的?
    为什么C++单例局部static初始化是线程安全的?constbg::AppSettings&bg::AppSettings::GetInstance(){staticAppSettingsinstance;returninstance;}对于以上单例模式代码,在C++11(及更高版本)中,函数局部静态AppSettings的构造保证是线程安全的。编译器将在AppS......