- 浏览: 584089 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (365)
- Tomcat调优 (2)
- Apache Http (20)
- Webserver安装 (5)
- Linux安装 (28)
- Linux常用命令 (17)
- C语言及网络编程 (10)
- 文件系统 (0)
- Lucene (12)
- Hadoop (9)
- FastDFS (8)
- 报表 (0)
- 性能测试 (1)
- JAVA (18)
- CSharp (3)
- C++ (38)
- BI (0)
- 数据挖掘 (0)
- 数据采集 (0)
- 网址收集整理 (3)
- Resin (0)
- JBoss (0)
- nginx (0)
- 数据结构 (1)
- 随记 (5)
- Katta (1)
- Shell (6)
- webservice (0)
- JBPM (2)
- JQuery (6)
- Flex (41)
- SSH (0)
- javascript (7)
- php (13)
- 数据库 (6)
- 搜索引擎排序 (2)
- LVS (3)
- solr (2)
- windows (1)
- mysql (3)
- 营销软件 (1)
- tfs (1)
- memcache (5)
- 分布式搜索 (3)
- 关注的博客 (1)
- Android (2)
- clucene (11)
- 综合 (1)
- c c++ 多线程 (6)
- Linux (1)
- 注册码 (1)
- 文件类型转换 (3)
- Linux 与 asp.net (2)
- perl (5)
- coreseek (1)
- 阅读器 (2)
- SEO (1)
- 励志 (1)
- 在线性能测试工具 (1)
- yii (7)
- 服务器监控 (1)
- 广告 (1)
- 代理服务 (5)
- zookeeper (8)
- 广告联盟 (0)
- 常用软件下载 (1)
- 架设自已的站点心得 (0)
最新评论
-
terry07:
java 7 用这个就可以了 Desktop desktop ...
关于java Runtime.getRunTime.exec(String command)的使用 -
HSINKING:
怎么设置打开的dos 窗口是指定的路径下
关于java调用bat文件,不打开窗口 -
liubang201010:
hyperic hq更多参考资料,请访问:http://www ...
hyperic-hq -
^=^:
STDIN_FILENO是unistd.h中定义的一个numb ...
深入理解dup和dup2的用法 -
antor:
留个记号,学习了
[转]用java流方式判断文件类型
1。 重载是如何实现的?
几个同名的重载函数仍然是不同的函数,它们是如何区分的呢?我们自然想到函数接口的两个要素:参数与返回值。
如果同名函数的参数不同(包括类型、顺序不同),那么容易区别出它们是不同的函数。
如果同名函数仅仅是返回值类型不同,有时可以区分,有时却不能。例如:
void Function(void);
int Function (void);
上述两个函数,第一个没有返回值,第二个的返回值是int类型。如果这样调用函数:
int x = Function ();
则可以判断出Function是第二个函数。问题是在C++/C程序中,我们可以忽略函数的返回值。在这种情况下,编译器和程序员都不知道哪个Function函数被调用。
所以只能靠参数而不能靠返回值类型的不同来区分重载函数。编译器根据参数为每个重载函数产生不同的内部标识符。例如编译器为示例8-1-1中的三个Eat函数产生象_eat_beef、_eat_fish、_eat_chicken之类的内部标识符(不同的编译器可能产生不同风格的内部标识符)。
如果C++程序要调用已经被编译后的C函数,该怎么办?
假设某个C函数的声明如下:
void foo(int x, int y);
该函数被C编译器编译后在库中的名字为_foo,而C++编译器则会产生像_foo_int_int之类的名字用来支持函数重载和类型安全连接。由于编译后的名字不同,C++程序不能直接调用C函数。C++提供了一个C连接交换指定符号extern“C”来解决这个问题。例如:
extern “C”
{
void foo(int x, int y);
… // 其它函数
}
或者写成
extern “C”
{
#include “myheader.h”
… // 其它C头文件
}
这就告诉C++编译译器,函数foo是个C连接,应该到库中找名字_foo而不是找_foo_int_int。C++编译器开发商已经对C标准库的头文件作了extern“C”处理,所以我们可以用#include 直接引用这些头文件。
注意并不是两个函数的名字相同就能构成重载。全局函数和类的成员函数同名不算重载,因为函数的作用域不同。例如:
void Print(…); // 全局函数
class A
{…
void Print(…); // 成员函数
}
不论两个Print函数的参数是否不同,如果类的某个成员函数要调用全局函数Print,为了与成员函数Print区别,全局函数被调用时应加‘::’标志。如
::Print(…); // 表示Print是全局函数而非成员函数
一句话,extern "C" 用到的地方:
1). c 库相关的头文件中,如 c.h 中(使 C++ 能调用 c库中函
数):
#ifdef __cplusplus
extern "C"{
#endif
...函数声明...
#ifdef __cplusplus
}
#endif
2). 有时候在 C++ 中,要调用 c 库中的函数 funcA()
extern "C"
{
funcA();
}
或
extern "C"
{
#include "c.h"
}
2. c库和 C++ 库的调用关系。
简单的说就是 C++ 可以调用 c 的, c 不能调用 C++ 的。
如:
1)g++ -o exe main.cpp myc.o/myc.a/myc.so
可以。 //main.cpp 要调用 myc 中的函数。注意 extern "C"
2)gcc -o exe main.c myc++.o/myc++.a/myc++.so
不行。 //main.c 要调用 myc++ 中的函数。
3)A: mylibc.o/mylibc.a/mylibc.so 中一函数为
FunC()
{
FunCplus();
}
B: mylibc++.o/mylibc++.a/mylibc++.so 中一函数为
FunCplus();
此时, main.cpp 调用 FunC ();
g++ -o exe main.cpp A B 也编译不过,道理和 2)差不多。
4)A: mylibc.o/mylibc.a/mylibc.so 中一函数为
int funC(int);
B: mylibc++.o/mylibc++.a/mylibc++.so 中一函数为
int funCplus(int)
此时, main.cpp 中有:
funC(funCplus(para));
funCplus(funC(para));
g++ -o exe main.cpp A B 可以编译成功并运行。
3.编译到目标的内容
(静态库)在编译可执行程序时,只有程序中确实用到的函数才会被包括进去,虽然一个头文件里包含着函数库中的全体函数声明,但在可执行程序中使用 include 语句引用,它并不会把整个函数库的内容都包括到可执行文件中去。
4.从 so 库封装 so 库。
已经有 libqt-mt.so.3.3.4(base.so),若 g++midlib.cpp 中调用了
libqt-mt.so.3.3.4(base.so) 中的函数,且又要被编译为一个共享库(so), main.cpp 调用该生成的新共享库。
1)g++ -shared -o libg++midlib.so g++midlib.cpp -I/root/QT/qt-x11-free-3.3.4/include /root/QT/qt-x11-free-3.3.4/lib/libqt-mt.so.3.3.4
g++ -o exe libg++midlib.so main.cpp -I/root/QT/qt-x11-free-3.3.4/inlucde
2) g++ -shared -o libg++midlib.so g++midlib.cpp -I/root/QT/qt-x11-free-3.3.4/include
g++ -o exe libg++midlib.so main.cpp -I/root/QT/qt-x11-free-3.3.4/include /root/QT/qt-x11-free-3.3.4/lib/libqt-mt.so.3.3.4
在这两种情况下生成的可执行文件 exe,都仅只需要有新生成的库 libg++midlib.so 就可以运行了。
2---4 运行的环境(估计其他的也差不多):
Linux localhost.localdomain 2.4.20-8 #1 Thu Mar 13 17:54:28 EST 2003 i686 i686 i386 GNU/Linux
[root@localhost bin]# gcc -v
Reading specs from /usr/lib/gcc-lib/i386-redhat-linux/3.2.2/specs
Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --enable-shared --enable-threads=posix --disable-checking --with-system-zlib --enable-__cxa_atexit --host=i386-redhat-linux
Thread model: posix
gcc version 3.2.2 20030222 (Red Hat Linux 3.2.2-5)
前面一部分是从 林锐博士 的《高质量 c/c++ 编程指南》里抄的,后面的都是自己写的。
呵呵,以前总是有些概念搞不清楚,所以就自己做了下实验,正好现在在看 《x86汇编语言与计算机体系结构》, 《linkers and loaders》, 《80x86保护模式系列教程》, 想把相关方面的东西再搞清楚些,呵呵。希望和各位多多交流,呵呵。
几个同名的重载函数仍然是不同的函数,它们是如何区分的呢?我们自然想到函数接口的两个要素:参数与返回值。
如果同名函数的参数不同(包括类型、顺序不同),那么容易区别出它们是不同的函数。
如果同名函数仅仅是返回值类型不同,有时可以区分,有时却不能。例如:
void Function(void);
int Function (void);
上述两个函数,第一个没有返回值,第二个的返回值是int类型。如果这样调用函数:
int x = Function ();
则可以判断出Function是第二个函数。问题是在C++/C程序中,我们可以忽略函数的返回值。在这种情况下,编译器和程序员都不知道哪个Function函数被调用。
所以只能靠参数而不能靠返回值类型的不同来区分重载函数。编译器根据参数为每个重载函数产生不同的内部标识符。例如编译器为示例8-1-1中的三个Eat函数产生象_eat_beef、_eat_fish、_eat_chicken之类的内部标识符(不同的编译器可能产生不同风格的内部标识符)。
如果C++程序要调用已经被编译后的C函数,该怎么办?
假设某个C函数的声明如下:
void foo(int x, int y);
该函数被C编译器编译后在库中的名字为_foo,而C++编译器则会产生像_foo_int_int之类的名字用来支持函数重载和类型安全连接。由于编译后的名字不同,C++程序不能直接调用C函数。C++提供了一个C连接交换指定符号extern“C”来解决这个问题。例如:
extern “C”
{
void foo(int x, int y);
… // 其它函数
}
或者写成
extern “C”
{
#include “myheader.h”
… // 其它C头文件
}
这就告诉C++编译译器,函数foo是个C连接,应该到库中找名字_foo而不是找_foo_int_int。C++编译器开发商已经对C标准库的头文件作了extern“C”处理,所以我们可以用#include 直接引用这些头文件。
注意并不是两个函数的名字相同就能构成重载。全局函数和类的成员函数同名不算重载,因为函数的作用域不同。例如:
void Print(…); // 全局函数
class A
{…
void Print(…); // 成员函数
}
不论两个Print函数的参数是否不同,如果类的某个成员函数要调用全局函数Print,为了与成员函数Print区别,全局函数被调用时应加‘::’标志。如
::Print(…); // 表示Print是全局函数而非成员函数
一句话,extern "C" 用到的地方:
1). c 库相关的头文件中,如 c.h 中(使 C++ 能调用 c库中函
数):
#ifdef __cplusplus
extern "C"{
#endif
...函数声明...
#ifdef __cplusplus
}
#endif
2). 有时候在 C++ 中,要调用 c 库中的函数 funcA()
extern "C"
{
funcA();
}
或
extern "C"
{
#include "c.h"
}
2. c库和 C++ 库的调用关系。
简单的说就是 C++ 可以调用 c 的, c 不能调用 C++ 的。
如:
1)g++ -o exe main.cpp myc.o/myc.a/myc.so
可以。 //main.cpp 要调用 myc 中的函数。注意 extern "C"
2)gcc -o exe main.c myc++.o/myc++.a/myc++.so
不行。 //main.c 要调用 myc++ 中的函数。
3)A: mylibc.o/mylibc.a/mylibc.so 中一函数为
FunC()
{
FunCplus();
}
B: mylibc++.o/mylibc++.a/mylibc++.so 中一函数为
FunCplus();
此时, main.cpp 调用 FunC ();
g++ -o exe main.cpp A B 也编译不过,道理和 2)差不多。
4)A: mylibc.o/mylibc.a/mylibc.so 中一函数为
int funC(int);
B: mylibc++.o/mylibc++.a/mylibc++.so 中一函数为
int funCplus(int)
此时, main.cpp 中有:
funC(funCplus(para));
funCplus(funC(para));
g++ -o exe main.cpp A B 可以编译成功并运行。
3.编译到目标的内容
(静态库)在编译可执行程序时,只有程序中确实用到的函数才会被包括进去,虽然一个头文件里包含着函数库中的全体函数声明,但在可执行程序中使用 include 语句引用,它并不会把整个函数库的内容都包括到可执行文件中去。
4.从 so 库封装 so 库。
已经有 libqt-mt.so.3.3.4(base.so),若 g++midlib.cpp 中调用了
libqt-mt.so.3.3.4(base.so) 中的函数,且又要被编译为一个共享库(so), main.cpp 调用该生成的新共享库。
1)g++ -shared -o libg++midlib.so g++midlib.cpp -I/root/QT/qt-x11-free-3.3.4/include /root/QT/qt-x11-free-3.3.4/lib/libqt-mt.so.3.3.4
g++ -o exe libg++midlib.so main.cpp -I/root/QT/qt-x11-free-3.3.4/inlucde
2) g++ -shared -o libg++midlib.so g++midlib.cpp -I/root/QT/qt-x11-free-3.3.4/include
g++ -o exe libg++midlib.so main.cpp -I/root/QT/qt-x11-free-3.3.4/include /root/QT/qt-x11-free-3.3.4/lib/libqt-mt.so.3.3.4
在这两种情况下生成的可执行文件 exe,都仅只需要有新生成的库 libg++midlib.so 就可以运行了。
2---4 运行的环境(估计其他的也差不多):
Linux localhost.localdomain 2.4.20-8 #1 Thu Mar 13 17:54:28 EST 2003 i686 i686 i386 GNU/Linux
[root@localhost bin]# gcc -v
Reading specs from /usr/lib/gcc-lib/i386-redhat-linux/3.2.2/specs
Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --enable-shared --enable-threads=posix --disable-checking --with-system-zlib --enable-__cxa_atexit --host=i386-redhat-linux
Thread model: posix
gcc version 3.2.2 20030222 (Red Hat Linux 3.2.2-5)
前面一部分是从 林锐博士 的《高质量 c/c++ 编程指南》里抄的,后面的都是自己写的。
呵呵,以前总是有些概念搞不清楚,所以就自己做了下实验,正好现在在看 《x86汇编语言与计算机体系结构》, 《linkers and loaders》, 《80x86保护模式系列教程》, 想把相关方面的东西再搞清楚些,呵呵。希望和各位多多交流,呵呵。
发表评论
-
[转载]strftime() 函数_时间格式
2011-01-12 11:21 1191[转载]strftime() 函数 (2007-12-06 1 ... -
fork函数
2011-01-11 13:23 916引用 在linux中,只有一 ... -
如何调试守护进程
2011-01-11 13:05 3213如何调试守护进程 我写 ... -
UNIX管道编程——使用pipe函数,dup函数,dup2函数
2011-01-11 10:02 51772009-12-29 11:46管道在unix ... -
c中的管道及复制描述符
2011-01-10 17:22 12381、 #include <stdio.h& ... -
如何在运行时确定对象类型(RTTI)
2011-01-10 11:45 943引用作者:NorthTibet RTTI 是“R ... -
string, char*, int类型转换 , c++强制转化
2011-01-10 10:04 16504一、 以下是常用的几种类型互相之间的转换 string 转 ... -
linux信号机制之sigaction结构体浅析
2011-01-10 00:27 1405linux 2009-02-20 16:47:00 阅读460 ... -
Linux下的管道编程技术-dup函数和dup2函数
2011-01-09 23:45 1150from [url]http://www.xxlinux.co ... -
Linux下使用C/C++访问数据库
2011-01-07 16:19 1342Linux下使用C/C++访问数据库——MySQL篇 ... -
多核分布式队列的实现:“偷”与“自私”的运用
2011-01-06 11:38 1062原创作品,允许转载, ... -
Boost和STL学习资料大全
2011-01-06 09:38 2638from http://blog.csdn.net/k2eat ... -
linux平台上编译安装boost库
2011-01-06 09:33 6739from http://dev.firnow.com/co ... -
C++多线程入门
2010-12-30 09:52 1249第1节 背景 为了更好 ... -
c++中__declspec用法总结
2010-12-29 17:47 1787c++中__declspec用法总结C++ ... -
__cplusplus的用处
2010-12-29 14:07 1063作者: Aprilgogo 发表日期: 2007-03-1 ... -
#ifdef __cplusplus深度剖析
2010-12-29 14:06 826时常在cpp的代码之中看 ... -
C和C++之间库的互相调用
2010-12-29 13:44 1056C和C++之间库的互相调用 昨晚有个朋友问我关于在C中调用C ... -
放在函数后面的const是什么意思?
2010-12-17 16:13 1458经常看到这样的定义: void f() const ... -
临时记录
2010-12-15 15:37 8091\ c开发包典型的名字是 glibc-devel-somet ...
相关推荐
- 在C++中调用C库的例子包括创建C动态库,使用gcc编译器的shared选项和lib选项将其编译为共享库,并使用extern "C"来告诉C++编译器后续的代码应按照C语言链接约定处理。 - 在C++程序中使用extern "C"来声明C库函数...
JNI允许Java代码和其他语言写的代码进行交互,包括调用C/C++编译的动态链接库(DLL)文件。下面将详细介绍如何使用JNI来调用DLL,并解释相关知识点。 1. **JNI简介** JNI是Java平台的标准部分,提供了一组接口,...
总之,C++调用MATLAB生成的DLL动态链接库是一个涉及多方面知识的过程,包括MATLAB的MEX接口、C++的动态链接、数据类型转换和内存管理等。通过熟练掌握这些技能,我们可以充分利用MATLAB的计算能力,同时利用C++的...
3. **C++动态库调用C动态库**:由于C语言的ABI(应用程序二进制接口)兼容性,C++代码可以直接调用C语言编写的DLL。只需确保C++函数声明遵循C语言的命名约定(通常是extern "C"),并且C语言的DLL导出函数不使用C++...
- **函数签名的一致性**:无论是C调用C++还是C++调用C,函数的参数类型和数量必须保持一致,否则会导致运行时错误。 - **动态链接库(DLL)**:在实际应用中,C和C++代码可能分别被打包成动态链接库(DLL),此时...
本主题关注的是如何在C#环境下调用由C++编写的DLL动态链接库,实现两者之间的交互。以下将详细解释这个过程的关键知识点。 1. **C#与C++互操作性**: C#(C Sharp)是.NET Framework的一部分,它是一种面向对象的...
在Java世界中,有时我们需要利用Java Native Interface (JNI) 和 Java Native Access (JNA) 这两种技术来调用C++编写的动态链接库(DLL或SO文件),以实现Java程序与底层系统的交互。这两者都是Java平台上的关键组件,...
然而,有时候为了利用已有的C或C++库,或者为了与这些语言进行互操作,C#开发者需要调用C和C++编写的动态链接库(DLL)。这个“C#调用C和C++动态库参数自动转换工具”就是为了帮助解决这个问题而设计的。下面将详细...
JavaScript调用C++通常依赖于一些库或框架,如Emscripten,它是一个LLVM到JavaScript的编译器,可以将C/C++代码编译成WebAssembly,然后在浏览器中运行。另一个常见的方式是使用ChakraCore,Microsoft的JavaScript...
9. **编写C语言调用程序**:在C语言程序中,包含C++库的C接口头文件,并使用`dlopen()`和`dlsym()`等动态链接函数来加载和调用库中的函数。 10. **编译和运行**:使用CMake生成Makefile,然后运行`make`命令编译...
有时我们需要在C#应用中调用C++编写的动态链接库(DLL),这涉及到跨语言互操作,也称为P/Invoke。本项目就是关于如何在C#中调用C++动态库,并通过回调机制让C++库能够调用C#中注册的函数。 首先,理解C#调用C++...
下面将详细解释与这个主题相关的C++知识点。 1. **函数调用**:在C++中,函数是一段可重用的代码块,可以接受输入参数(如果有的话),执行特定任务,并可能返回结果。函数调用是程序中一个函数被另一个函数或主...
在IT行业中,跨平台开发是常见...总之,C++调用Android函数工程涉及到的技术点包括JNI接口定义、C++代码实现、本地库构建以及在Java层的调用。理解这些知识点,能帮助开发者在Android应用中灵活运用C++,提升应用性能。
总之,C#调用C++动态库涉及的主要知识点包括:C++的`__declspec(dllexport)`导出、C#的`DllImport`特性、调用约定`CallingConvention`,以及可能的异常处理和COM互操作。通过理解这些概念,开发者可以有效地在两种...
标题 "C++调用java jar包测试代码" 描述了一个跨语言交互的场景,其中C++程序通过调用Java编译后的jar包来执行特定功能。这个过程涉及到多个技术点,包括Java的编译和打包,C++的编程以及两者之间的接口调用。 1. *...
知识点1:C++调用C#编写的dll的必要性 在实际开发中,C++和C#是两种不同的编程语言,C++是一种静态类型的语言,而C#是一种动态类型的语言。因此,当我们需要在C++代码中调用C#编写的dll时,需要使用一些特殊的技术...
在本技术文档中,我们将深入探讨如何利用Delphi来调用C++编写的DLL(动态...以上就是关于Delphi调用C++ DLL的相关知识点,希望能对您有所帮助。如果需要进一步了解具体的实现细节,建议参考相关的文档资料或实践案例。
标题 "PB调用C++DLL" 涉及的关键知识点主要是在PowerBuilder(PB)环境中如何与C++编写的动态链接库(DLL)进行交互。PowerBuilder是一种强大的客户端/服务器应用程序开发工具,而C++是一种功能丰富的编程语言,广泛...
C++高效获取函数调用堆栈 在程序设计和开发过程中,出现问题是很正常的。这时候,快速找到问题所在,并确定程序的上下文环境就变得非常重要。函数调用堆栈的信息对于解决问题具有很大的帮助。传统的方法是使用 ...
本主题将深入探讨如何在C#中调用C++编写的动态链接库(DLL),并传递复杂的数据类型,如指针和数组。我们将分析标题和描述中的关键知识点,并提供详细的步骤和示例。 首先,`C#调用C++动态库实例程序`表明我们需要...