为了更加直观的比较,好吧,我们选择以对象的初始化并add到list为例子。

首先,定义object如下:

#include <string>
#pragma once
using namespace std;
class FirstCPPCls
{ private:
string serviceId;
string systemId;
string subSystemId;
string appVersion;
string companyId;
string clusterName; public:
FirstCPPCls(void);
~FirstCPPCls(void);
inline string getServiceId() { return serviceId;}
inline string getSystemId() { return systemId;}
inline string getSubSystemId() { return subSystemId;}
inline string getAppVersion() { return appVersion;}
inline string getCompanyId() { return companyId;}
inline string getClusterName() { return clusterName;} inline void setServiceId(string v) { serviceId = v;}
inline void setSystemId(string v) { systemId = v;}
inline void setSubSystemId(string v) { subSystemId = v;}
inline void setAppVersion(string v) { appVersion = v;}
inline void setCompanyId(string v) { companyId = v;}
inline void setClusterName(string v) { clusterName = v;}
}

测试代码:

    // 对象创建时间比较
DWORD begin = GetTickCount();
int f;
vector<FirstCPPCls*> vO;
for(i=;i<;i++) {
FirstCPPCls clz;
clz.setAppVersion("12.32.33");
clz.setClusterName("osm-service");
clz.setCompanyId("");
clz.setServiceId("sysL.1.223");
clz.setSubSystemId("");
clz.setSystemId("");
vO.push_back(&clz);
}
cout << vO.size() << endl;
DWORD end = GetTickCount(); // 打印时间差
cout << (end - begin) << endl; // 平均4800豪秒左右
system("pause");

java:

    public static void main(String[] args) {
List<RouteItem> routeItems = new ArrayList<RouteItem>();
System.out.println(System.currentTimeMillis());
for(int i=0;i<100000;i++) {
RouteItem clz = new RouteItem();
clz.setAppVersion("12.32.33");
clz.setClusterName("osm-service");
clz.setCompanyId("239383");
clz.setServiceId("sysL.1.223");
clz.setSubSystemId("23");
clz.setSystemId("32");
routeItems.add(clz);
}
System.out.println(routeItems.size());
System.out.println(System.currentTimeMillis());
// 平均15ms左右
}

好吧,cpp换成char*指针:

#include <string>
#pragma once
using namespace std;
class FirstCPPCls
{
private:
char* serviceId;
char* systemId;
char* subSystemId;
char* appVersion;
char* companyId;
char* clusterName; public:
FirstCPPCls(void);
~FirstCPPCls(void);
inline char* getServiceId() { return serviceId;}
inline char* getSystemId() { return systemId;}
inline char* getSubSystemId() { return subSystemId;}
inline char* getAppVersion() { return appVersion;}
inline char* getCompanyId() { return companyId;}
inline char* getClusterName() { return clusterName;} inline void setServiceId(char* v) { serviceId = v;}
inline void setSystemId(char* v) { systemId = v;}
inline void setSubSystemId(char* v) { subSystemId = v;}
inline void setAppVersion(char* v) { appVersion = v;}
inline void setCompanyId(char* v) { companyId = v;}
inline void setClusterName(char* v) { clusterName = v;} };

再测试,平均大约为46ms。还是比java慢啊。

再看大量代码中会用到的char[],如下:

#include <string>
#pragma once
using namespace std;
class FirstCPPCls
{
private:
char serviceId[];
char systemId[];
char subSystemId[];
char appVersion[];
char companyId[];
char clusterName[]; public:
FirstCPPCls(void);
~FirstCPPCls(void);
inline char* getServiceId() { return serviceId;}
inline char* getSystemId() { return systemId;}
inline char* getSubSystemId() { return subSystemId;}
inline char* getAppVersion() { return appVersion;}
inline char* getCompanyId() { return companyId;}
inline char* getClusterName() { return clusterName;} inline void setServiceId(char* v) {
memset(serviceId,,);
memcpy(serviceId,v,strlen(v));
}
inline void setSystemId(char* v) {
memset(systemId,,);
memcpy(systemId,v,strlen(v));
}
inline void setSubSystemId(char* v) {
memset(subSystemId,,);
memcpy(subSystemId,v,strlen(v));
}
inline void setAppVersion(char* v) {
memset(appVersion,,);
memcpy(appVersion,v,strlen(v));
}
inline void setCompanyId(char* v) {
memset(companyId,,);
memcpy(companyId,v,strlen(v));
}
inline void setClusterName(char* v) {
memset(clusterName,,);
memcpy(clusterName,v,strlen(v));
}
};

再测试,平均大约为62ms。还是比java慢啊,大部分情况下,处于可读性的考虑,应该使用第三种。

后面测试了vector、map之后,发现主要是cpp默认是value拷贝(简单地说可以认为java中的clone实现吧,当然细节相差还是很大的,尚且这么认为吧)的原因。使用指针后,内容复制消除了很多。

回到java,应该来说发展到jdk 6之后,虽然开发都用object,但是JVM内部将非primitive类型的所有对象都自动转换为指针操作了,而cpp因为要兼容早期的原因,不得不保留传统的机制。

注:上述测试是在msvc下测试的,换成gcc之后,string的速度可能会比char *要快,参考http://tieba.baidu.com/p/1038620654,大家可以进行测试。

