C++ 静态调用C的DLL库(调用lib文件)

简介: C++ 静态调用C的DLL库(调用lib文件)

编写DLL代码

新建工程

新建空项目工程

tt.png

点击确定。然后右键项目选择新建项。

tt.png

再次选择新建项,选中C++文件,将其改为MySocketClient.c,然后选择添加。

tt.png

到这里,新建工程就完成了。

tt.png

然后右键项目,选择属性 将配置类型改为动态库(.dll)

tt.png

编写头文件MySocketClient.h

#ifndef _INC_MYSOCKETCLIENT_H_


#define _INC_MYSOCKETCLIENT_H_


#define Import_SSS


#ifdef Import_SSS


#define API _declspec(dllexport)


#else


#define API _declspec(dllimport)


#endif



#ifdef _cplusplus//extern"C" 来告诉编译器:这是一个用C写成的库文件,请用C的方式来链接它们。


extern "C" {

#endif // _cplusplus


   API//导出函数,让外界调用。


   int socketClient_Init(void **handle);


   API


   int socketClient_Send(void *handle, unsigned char *buf, int buflen);


   API


   int socketClient_Recv(void *handle, unsigned char *buf, int *buflen);


   API


   int socketClient_Destory(void *handle);


#ifdef _cplusplus


}


#endif // _cplusplus


#endif //_INC_MYSOCKETCLIENT_H_


编写MySocketClient.c

#define _CRT_SECURE_NO_WARNINGS


#include <stdlib.h>


#include <string.h>


#include <stdio.h>


#include "MySocketClient.h"


typedef struct _Sck_Handle


{

   char version[16];


   char ip[16];


   int port;


   unsigned char *p;


   int len;


}Sck_Handle;//定义Handle的结构体。


int socketClient_Init(void **handle)


{

   int ret = 0;


   Sck_Handle *tmpHandle = NULL;


   if (handle == NULL)


   {

        ret = -1;


        printf("[socketClient_Init] err %d handle=NULL \n", ret);


        return ret;


   }


   tmpHandle = (Sck_Handle *)malloc(sizeof(Sck_Handle));


   if (tmpHandle == NULL)


   {

        ret = -2;


        printf("[socketClient_Init] err:%d malloc err \n", ret);


   }


   memset(tmpHandle, 0, sizeof(Sck_Handle));//初始化结构体。


   strcpy(tmpHandle->version, "1.0.0.1");


   strcpy(tmpHandle->ip, "192.168.12.121");


   tmpHandle->port = 11111;


   *handle = tmpHandle;


   return ret;


}


socket报文发送


//__declspec(dllexport)


int socketClient_Send(void *handle, unsigned char *buf, int buflen)


{

   int          ret = 0;


   Sck_Handle   *tmpHandle = NULL;


   if (handle == NULL || buf == NULL || buflen <= 0)


   {

        ret = -2;


        printf("func socketclient_send() err :%d  (handle == NULL ||  buf==NULL || buflen <=0 ) \n", ret);


        return ret;


   }


   tmpHandle = (Sck_Handle *)handle;


   tmpHandle->len = buflen;


   tmpHandle->p = (unsigned char *)malloc(buflen);


   if (tmpHandle->p == NULL)


   {

        ret = -2;


        printf("func socketclient_send() err :%d  malloc len:%d \n", ret, buflen);


        return ret;


   }


   memcpy(tmpHandle->p, buf, buflen); //数据的缓存到内存


   printf("接收到发送数据是%s \n", tmpHandle->p);


   return ret;


}


socket报文接受


//__declspec(dllexport)


int socketClient_Recv(void *handle, unsigned char *buf, int *buflen)


{

   int          ret = 0;


   Sck_Handle   *tmpHandle = NULL;


   if (handle == NULL || buf == NULL || buflen == NULL)


   {

        ret = -2;


        printf("func socketclient_recv() err :%d  (handle == NULL ||  buf==NULL || buflen==NULL ) \n", ret);


        return ret;


   }


   tmpHandle = (Sck_Handle *)handle;


   memcpy(buf, tmpHandle->p, tmpHandle->len);


   *buflen = tmpHandle->len; //间接赋值  告诉调用者 收到的数据的长度


   printf("数据长度是%d \n", tmpHandle->len);


   return ret;


}


socket环境释放


//__declspec(dllexport)


int socketClient_Destory(void *handle)


