为了更加直观的比较,好吧,我们选择以对象的初始化并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++性能对比实测的更多相关文章
-
Java-Runoob-高级教程-实例-字符串:11. Java 实例 - 字符串性能比较测试
ylbtech-Java-Runoob-高级教程-实例-字符串:11. Java 实例 - 字符串性能比较测试 1.返回顶部 1. Java 实例 - 字符串性能比较测试 Java 实例 以下实例演 ...
-
使用 W3C Performance 对象通过 R 和 JavaScript 将浏览器内的性能数据可视化[转]
当考虑 Web 性能指标时,需要关注的目标数字应该是从您自己的用户那里获得的实际用户指标.最常见的方法是利用 Splunk 之类的工具来分析您的机器数据,该工具支持您分析和可视化您的访问权限和错误日志 ...
-
转:STL容器里存放对象还是指针
一.问题的引出: 容器可以存放对象,可以存放指针,这里要谈的是两者的使用问题.就是什么时候存放对象更好,什么时候存放指针更好? 二.问题的分析过程: 1. 首先说下stl容器的工作方式 对于内建类 ...
-
如何利用缓存机制实现JAVA类反射性能提升30倍
一次性能提高30倍的JAVA类反射性能优化实践 文章来源:宜信技术学院 & 宜信支付结算团队技术分享第4期-支付结算部支付研发团队高级工程师陶红<JAVA类反射技术&优化> ...
-
JVM常用命令和性能调优建议 [Could not create the Java virtual machine]
一.查看jvm常用命令jinfo:可以输出并修改运行时的java 进程的opts. jps:与unix上的ps类似,用来显示本地的java进程,可以查看本地运行着几个java程序,并显示他们的进程号. ...
-
jvm 命令使用调优 通过jstat、jmap对java程序进行性能调优
转载:http://blog.csdn.net/jerry024/article/details/8507589 转载: https://blog.csdn.net/zhaozheng7758/art ...
-
在 NetBeans IDE 6.0 中分析 Java 应用程序性能
NetBeans IDE 6.0 包含一个强大的性能分析工具,可提供与应用程序运行时行为有关的重要信息.通过 NetBeans 性能分析工具,我们可以方便地在 IDE 中监控应用程序的线程状态.CPU ...
-
lua、groovy嵌入到java中的性能对比(转)
lua和groovy都是可以嵌入到java中的脚本语言.lua以高性能著称,与C/C++在游戏开放中有较多使用,groovy是一个基于Java虚拟机(JVM)的敏捷动态语言,在jvm下有着不错的性能. ...
-
java反射之-性能优化
在最近的计划中,打算看看在不使用google protobuf的情况下,在原有的采用jackson作为json序列化工具的基础上,是否可以实现进一步的性能优化.主要是针对list的情况. 测试的时候选 ...
随机推荐
-
zabbix监控tomcat
服务端配置修改 编译zabbix的时候需要添加参数--enable-java --enable-java 修改zabbix_java配置文件 vim /usr/local/zabbix-2.4.6/s ...
-
【转载】 IE/Firefox每次刷新时自动检查网页更新,无需手动清空缓存的设置方法
[参考了别人的文章]我们做技术,经常在写页面的时候需要多次刷新测试,可是浏览器都有自己的 缓存机制,一般CSS和图片都会被缓存在本地,这样我们修改的CSS就看不到效果 了,每次都去清空缓存,再刷新看效 ...
-
如何使用 Migration创建一个迁移
切换到YII所在的目录 yii migrate/create test
-
c 转置字符串You are a so cheap man ->;man cheap so a are You
解题思路: 1.将字符串转置 2.对转置后的字符串中单词转置 #include<stdio.h> #include<string.h> #include<stdlib.h ...
-
网络获取数据的Xml的Pull解析
网络获取的XML的Pull解析 <?xml version="1.0" encoding="utf-8" ?> - <students> ...
-
pip安装问题
一,安装pyecharts 出现问题的2个提示 failed to import pyecharts_snapshot 成功解决 第一个升级问题 you are using pip version ...
-
postgresql数据库查询慢SQL
--查询总耗时最长SQLselect * from pg_stat_statements order by total_time desc;--查询平均耗时最长SQLselect * from pg_ ...
-
JMeter上架标的(yyb-csg)
yyb-csg 1.登录时一直提示用户名不能为空,可是明明已经传值了呀 解决:添加cookie管理器 2.怎么获取到待受理的项目, 在python脚本的实现过程中发现,在平台受理一步中传的lid值就是 ...
-
iScroll.js插件使用方法
iScroll.js 用法参考 (share) 分享是传播.学习知识最好的方法 以下这篇文章是iScroll.js官网的中文翻译,尽管自己英文不好,但觉得原作者们翻译的这个资料还是可以的,基本用法介绍 ...
-
VS自带的dbghelp.h文件 报错
场景: 编译报错: 解决方法: 在#include <dbghelp.h> 之前 #include <Windows.h>