已经实现了接口编译后生成的文件中的函数,为什么编译还是报错

必看:深入学习Java8中的函数式接口
点击上方“云栖社区”可以订阅哦
目前由于系统已经全面切换为JDK8,所以有必要系统的了解一下Java8的一些新特性,以便后续在日常工作中可以使用一些高级特性来提高编程效率。
因为Java8引入了函数式接口,在java.util.function包含了几大类函数式接口声明。这里第一篇主要研究一下Function相关的接口。
FunctionalInterface注解
Java8的新引入,包含函数式的设计,接口都有@FunctionalInterface的注解。就像这个注解的注释说明一样,它注解在接口层面,且注解的接口要有且仅有一个抽象方法。具体就是说,注解在Inteface上,且interface里只能有一个抽象方法,可以有default方法。因为从语义上来讲,一个函数式接口需要通过一个***逻辑上的***方法表达一个单一函数。那理解这个单一就很重要了,单一不是说限制你一个interface里只有一个抽象方法,单是多个方法的其他方法需要是继承自Object的public方法,或者你要想绕过,就自己实现default。函数式接口自己本身一定是只有一个抽象方法。同时,如果是Object类的public方法,也是不允许的。官方的说明翻译如下:
如果一个接口I,I有一组抽象方法集合M,且这些方法都不是Object类的public签名方法,那么如果存在一个M中的方法m,满足:
m的签名是所有M中方法签名的子签名。
m对于M中的每个方法都是返回类型可替换的。 此时,接口I是一个函数式接口。
怎么理解,看几个例子。
比如:你声明一个接口:
这会编译错,编译器会告诉你*no target method*。而如果加一个方法:
这就OK了,一个函数式接口声明好了。再加一个呢?
不ok,明确说了只有一个抽象方法嘛。但是如果换一种函数签名:
错误依旧,因为这个方法签名是Object类的public方法。而再改一下:
这就OK了。一个抽象方法,一个Object的public方法,相安无事。Object还有其他方法,clone方法试试会怎么样?
这又不行了,因为前面明确说了,要是Object的public方法,而clone是protected的。
所以总结一句话就是:
函数式接口,有且仅有一个抽象方法,Object的public方法除外。
因为Java本身支持多接口实现,你定义一个Class可以implements多个interface。所以这个限制也没什么影响,如果想约定一个函数式接口来统一,也可以做一些默认的实现来达到一个接口多个抽象方法的目的,比如下面这种做法:
一个普通接口NonFunc:
函数式接口Func:
实现的测试类:
函数式接口的一大特性就是可以被lambda表达式和函数引用表达式代替。也就是说声明这样的接口,是可以灵活的以方法来传参。看个例子:
上面例子列举了一个lambda模式和一个方法引用模式,这样就可以利用函数式编程强大的能力,将方法作为参数了。
另一个大的话题是针对上文的***逻辑上的方法***。所谓逻辑上,就是说当你出现函数式接口多重继承其他接口时,如果继承的多个接口有相同的方法签名,那么也是OK的。而这种相同签名的方法,也包括了泛型的情况,以下的声明中的Z接口,都是函数式接口。
但是要注意的是,这种泛型的支持,是因为函数式接口的官方声明规范里要求类型可替换和子签名,不是因为泛型擦除。
比如下面的例子就不是函数式接口:
最后,Java8里关于函数式接口的包是java.util.function,里面全部是函数式接口。主要包含几大类:Function、Predicate、Supplier、Consumer和*Operator(没有Operator接口,只有类似BinaryOperator这样的接口)。后面依次展开详细说明一下。
关于Function接口,其接口声明是一个函数式接口,其抽象表达函数为
函数意为将参数T传递给一个函数,返回R。即$R=Function(T)$
其默认实现了3个default方法,分别是compose、andThen和identity,对应的函数表达为:compose对应$V=Function(ParamFunction(T))$,体现嵌套关系;andThen对应$V=ParamFunction(Function(T))$,转换了嵌套的顺序;还有identity对应了一个传递自身的函数调用对应$Function(T)=T$。从这里看出来,compose和andThen对于两个函数f和g来说,f.compose(g)等价于g.andThen(f)。看个例子:
只是普通的lambda表达式,其能力有限。我们会希望引入更强大的函数能力——高阶函数,可以定义任意同类计算的函数。
比如这个函数定义,参数是z,返回值是一个Function,这个Function本身又接受另一个参数y,返回z+y。于是我们可以根据这个函数,定义任意加法函数:
由于高阶函数接受一个函数作为参数,结果返回另一个函数,所以是典型的函数到函数的映射。
BiFunction提供了二元函数的一个接口声明,举例来说:
其输出结果将是:f(z)=x*y, when x=3,y=5, then f(z)=15。
二元函数没有compose能力,只是默认实现了andThen。
有了一元和二元函数,那么可以通过组合扩展出更多的函数可能。
Function接口相关的接口包括:
BiFunction :R apply(T t, U u);接受两个参数,返回一个值,代表一个二元函数;
DoubleFunction :R apply(double value);只处理double类型的一元函数;
IntFunction :R apply(int value);只处理int参数的一元函数;
LongFunction :R apply(long value);只处理long参数的一元函数;
ToDoubleFunction:double applyAsDouble(T value);返回double的一元函数;
ToDoubleBiFunction:double applyAsDouble(T t, U u);返回double的二元函数;
ToIntFunction:int applyAsInt(T value);返回int的一元函数;
ToIntBiFunction:int applyAsInt(T t, U u);返回int的二元函数;
ToLongFunction:long applyAsLong(T value);返回long的一元函数;
ToLongBiFunction:long applyAsLong(T t, U u);返回long的二元函数;
DoubleToIntFunction:int applyAsInt(double value);接受double返回int的一元函数;
DoubleToLongFunction:long applyAsLong(double value);接受double返回long的一元函数;
IntToDoubleFunction:double applyAsDouble(int value);接受int返回double的一元函数;
IntToLongFunction:long applyAsLong(int value);接受int返回long的一元函数;
LongToDoubleFunction:double applyAsDouble(long value);接受long返回double的一元函数;
LongToIntFunction:int applyAsInt(long value);接受long返回int的一元函数;
Operator其实就是Function,函数有时候也叫作算子。算子在Java8中接口描述更像是函数的补充,和上面的很多类型映射型函数类似。
算子Operator包括:UnaryOperator和BinaryOperator。分别对应单元算子和二元算子。
算子的接口声明如下:
二元算子的声明:
很明显,算子就是一个针对同类型输入输出的一个映射。在此接口下,只需声明一个泛型参数T即可。对应上面的例子:
例子里补充一点的是,BinaryOperator提供了两个默认的static快捷实现,帮助实现二元函数min(x,y)和max(x,y),使用时注意的是排序器可别传反了:)
其他的Operator接口:(不解释了)
LongUnaryOperator:long applyAsLong(long operand);
IntUnaryOperator:int applyAsInt(int operand);
DoubleUnaryOperator:double applyAsDouble(double operand);
DoubleBinaryOperator:double applyAsDouble(double left, double right);
IntBinaryOperator:int applyAsInt(int left, int right);
LongBinaryOperator:long applyAsLong(long left, long right);
predicate是一个谓词函数,主要作为一个谓词演算推导真假值存在,其意义在于帮助开发一些返回bool值的Function。本质上也是一个单元函数接口,其抽象方法test接受一个泛型参数T,返回一个boolean值。等价于一个Function的boolean型返回值的子集。
其默认方法也封装了and、or和negate逻辑。写个小例子看看:
Predicate在Stream中有应用,Stream的filter方法就是接受Predicate作为入参的。这个具体在后面使用Stream的时候再分析深入。
其他Predicate接口:
BiPredicate:boolean test(T t, U u);接受两个参数的二元谓词
DoublePredicate:boolean test(double value);入参为double的谓词函数
IntPredicate:boolean test(int value);入参为int的谓词函数
LongPredicate:boolean test(long value);入参为long的谓词函数
看名字就可以想到,这像谓词函数接口一样,也是一个Function接口的特殊表达——接受一个泛型参数,不需要返回值的函数接口。
这个接口声明太重要了,对于一些纯粹consume型的函数,没有Consumer的定义真无法被Function家族的函数接口表达。因为Function一定需要一个泛型参数作为返回值类型(当然不排除你使用Function来定义,但是一直返回一个无用的值)。比如下面的例子,如果没有Consumer,类似的行为使用Function表达就一定需要一个返回值。
其他Consumer接口:
BiConsumer:void accept(T t, U u);接受两个参数
DoubleConsumer:void accept(double value);接受一个double参数
IntConsumer:void accept(int value);接受一个int参数
LongConsumer:void accept(long value);接受一个long参数
ObjDoubleConsumer:void accept(T t, double value);接受一个泛型参数一个double参数
ObjIntConsumer:void accept(T t, int value);接受一个泛型参数一个int参数
ObjLongConsumer:void accept(T t, long value);接受一个泛型参数一个long参数
最后说的是一个叫做Supplier的函数接口,其声明如下:
其简洁的声明,会让人以为不是函数。这个抽象方法的声明,同Consumer相反,是一个只声明了返回值,不需要参数的函数(这还叫函数?)。也就是说Supplier其实表达的不是从一个参数空间到结果空间的映射能力,而是表达一种生成能力,因为我们常见的场景中不止是要consume(Consumer)或者是简单的map(Function),还包括了new这个动作。而Supplier就表达了这种能力。
比如你要是返回一个常量,那可以使用类似的做法:
这保证supplier对象输出的一直是1。
如果是要利用构造函数的能力呢?就可以这样:
这样的输出可以看到,全部的对象都是new出来的。
这样的场景在Stream计算中会经常用到,具体在分析Java 8中Stream的时候再深入。
其他Supplier接口:
BooleanSupplier:boolean getAsBoolean();返回boolean
DoubleSupplier:double getAsDouble();返回double
IntSupplier:int getAsInt();返回int
LongSupplier:long getAsLong();返回long
整个函数式接口的大概总结如下:
java8:lambda表达式强化练习
本篇博客写2个练习,巩固下lambda表达式,如果你还不了解lambda,请看这http://blog.csdn.net/zhiwenyan/article/details/需求:声明...
Java8的四大核心函数式接口
前言在学习一段时间后会不会有这样的疑问—难道我要用Lambda表达式的时候总要自己写函数式接口吗?
当然不是这样了,Java8里面提供了四大核心的函数式供我们使用!四大核心函数式接口测试代码
Java8的四种函数式接口
java8提供的函数式接口在Function包下有几十个接口,但是这几十个接口是从下面4种接口扩展而来的。下面我们看看这四种函数式接口。
java8的函数式编程主要就是4类接口。
java提供的函数式接口
下面是我归纳的一些核心函数式接口,
1. Consumer
消费型接口
accept(T t) ,提供的是无返回值的抽象方法
lambda表达式:函数式接口
写给大忙人看的JavaSE8中的函数式接口
函数式接口和lambda表达式
函数式接口和lambda表达式函数式接口(Functional Interface) :
任何接口,如果只包含唯一 一个抽象方法,那么它就是一个FI。(之前它们被称为 SAM类型,即 单抽象方法...
java 8 新特性(1.函数式接口 - Functional Interface)
1.函数式接口(Functional Interface):
所谓的函数式接口,当然首先是一个接口,然后就是在这个接口里面只能有一个抽象方法。这种类型的接口也称为SAM接口,即Single Abst...
常用函数式接口JDK 8 中重要的函数接口接口
Supplier None T 提供者 工厂方法创建对象
没有更多推荐了,caffe 在windows下怎么编译Matlab接口函数_百度知道
caffe 在windows下怎么编译Matlab接口函数
答题抽奖
首次认真答题后
即可获得3次抽奖机会,100%中奖。
来自电脑网络类芝麻团
采纳数:84
获赞数:63
参与团队:
整了一晚上加一上午。网上关于python的记录较少,这里写一下。这里的环境是WIN10+cudav7.5+cudnnv4+opencv+pycharm+VS2013使用的是GPU,我的GPU是titan16G+内存32G首先是caffe的文件以及第三方库的编译,这里提供一个已经编译好的的连接,我就是从那里下好然后编译完毕的。点击打开链接happynear的然后就是如何编译python接口。1、首先先生成两个python文件,在src/caffe/proto/extract_proto.bat里生成caffe_pb2.py这个之后有用。2、然后打开已经给好的caffe/buildVS2013,打开里面已经有的工程文件,正常的情况下应该是有7个工程,选中pycaffee单独作为要编译的项目。如图所示:把pycaffe作为单启动。注意需要在releasex64位下编译。如果没有这个的话,就将这个文件夹里python文件夹中的项目加入即可。如果没有python项目,就自己建一个,将python文件夹里的cpp文件加入就可以了。3、选择pycaffe的属性,将配置属性下的VC++目录中的包含目录和库目录填上你python所在的include和libs再在C/C++的目录下的附加包含目录一项中添加以我的python为例。D:/python27/Lib;D:/python/include/以及D:/Python27/Lib/site-packages/numpy/core/include如果你安装了CUDNN这里可以在预处理器那里把USE_CUDNN加上,同时在LINKER的输入目录下的附加依赖库中加入cudnn的lib文件。3、开始编译即可。这里要注意一定要和caffe、caffelib在一个项目里编译,否则会报错。4、编译成功后会在caffe/python/caffe下生成_caffe.pyd是打不开的5、配置python环境:需要几个额外库Cython&=0.19.2numpy&=1.7.1scipy&=0.13.2scikit-image&=0.9.3matplotlib&=1.3.1ipython&=3.0.0h5py&=2.2.0leveldb&=0.191networkx&=1.8.1nose&=1.3.0pandas&=0.12.0python-dateutil&=1.4,=2.5.0python-gflags&=2.0pyyaml&=3.10Pillow&=2.3.0six&=1.1.0其中numpy要装MKL版本的,不然scipy装上了BLAS不能用leveldb没有windows版本的,不过我找到了可以使用的法。见这个博客:点击打开链接如果有pipinstall装不上的,可以上这个网站找wheel文件安装就可以了点击打开链接6、最后把目录中python下的caffe文件夹复制到python27/Lib/site-packages就可以了。测试的时候只需要在控制台下输入importcaffe看能载入就知道成功了:)
为你推荐:
其他类似问题
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。java基础知识辅导:Java8之默认方法、函数式接口、方法引用4
发表时间:日20:19 来源:中大网校
点击关注微信:
除过以前的那些区别外,带有默认方法的interface和抽象类的区别:抽象类是有个状态的,它可以有构造函数和成员变量抽象类不能用于lambda表达式中默认方法不能覆盖 equals, hashCode, toString 方法!!!原因可以参考Brian Goetz给出的回答:Allow default methods to override Object's methodshttp://viralpatel.net/blogs/java-8-default-methods-tutorial/http://zeroturnaround.com/rebellabs/java-8-explained-default-methods/函数式接口(Functional Interfaces)函数式接口就是只包含一个抽象方法的接口。比如Java标准库中的java.lang.Runnable和 java.util.Comparator都是典型的函数式接口。使用注解 @FunctionalInterface 可以显示指明一个接口是函数式接口,但如果接口中只定义了一个抽象方法,通常不用自己写这个注解,编译器会自动识别它就是函数式接口。因为默认方法不是抽象的,所以函数接口里还可以定义任意多的默认方法。实质就是 C# 的委托(delegate)。定义Java代码interface MyFi1 {public abstract void run();}@FunctionalInterfaceinterface MyFi2 {public abstract void run();}@FunctionalInterfaceinterface MyFi3 {public abstract void run();default void tripleRun(){run();run();run();}}实现Java代码// 匿名类实现new MyFi1() {@Overridepublic void run() {System.out.println("Anonymous Inner class");}}.run();Java代码// lambda表达式实现只需要提供形式参数和方法体。// 函数式接口只有一个抽象方法,编译器能自动推断方法。MyFi1 dbl = () -> System.out.println("Lambda Expression");dbl.run();如果接口有多个抽象方法,会提示“The target type of this expression must be a functional interface”。Java代码public interface Comparator { int compare(T o1, T o2); boolean equals(Object obj); }Comparator接口里面虽然声明了两个方法,但它是函数接口。因为equals方法是Object的,不影响它依然是个函数接口。Java 8在java.util.function中定义了很多常用的函数类型接口。分类函数:Function / BiFunction  T -> R运算:UnaryOperator / BinaryOperator T -> T 或 (T, T) -> T预言:Predicate / BiPredicate生产者:Supplier 返回T消费者:Consumer / BiConsumer 只有一个参数编辑推荐:相关链接:&
(责任编辑:pgl)
共2页,当前第1页&&&&&&封装静态库时,接口函数使用问题//报无法解析不知道为什么
[问题点数:100分,结帖人mirroatl238]
本版专家分:0
结帖率 100%
CSDN今日推荐
本版专家分:87755
2013年7月 荣获微软MVP称号2012年7月 荣获微软MVP称号2011年7月 荣获微软MVP称号
2013年9月 VC/MFC大版内专家分月排行榜第一2013年8月 VC/MFC大版内专家分月排行榜第一
2012年2月 VC/MFC大版内专家分月排行榜第二2011年3月 VC/MFC大版内专家分月排行榜第二2011年2月 VC/MFC大版内专家分月排行榜第二
2014年8月 VC/MFC大版内专家分月排行榜第三2014年7月 VC/MFC大版内专家分月排行榜第三
本版专家分:17021
本版专家分:17021
本版专家分:0
本版专家分:432084
2009年 总版技术专家分年内排行榜第二2005年 总版技术专家分年内排行榜第二
2009年7月 总版技术专家分月排行榜第二2009年3月 总版技术专家分月排行榜第二2009年1月 总版技术专家分月排行榜第二2005年7月 总版技术专家分月排行榜第二2005年5月 总版技术专家分月排行榜第二2005年3月 总版技术专家分月排行榜第二
优秀小版主2015年8月优秀小版主2015年9月优秀小版主2015年5月优秀小版主2015年2月论坛优秀版主
2009年6月 总版技术专家分月排行榜第三2009年2月 总版技术专家分月排行榜第三2005年4月 总版技术专家分月排行榜第三2005年1月 总版技术专家分月排行榜第三
本版专家分:432084
2009年 总版技术专家分年内排行榜第二2005年 总版技术专家分年内排行榜第二
2009年7月 总版技术专家分月排行榜第二2009年3月 总版技术专家分月排行榜第二2009年1月 总版技术专家分月排行榜第二2005年7月 总版技术专家分月排行榜第二2005年5月 总版技术专家分月排行榜第二2005年3月 总版技术专家分月排行榜第二
优秀小版主2015年8月优秀小版主2015年9月优秀小版主2015年5月优秀小版主2015年2月论坛优秀版主
2009年6月 总版技术专家分月排行榜第三2009年2月 总版技术专家分月排行榜第三2005年4月 总版技术专家分月排行榜第三2005年1月 总版技术专家分月排行榜第三
本版专家分:25744
本版专家分:25744
本版专家分:-670
本版专家分:2251
本版专家分:2251
匿名用户不能发表回复!
其他相关推荐
在使用vs2008调试程序的过程中,经常会出现无法解析的外部符号问题,可能的原因有很多种,下面这些是我一年来积累的经验.
考虑可能的原因:
[0]出现无法解析可能是因为lib文件不正确,比如64位的编译配置,结果使用的是32位的lib包.
[1]只写了类声明,但还没有写实现类,造成调用时无法解析
[2]声明和定义没有统一,造成链接不一致,无法解析
导入第三方库后,有一个库函数编译报错(无法解析的外部符号),况且把这个函数称为问题函数,其他库函数编译正常。把问题函数删掉再运行,发现运行正常。其他库函数正常调用,证明不是库导入问题,但是为什么就这个问题函数不能调用。...
1动态库的编译环境和使用动态库的编译环境不一致。
2,导出动态库的头文件中,不能含有函数的实现。
本来工程在共享库中使用MFC是没问题的。改为在静态库中使用MFC就出现了下面的问题。
1&msvcrtd.lib(ti_inst.obj) : error LNK2005: &private: __thiscall type_info::type_info(class type_info const &)& (??0type_info@@AAE@ABV0@@Z) 已经在 libcmtd.
bundle打包xib文件
字数326 阅读204 评论1 喜欢6
GitHub幽灵^_^
1.创建工程,新建一个Class,勾选Xib,然后布局Xib
xib文件中添加了一个UIImageView,图片名称不需要添加&AAA.bundle/&,因为打包bundle的时候xib文件和图片资源文件在同一目录下.
我们知道,在C语言里面的静态变量,在程序运行上只有一份拷贝, 在程序的任何一处改变其值后, 其他地方再调用会得到已经修改后的值, 因此可以当做一个全局变量来使用.
但是,当系统比较庞大时,经常会将一些功能代码编译成各种库来调用,这里的库有静态库和动态库.
问题是, 当一个静态变量是定义在一个静态库里面时, 它是不是也只有一份拷贝呢,答案是不一定. 考虑这样的一个情况, 有一个静态库liba,
网上关于Framework制作的教程数不胜数,然而都过于陈旧,最新的也是使用Xcode7的教程,而且有些设置也只给出步骤,并没有给出原因,而且按照有些教程制作出的framework还有些问题,所以我把自己制作framework的过程记录下来,并且使用的是最新的Xcode8环境。本次制作framework,包含AFN,FMDB第三方,.a文件,xib,Bundle文件,还有Category分类,几乎制作和使用framework遇到的所有坑都被我遇到了,所以,此篇博客在我这属于干货,特此分享给大家,以免再走弯路
error:符号无法解析标签(空格分隔):vs c/c++符号无法解析的常见原因
头文件包含出错,导致链接过程找不到源文件
lib或dll引入失败(静态库或动态库配置问题)
调用动态库的情况下,跨工程引入头文件导致的符号解析错误
对第三种情况进行详细说明
较为大型的项目常常会设置较多个工程,以其中一个工程为主工程(包含main函数),且该主工程通过调用其他子工程的静态库或动态库中的相关函数完成处理
在使用VS编译库的时候经常会提示无法解析的外部符号
由提示信息可知编译过程已经进行到了创建库的阶段。即到了实质性引入库的阶段。
我们需要做的就是提供所需要的库给编译器即可,但是这个过程往往会出现很多问题,这里记录一些供参考。
1 有所需要的lib库,从但是库中不包含所需要的函数或者方法。
这种情况多出现在lib库版本不对应的时候,即,在编译时库里的函数方法已经不满足库使用了。需要处
1. 新建一个文件,设为共享目录。在svn中新建一个目录的具体操作方法如下:第一步:打开SVN服务端,找到特定的项目目录,右击选择“属性”第二步:然后点击“增加”第三步:在增加的页面中,选择重新创建用户名和密码第四步:上述步骤完成之后,填写新建的用户名和密码就可以了参考:https://zhidao.baidu.com/question/.htmlvc编译过程都调用了哪些接口函数或调用宏呢
<a data-traceid="question_detail_above_text_l&&
有没有知道VC编译各个过程都调用的接口函数或接口变量的?就是在VS2008上建了一个工程,建好之后编译,链接,再生产可执行文件。请问VC在这过程都调用了哪些接口函数和哪些宏,如果想要调用这些接口函数或宏,如何调用呢?~
没看懂!!!可能需要阐述的再详细些
我的理解是,你想知道VC的IDE怎么把源代码变成程序的
实际上你可以看看IDE编译之后给的LOG.HTML,
具体来说就是IDE调用了 cl.exe 来编译,link.exe 来链接,
对应的GCC版是 gcc -& cl.exe ,ld -& link.exe ,make -& nmake.exe
实际上对于IDE产生的项目文件 *.vcproj 可以使用命令行工具 vcbuild.exe,vc2010新版的 *.vcxproj 可以用 msbuild.exe
很久没用IDE了,也没有手写过Makefile,如果有错请纠正,我用CMake
cmake.exe -G &Visual Studio 10& ..
msbuild.exe /p:Configuration=RPlatfrom=Win32 all.sln
引用来自“lucky_star”的答案没看懂!!!可能需要阐述的再详细些就是说,我的工程有100个cpp文件和相应的100个头文件,编译器如何将这100个cpp文件和100个h文件最终生成一个可执行文件呢?我大概知道编译器将这100个cpp文件和100个h文件编译、链接、生成obj文件,最终生成可执行文件,但是这些过程编译器除了调用100个cpp和100个h的接口外,还都调用了哪些内部的接口函数或宏定义呢?如果我想调用这些内部接口,如何调?
VC IDE里面有个browse,你可以查看父函数或子函数。会列到库函数位置。你可以看下那些函数被调用。这是IDE的工具。但是不能自动生成。另外你可以生成VC的profile来看。网络上资料。
这两种方法都比较简单的索引到你实际代码中调用了哪些函数。而库函数内部怎么玩的,你只有看代码了。不一定有。
引用来自“中中中”的答案引用来自“lucky_star”的答案没看懂!!!可能需要阐述的再详细些就是说,我的工程有100个cpp文件和相应的100个头文件,编译器如何将这100个cpp文件和100个h文件最终生成一个可执行文件呢?我大概知道编译器将这100个cpp文件和100个h文件编译、链接、生成obj文件,最终生成可执行文件,但是这些过程编译器除了调用100个cpp和100个h的接口外,还都调用了哪些内部的接口函数或宏定义呢?如果我想调用这些内部接口,如何调?
你需要知道是makefile文件如何编写。你说的“内部的接口函数或宏定义”如果指的是标准函数库的话,你就一直在用,比如stdio.h, stdlib.h等。如果不是这些的话, 你是没有办法调用的,这些是编译器的内部实现,就算对外开放的话也是没有什么意义的。在链接的时候是代码和数据是有重定位的,你可以认为这些都是编译器的内部实现,认为是个黑盒就好了。

我要回帖

更多关于 设备驱动程序接口函数如何实现 的文章

 

随机推荐