赞
踩
前面简单了解了C++中的extern "C"之后,可能很多小伙伴对这个陌生的词非常困惑,不能理解他的使用场景。
所以本章内容就来详细了解extern "C"的用法,这里使用栈的一个OJ题来举例。
题目在这里---->有效的括号
解题方法在这里--->栈和队列经典OJ练习
在这里我们解这道题需要使用栈,有两种方法,第一种方法是自己写一个栈;第二种方法是调用别人已经写好编译好的库。(当然这里为了演示我们选择第二种方法)
程序代码:
- #include<iostream>
- using namespace std;
-
-
- bool isValid(const char* s) {
- Stack st;
- StackInit(&st);
- while (*s)
- {
- if ((*s == '(') || (*s == '[') || (*s == '{'))
- {
- StackPush(&st, *s);
- s++;
- }
- else
- {
- if (StackEmpty(&st))
- {
- return false;
- }
- char tmp = StackTop(&st);
- StackPop(&st);
- if ((tmp == '(' && *s != ')')
- || (tmp == '[' && *s != ']')
- || (tmp == '{' && *s != '}'))
- {
- return false;
- }
- else
- {
- s++;
- }
- }
- }
- bool ret = StackEmpty(&st);
- return ret;
-
- }
-
-
- int main()
- {
- cout << isValid("{[]}") << endl;
- cout << isValid("([)]") << endl;
- return 0;
- }
![](https://csdnimg.cn/release/blogv2/dist/pc/img/newCodeMoreWhite.png)
动态库/静态库,目前我也不太清楚,这里的知识后面学习了再补充,现在就理解成别人写好给你用的被编译好的程序就可以了。
这里简单介绍一下怎么样创建一个静态库:
然后将栈的实现放到静态库中,这样一个静态库就创建好了。
现在创建好了一个用C++写的程序,然后调用C语言写的库。
首先需要包含头文件,而这里与以前包含的方式不同:
#include"../Stack/stack.h"
. 表示当前目录
..表示上一层目录
然后我们来运行一下:
但这里出现了链接错误,这里有两个原因:
1.C++程序会使用被修饰后的函数名在C的静态库中寻找,而静态库中的函数名没有被修饰。
2.这里只包含了Stack.h文件,只有声明,没有定义,没有地址,找不到这些函数。
下面来链接静态库:
这一步是将静态库中的Stack.lib文件添加
再来运行一下:
还是不行,我们将静态库中的文件名后缀改成.cpp试一下:
然后就编译成功了:
以上说明现在就是第一个问题了:C++的函数名修饰规则在查找函数名时与C语言不同,导致在静态库中找不到这些函数。所里这里的主角来了:extern "C"
方法:
这段代码的意思是:告诉编译器在调用这个静态库时,调用函数使用C的风格去调用(即调用函数时不使用函数名修饰规则)
最后我们就能正确运行程序:
用一个C程序调用C++写的静态库,前面的包含静态库的步骤类似,就不再重复演示了。
但这里extern "C"使用时与前面有区别,因为C语言的语法中不支持 extern "C",所以只能在C++的静态库中使用。
这里C程序调用C静态库是能运行的:
然后将C静态库改成C++静态库:
运行一下:C程序无法调用C++静态库中函数名被修饰的函数
所以需要在C++静态库中使用extern "C"
当然可能在有些编译器下直接使用可能会报错,因为包含头文件之后会将静态库中的内容展开到C程序中,但是C程序不支持extern "C",这里就无法识别。
使用条件编译:
现在就能正常运行了:
综上就是extern "C"的用法及使用场景。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。