- 浏览: 570640 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (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 1164[转载]strftime() 函数 (2007-12-06 1 ... -
fork函数
2011-01-11 13:23 877引用 在linux中,只有一 ... -
如何调试守护进程
2011-01-11 13:05 3167如何调试守护进程 我写 ... -
UNIX管道编程——使用pipe函数,dup函数,dup2函数
2011-01-11 10:02 51352009-12-29 11:46管道在unix ... -
c中的管道及复制描述符
2011-01-10 17:22 12091、 #include <stdio.h& ... -
如何在运行时确定对象类型(RTTI)
2011-01-10 11:45 904引用作者:NorthTibet RTTI 是“R ... -
string, char*, int类型转换 , c++强制转化
2011-01-10 10:04 16428一、 以下是常用的几种类型互相之间的转换 string 转 ... -
linux信号机制之sigaction结构体浅析
2011-01-10 00:27 1366linux 2009-02-20 16:47:00 阅读460 ... -
Linux下的管道编程技术-dup函数和dup2函数
2011-01-09 23:45 1112from [url]http://www.xxlinux.co ... -
Linux下使用C/C++访问数据库
2011-01-07 16:19 1311Linux下使用C/C++访问数据库——MySQL篇 ... -
多核分布式队列的实现:“偷”与“自私”的运用
2011-01-06 11:38 1025原创作品,允许转载, ... -
Boost和STL学习资料大全
2011-01-06 09:38 2605from http://blog.csdn.net/k2eat ... -
linux平台上编译安装boost库
2011-01-06 09:33 6698from http://dev.firnow.com/co ... -
C++多线程入门
2010-12-30 09:52 1221第1节 背景 为了更好 ... -
c++中__declspec用法总结
2010-12-29 17:47 1754c++中__declspec用法总结C++ ... -
__cplusplus的用处
2010-12-29 14:07 1030作者: Aprilgogo 发表日期: 2007-03-1 ... -
#ifdef __cplusplus深度剖析
2010-12-29 14:06 793时常在cpp的代码之中看 ... -
C和C++之间库的互相调用
2010-12-29 13:44 1019C和C++之间库的互相调用 昨晚有个朋友问我关于在C中调用C ... -
放在函数后面的const是什么意思?
2010-12-17 16:13 1382经常看到这样的定义: void f() const ... -
临时记录
2010-12-15 15:37 7561\ c开发包典型的名字是 glibc-devel-somet ...
相关推荐
Visual C++ 知识库电子书 VC 知识库文章 VC 知识库Faqs VC 知识库Tips VC++5.0是Microsoft新近推出的可视化C++集成开发环境。它在继承以前VC++的基础上增加了许多新的功能,用于支持Win32平台应用程序、服务...
Matlab程序设计初步、Matlab编译器、Matlab与C语言的接口、生成可独立运行的Matlab程序、VisualC++调用Matlab程序、Matlab DotNetBuilder与Visual C++、Matcom与C/C++以及Visual C++调用Matlab C++数学库。...
通过头文件可能方便地调用库功能,而不必关心其实现方式 三、* , &修饰符的位置 对于*和&修饰符,为了避免误解,最好将修饰符紧靠变量名 四、if语句 不要将布尔变量与任何值进行比较,那会很容易出错的。...
同时要学习C++图形库相关的知识,也可以点击我的主页,找到EasyX专栏进行图形库的学习。 值得注意的是,在使用本算法时需要调用drawImg()函数,参数为:drawImg(图片左上角坐标X,图片左上角坐标y,&加载过后的图片...
Python 提供了 C++ 库,使得开发者能很方便地从 C++ 程序中调用 Python 模块。接下来通过本文给大家介绍 C++ 调用 Python 模块的相关知识,需要的朋友参考下吧
1.c++虚函数原理 作用:C++中的虚函数的作用主要是实现了多态的机制。当基类中的成员函数定义了虚函数,其子类可以重新改写该函数。也即是允许派生类调用父类的同名函数而实现不同的功能,也叫动态联编。在主函数...
4.在Visual C++集成环境下,能够编写简单的C 程序,并具有基本的纠错和调试程序的能力。 2 考试内容 一、C语言程序的结构 1.程序的构成,main函数和其他函数。 2.头文件,数据说明,函数的开始和结束标志...
cocos2d-x 通过JNI实现c/c++和Android的java层函数互调, 本文主要实现两个功能: (1)通过Android... 首先来简单学习一下JNI的相关知识,我这篇文章中简单实现了怎么在Android Java层调用c++函数。要想使用JNI,必须得…
1.1 什么是C语言和C++ 1.1.1 C和C++历史回顾 1.1.2 C/C++是一门编译语言 1.1.3 为什么许多程序员都选择C++ 1.2 什么是面向对象 1.2.1 C++程序并不一定是面向对象的 1.2.2 一个简单的面向对象程序示例 1.2.3 面向...
1、 C++对C的扩展 1 1简单的C++程序 1 1.1求圆的周长和面积 1 1.2初学者易犯错误模型 3 2程序设计方法的发展历程 4 3 C语言和C++语言关系 6 4 C++对C的加强 6 4.1 namespace命名空间 6 4.2 “实用性”增加 6 4.3 ...
13.7 C库文件 208 13.8 本章小结 第1篇 基本知识 第1章 C++的初步知识 *1.1 从C到C++ *1.2 最简单的C++程序 1.3 C++程序的构成和书写形式 1.4 C++程序的编写和实现 1.5 关于C++上机实践 习题 第2章 ...
08_C语言和C++语言的关系_工作经验分享 09_namespace和iotream 10_实用性加强_register增强_检测增强 11_struct关键字类型增强 12_c++类型类型检查加强 13_新增数据类型bool类型14_中午课程回顾 15_c++中的三目...
设计原则 从c到c++相关知识 实例研究 basic 相关函数的调用方法
绘图是现代人学习、工作中的不可缺少的一项,人们在工作学习中常常需要绘制一些图形,虽然在一些文档工具中可以实现图形绘制,但往往比较麻烦,并且不易学习,一般没学过相关知识的人是不会运用文档工具中的功能去...
【原书名】 C++ Primer (4th Edition) 【原出版社】 Addison Wesley/Pearson 【作者】 (美)Stanley B.Lippman,Josée LaJoie,Barbara E.Moo 【译者】 李师贤 蒋爱军 梅晓勇 林瑛 【丛书名】 图灵计算机科学丛书 ...
本书以流行的面试题讲解为主要内容,介绍了C、C++语言基本概念,包括保留字、字符串、指针和引用、结构体、库函数等各个方面的基础知识,介绍了面向对象编程基本概念,包括如何实现继承、多态和封装等。还介绍了排序...
13.7 C库文件 208 13.8 本章小结 第1篇 基本知识 第1章 C++的初步知识 *1.1 从C到C++ *1.2 最简单的C++程序 1.3 C++程序的构成和书写形式 1.4 C++程序的编写和实现 1.5 关于C++上机实践 习题 第2章 ...
1.1 什么是C语言和C++ 1.1.1 C和C++历史回顾 1.1.2 C/C++是一门编译语言 1.1.3 为什么许多程序员都选择C++ 1.2 什么是面向对象 1.2.1 C++程序并不一定是面向对象的 1.2.2 一个简单的面向对象程序示例 1.2.3 面向对象...