为了更加直观的比较,好吧,我们选择以对象的初始化并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. python3学习笔记(3)_dict-set

    # !/usr/bin/env python3 # -*- coding:utf8 -*- #dict 和 set #dict dictionary 用于存放 键值对的, 无序,key 不可变 #姓名 ...

  2. SQL SERVER 事务执行情况跟踪分析

    [sql] view plain copy ---查看现在所有的事务 select '正在运行事务的会话的 ID'=session_id, --session_id与transaction_id的对应 ...

  3. 群用户通过微信小程序可以更好地协作了

    今天,小程序向开发者开放了群ID的接口能力.简单地说,就是当你把小程序分享在群聊中,被点击后开发者可获取群ID和群名称,也方便更好地针对群场景提供个性化服务.不同的群有各自的群ID,那么这个新能力开发 ...

  4. ul li剧中对齐

    html: <div class="footernav"> <ul> <li>首页</li> <li>文章</li ...

  5. python的时间差计算

    import time start = time.clock() #当中是你的程序 elapsed = (time.clock() - start) print("Time used:&qu ...

  6. vue学习六之vuex

    由于状态零散地分布在许多组件和组件之间的交互中,大型应用复杂度也经常逐渐增长.为了解决这个问题,Vue 提供 vuex. 什么是Vuex Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 ...

  7. [LeetCode] 690. Employee Importance_Easy tag: BFS

    You are given a data structure of employee information, which includes the employee's unique id, his ...

  8. HTTP 头和 PHP header() 函数

    http://unifreak.github.io/translation/Http_headers_and_PHP_header()_function 引言 许多初级到中级的的 PHP 程序员把 h ...

  9. Integer类之equals与hashCode

    一.源码. 1.equals源码.可以看出,比较的是两者的类型相同且内容相同.即是否有相等的int类型的value值. ######################################## ...

  10. 混合高斯模型(Mixtures of Gaussians)

    http://www.cnblogs.com/jerrylead/archive/2011/04/06/2006924.html 这篇讨论使用期望最大化算法(Expectation-Maximizat ...