C++调用Lua的性能測试
游戏服务器经典的架构就是C++和Lua的结合,C++开发主体框架。Lua实现一些复杂的逻辑。我们都知道Lua是一种很快的语言。可是究竟有多块。我们測试下看看。
C++调用Lua的性能測试。发现不正确的地方望提出。
实验一:我们使用C++调用Lua带8个以上參数的函数,而这个函数里面什么也没有做。我们通过这个实验能够简单地測试出:使用Lua虚拟机和向调用栈当中传入8+个參数和Lua取出这些參数的时间。
可是当中的參数类型比較多样。有整形。浮点型,和数组。实验的Lua函数比較简单,例如以下:
function test(x1,x2,x3,x4,x5,x6,x7,x8,x9)
end
实验结果:我们调用这个函数1000次所须要的时间在35ms左右,也就是说一次调用的时间在0.035ms左右
实验二:我们使用C++调用带有一个參数的Lua函数。通过和实验一的结果组成方程组能帮我们求出使用Lua虚拟机的时间和參数出入栈的时间。
当中Lua函数是很easy的例如以下:
function test(x1)
end
实验结果:我们调用这个函数1000次所须要的时间在16ms左右。也就是说一次调用的时间在0.016ms左右。
实验三:我们在实验二的函数中增加Lua调用C++的函数。这个函数在C++端也什么都不做,来測试Lua调用C++时入栈和出栈时候的时间。
函数简单例如以下:
function test(x1)
Chat(x1,x2,x3,x4,x5,x6,x7)
end
实验结果:我们发现其使用时间高于(实验二)15ms左右,预计。调用一次虚拟机的时间是14ms,參数的时间预计是1ms左右
实验四:我们在实验二的基础之上将其函数參数扩充到2个,我们观察其时间有没有小幅的变化。
函数例如以下:
function test(x1,x2)
end
实验结果:我们发现时间和实验二几乎相同,这也许能够反映出出入栈的时间是比較快的。申请比較大的栈内存也许会占用比較多的时间。
实验五:我们在实验二的基础上将函数的參数扩充到3个。我们发现其时间还是没有明显的变化。
函数例如以下:
function test(x1,x2。x3)
end
实验结果:能够反映出出入栈的时间是比較快的,申请比較大的栈内存也许会占用比較多的时间。
实验六:我将函数的參数扩展到7个,我们观察其时间是怎样变化的
函数例如以下:
function test(x1,x2,x3,x4,x5,x6,x7)
end
实验结果:发现去时间和实验五几乎相同。也许能够验证出入栈的时间是比較快的。申请比較大的栈内存也许会占用比較多的时间。
C++调用Lua的性能測试的更多相关文章
- JNI/NDK开发指南(九)——JNI调用性能測试及优化
转载请注明出处:http://blog.csdn.net/xyang81/article/details/44279725 在前面几章我们学习到了.在Java中声明一个native方法,然后生成本地接 ...
- Window平台搭建Redis分布式缓存集群 (一)server搭建及性能測试
百度定义:Redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对很多其它.包含string(字符串).list(链表).set(集合).zset(sort ...
- 系统吞吐量、TPS(QPS)、用户并发量、性能測试概念和公式
PS:以下是性能測试的主要概念和计算公式,记录下: 一.系统吞度量要素: 一个系统的吞度量(承压能力)与request对CPU的消耗.外部接口.IO等等紧密关联.单个reqeust 对CPU消耗越高, ...
- Linux 性能測试工具
Linux 性能測试工具 linux performance 查看系统配置 查看CPU信息 lscpu Architecture: x86_64 CPU op-mode(s): 32-bit, 64- ...
- Redis源代码分析(十三)--- redis-benchmark性能測试
今天讲的这个是用来给redis数据库做性能測试的,说到性能測试,感觉这必定是高大上的操作了.redis性能測试.測的究竟是哪方面的性能,怎样測试,通过什么指标反映此次測试的性能好坏呢.以下我通过源代码 ...
- Android性能測试 一些适用于Android Studio的代码审查和性能測试工具
导言: Android应用在CPU占用,内存消耗方面的性能指标是影响产品质量的重要因素,因为QQ管家,360手机助手等应用都提供直观的内存消耗,流量监控功能,致使用户比以往更加关注软件的性能,并以此进 ...
- mongodb3.0 性能測试报告 一
mongodb3.0 性能測试报告 一 mongodb3.0 性能測试报告 二 mongodb3.0 性能測试报告 三 測试环境: 服务器:X86 pcserver 共6台 cpu: 单颗8核 ...
- mysql主键设置成auto_increment时,进行并发性能測试出现主键反复Duplicate entry 'xxx' for key 'PRIMARY'
mysql主键设置成auto_increment时,进行并发性能測试出现主键反复Duplicate entry 'xxx' for key 'PRIMARY' 解决方法: 在my.cnf的[mysql ...
- LR杂记 - 性能測试指标及经常使用的监控工具
监控指标 性能測试通常须要监控的指标包含: 1.serverLinux(包含CPU.Memory.Load.I/O). 2.数据库:1.Mysql 2.Oracle(缓存命中.索引.单条SQL性能.数 ...
随机推荐
- VP相关
1.485模块电平,如果是集成的IC模块,则发送低电平,接收高电平: 2.阀门程序移植至PLC注意事项: 1) 阀门程序中的变量厘清,移植过程中阀门程序中的模块有些用到了,有些没用到,所以这是变量也很 ...
- ActiveMQ学习笔记(15)----Message Dispatch高级特性(一)
1. Message Cursors 1.1 概述 ActiveMQ发送持久化消息的典型的厝里方式是:当消息的消费者准备就绪时,消息发送系统把存储的消息按批次发送给消费者,在发送完一个批次的消息后,指 ...
- [BeiJing2006]狼抓兔子 dijkstra+平面图最小割
一眼裸的最大流求最小割,然而数据范围过大,跑不下来. 我们可以将平面图转成对偶图,并进行连边. 这样,每条边的长度就对应原图中的割边长度. 起点到终点的最短路即为最小割. 别用SPFA,会死的很惨 C ...
- 路飞学城Python-Day9(practise)
def save(): with open('practise_4', 'w+', encoding='utf-8') as f: for i in user_list: info = str(i) ...
- NodeJS学习笔记 (1)资源压缩-zlib(ok)
原文: https://github.com/chyingp/nodejs-learning-guide/blob/master/README.md 自己的跟进学习: 概览 做过web性能优化的同学, ...
- 关于 Error: No PostCSS Config found in 的错误
问题描述: 项目在本地运行不报错,上传到 GitHub 之后,再 clone 到本地, npm install 安装完成之后再执行 npm run dev 这时报错 Error: No PostCSS ...
- HNU 13108 Just Another Knapsack Problem DP + Trie树优化
题意: 给你一个文本串,和一些模式串,每个模式串都有一个价值,让你选一些模式串来组成文本串,使获得的价值最大.每个模式串不止能用一次. 思路: 多重背包,枚举文本串的每个位置和模式串,把该模式串拼接在 ...
- 榨取kkksc03 luogu1855 dp 裸二维费用背包
首先对于这个题目背景,,个人认为很(you)好(qu),,, 核心就是一个裸的二维费用背包,刚刚学习的同学参见dd大牛的背包九讲 #include <cstdio> #include &l ...
- Leetcode-Best Time to Buy and Sell Stock -java
题目: Say you have an array for which the ith element is the price of a given stock on day i. If you w ...
- [Servlet&JSP] HttpSession会话管理
我们能够将会话期间必须共享的资料保存在HttpSession中,使之成为属性.假设用户关掉浏览器接受Cookie的功能.HttpSession也能够改用URL重写的方式继续其会话管理功能. HttpS ...