c++性能之对象与指针性能比较、以及java与c++性能对比实测的更多相关文章

  1. Java-Runoob-高级教程-实例-字符串:11. Java 实例 - 字符串性能比较测试

    ylbtech-Java-Runoob-高级教程-实例-字符串:11. Java 实例 - 字符串性能比较测试 1.返回顶部 1. Java 实例 - 字符串性能比较测试  Java 实例 以下实例演 ...

  2. 使用 W3C Performance 对象通过 R 和 JavaScript 将浏览器内的性能数据可视化[转]

    当考虑 Web 性能指标时,需要关注的目标数字应该是从您自己的用户那里获得的实际用户指标.最常见的方法是利用 Splunk 之类的工具来分析您的机器数据,该工具支持您分析和可视化您的访问权限和错误日志 ...

  3. 转:STL容器里存放对象还是指针

    一.问题的引出: 容器可以存放对象,可以存放指针,这里要谈的是两者的使用问题.就是什么时候存放对象更好,什么时候存放指针更好? 二.问题的分析过程: 1. 首先说下stl容器的工作方式   对于内建类 ...

  4. 如何利用缓存机制实现JAVA类反射性能提升30倍

    一次性能提高30倍的JAVA类反射性能优化实践 文章来源:宜信技术学院 & 宜信支付结算团队技术分享第4期-支付结算部支付研发团队高级工程师陶红<JAVA类反射技术&优化> ...

  5. JVM常用命令和性能调优建议 [Could not create the Java virtual machine]

    一.查看jvm常用命令jinfo:可以输出并修改运行时的java 进程的opts. jps:与unix上的ps类似,用来显示本地的java进程,可以查看本地运行着几个java程序,并显示他们的进程号. ...

  6. jvm 命令使用调优 通过jstat、jmap对java程序进行性能调优

    转载:http://blog.csdn.net/jerry024/article/details/8507589 转载: https://blog.csdn.net/zhaozheng7758/art ...

  7. 在 NetBeans IDE 6.0 中分析 Java 应用程序性能

    NetBeans IDE 6.0 包含一个强大的性能分析工具,可提供与应用程序运行时行为有关的重要信息.通过 NetBeans 性能分析工具,我们可以方便地在 IDE 中监控应用程序的线程状态.CPU ...

  8. lua、groovy嵌入到java中的性能对比(转)

    lua和groovy都是可以嵌入到java中的脚本语言.lua以高性能著称,与C/C++在游戏开放中有较多使用,groovy是一个基于Java虚拟机(JVM)的敏捷动态语言,在jvm下有着不错的性能. ...

  9. java反射之-性能优化

    在最近的计划中,打算看看在不使用google protobuf的情况下,在原有的采用jackson作为json序列化工具的基础上,是否可以实现进一步的性能优化.主要是针对list的情况. 测试的时候选 ...

随机推荐

  1. .NET程序运行过程

    ASP.NET http请求 - IIS - isapi.dll - CLR(com服务通信初始化CLR - AppDomain - 加载程序集 - JIT译 - 本地机器码 - 内存 - CPU 执 ...

  2. 一次使用Python连接数据库生成二维码并安装为windows服务的工作任务

    最近有一个需求,在现有生产系统上的人员库中增加一个此人员关键信息的二维码,支持文字版和跳转版两种方式,与报表工具关联,可打印.以windows服务方式,定时检查,只要发现某人员没有此二维码信息,就生成 ...

  3. POJ 1149 - PIGS - [最大流构图]

    Time Limit: 1000MS Memory Limit: 10000K Description Mirko works on a pig farm that consists of M loc ...

  4. Spyer中添加一些常用包的方法

    我用的是Anaconda中的Spyer编译,在导入包pyaudio时,发现找不到,需要手工导入.可以打开Anacoda promt,查看已经安装的包名用:pip list Spyer中的所有包在这里安 ...

  5. FMOD变声如何捕获并存储处理音效之后的数据

    类似AVAudioEngine的功能,一个Engine可以将N个connect连接(串联和并联)在一起,这样来实现多个输入源,多层处理效果的混合输出.实现这个所需功能也是通过这样的方案来实现的.也就是 ...

  6. 正则表达式(二):Unicode诸问题上篇(转)

    原文:http://www.infoq.com/cn/news/2011/02/regular-expressions-unicode 关于正则表达式的文档很多,但大部分都是英文的,即便有中文的文档, ...

  7. windows底下怎么让cmder通过输入subl去打开sublime text

    在window自身的cmd或者你安装的cmder中输入 doskey subl="D:\Program Files\sublime3\Sublime Text 3\sublime_text. ...

  8. 看懂Oracle执行计划、表连接方式

    看懂Oracle执行计划  原文:https://www.cnblogs.com/Dreamer-1/p/6076440.html 最近一直在跟Oracle打交道,从最初的一脸懵逼到现在的略有所知,也 ...

  9. android 6.0之后动态获取权限

    Android 6.0 动态权限申请   1. 概述 Android 6.0 (API 23) 之前应用的权限在安装时全部授予,运行时应用不再需要询问用户.在 Android 6.0 或更高版本对权限 ...

  10. 你知道Windows和WordPress上帝模式吗?

    一.Windows 上帝模式 这个玩意出来很久很久了,估计不用多说,知道的同学还是挺多的,不知道的也只要百度一下,你就知道了. 方法很简单,在 Windows 系统任何地方新建一个文件夹,如下命名即可 ...