{

   int          ret = 0;


   Sck_Handle   *tmpHandle = NULL;


   if (handle == NULL)


   {

        return -1;


   }


   tmpHandle = (Sck_Handle *)handle;


   if (tmpHandle->p != NULL)


   {

        free(tmpHandle->p); //释放结构体 成员域的 指针所指向的内存空间


   }


   free(tmpHandle); //释放结构体内存


   return 0;


}


然后右键编译工程。在Debug文件夹下面就可以看到生成的dll



静态调用

静态调用,使用lib文件调用


#define  _CRT_SECURE_NO_WARNINGS


#include <stdio.h>


#include <windows.h>


#include <iostream>


using namespace std;


#pragma comment(lib,"MySocketClient.lib")


extern "C"


{


   int socketClient_Init(void **handle);


int socketClient_Send(void *handle, unsigned char *buf, int buflen);


int socketClient_Recv(void *handle, unsigned char *buf, int *buflen);


int socketClient_Destory(void *handle);


}


int main()


{



   unsigned char buf[1024];


   int buflen;



   unsigned char out[1024];


   int outlen;


   void *handle = NULL;


   int ret = 0;


   strcpy((char *)buf, "aaaaAAAAAFFffffffdddddddd");


   buflen = 9;


   //客户端初始化 获取handle上下


   ret = socketClient_Init(&handle /*out*/);


   if (ret != 0)


   {


        printf("func socketclient_init() err:%d \n ", ret);


        goto End;


   }


   //客户端发报文


   ret = socketClient_Send(handle /*in*/, buf /*in*/, buflen /*in*/);


   if (ret != 0)


   {


        printf("func socketclient_send() err:%d \n ", ret);


        goto End;


   }


   //客户端收报文


   ret = socketClient_Recv(handle /*in*/, out /*in*/, &outlen/*in out*/);


   if (ret != 0)


   {


        printf("func socketclient_recv() err:%d \n ", ret);


        goto End;


   }


   printf("接收到的数据长度是%d \n", outlen);



End:


   //客户端释放资源


   ret = socketClient_Destory(handle/*in*/);



   printf("hello...\n");


   system("pause");


   return 0;


}


运行结果:

tt.png



 


tt.png

目录
相关文章
|
1月前
|
算法 C++ 容器
C++标准库(速查)总结
C++标准库(速查)总结
61 6
|
1月前
|
存储 算法 C++
C++ STL 初探:打开标准模板库的大门
C++ STL 初探:打开标准模板库的大门
95 10
|
1月前
|
存储 程序员 C++
C++常用基础知识—STL库(2)
C++常用基础知识—STL库(2)
69 5
|
1月前
|
存储 自然语言处理 程序员
C++常用基础知识—STL库(1)
C++常用基础知识—STL库(1)
52 1
|
1月前
|
Linux C++
Linux c/c++文件的基本操作
在Linux环境下使用C/C++进行文件的基本操作,包括文件的创建、写入、读取、关闭以及文件描述符的定位。
19 0
Linux c/c++文件的基本操作
|
2月前
|
编译器 API C语言
超级好用的C++实用库之跨平台实用方法
超级好用的C++实用库之跨平台实用方法
39 6
|
2月前
|
缓存 网络协议 Linux
超级好用的C++实用库之套接字
超级好用的C++实用库之套接字
34 1
|
1月前
|
Linux C++
Linux c/c++文件虚拟内存映射
这篇文章介绍了在Linux环境下,如何使用虚拟内存映射技术来提高文件读写的速度,并通过C/C++代码示例展示了文件映射的整个流程。
47 0
|
1月前
|
Linux C++
Linux c/c++文件移动
这篇文章介绍了在Linux环境下,使用C/C++语言通过命令方式和文件操作方式实现文件移动的方法。
70 0
|
9天前
|
存储 编译器 C++
【c++】类和对象(中)(构造函数、析构函数、拷贝构造、赋值重载)
本文深入探讨了C++类的默认成员函数,包括构造函数、析构函数、拷贝构造函数和赋值重载。构造函数用于对象的初始化,析构函数用于对象销毁时的资源清理,拷贝构造函数用于对象的拷贝,赋值重载用于已存在对象的赋值。文章详细介绍了每个函数的特点、使用方法及注意事项,并提供了代码示例。这些默认成员函数确保了资源的正确管理和对象状态的维护。
37 4