c/c++语言开发共享为什么第一次运行C程序,运行速度慢10倍

使用排序的我的C程序第一次运行速度比其他时间慢10倍。 它使用整数文件进行排序,即使我更改数字,程序仍然运行得更快。 当我重新启动PC时,第一次程序运行速度慢了10倍。 我用time来计算时间。

    操作系统将数据保存在RAM中,即使它不再需要(这称为“缓存”),因此当程序再次运行时,它从那里获取所有数据,并且没有磁盘I / O. 即使您更改数据,该更改也会先在RAM中发生,并且即使在写入文件后也会保留在RAM中。

    但是,它不会永远停留在RAM中,请注意。 如果其他内容需要内存,则删除缓存。 此时,需要磁盘访问(此时它再次缓存在RAM中。)

    这就是重启后首次访问总是很慢的原因; 数据尚未缓存,因为它从未从文件中读取过。

    你必须做出假设并将它们面对现实。 你可以合理地做的第一个是它确实闻起来很像缓存问题!

    问自己这些问题:

    好吧,它可能是也可能不是其中之一,但它不会伤害尝试:)

    这不是什么新鲜事,不只是你的程序很多流行的商业软件都面临这个问题。

    首先检查一下关于慢拳时间执行的MATLAB文章

    对于在C#或Java等虚拟机上运行的其他编程语言,这种情况非常普遍。

    缓存是在C中发生这种情况的一个很好的理由,但仍然是10倍的持续时间很长。重启后系统可能还在加载其他资源。

    重启后10分钟后应该运行程序以获得更好的结果。 到那时,所有启动应用程序都将被加载。 (10分钟—-取决于启动应用程序的数量和启动它们所需的时间)

    如果您的程序进行网络访问,则可能是初始延迟的原因。 许多网络协议需要时间来设置。 一些例子:

    从这里你可以使用一些低级别的跟踪工具来查看花费的时间。 在linux上一个基本的工具是strace -r 。 其他系统可能有一些类似的工具。 您的编译器还必须附带一个分析器(即GCC或Ggrof)。

    这是因为编译器的优化,它的作用是缓存Temoparal Locality的结果并保存激活记录,也节省了时间,因为在链接阶段必须重新加载绑定对象

    测量时间有两个组成部分

    如果您正在从磁盘读取文件,并将其加载到内存中 – 并进行排序:

    1)读取文件并将其存储在数组中的时间2)排序时间

    这些是分开测量的吗?

    你能看看吗? 使Linux缓冲区高速缓存无效

    如果重复实验并清除缓存会产生相同的结果,那么您可以推断出文件缓冲区缓存效果没有被考虑在内,而不是重新启动。

      以上就是c/c++开发分享为什么第一次运行C程序,运行速度慢10倍相关内容,想了解更多C/C++开发(异常处理)及C/C++游戏开发关注计算机技术网(www.ctvol.com)!)。

      本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

      ctvol管理联系方式QQ:251552304

      本文章地址:https://www.ctvol.com/c-cdevelopment/565170.html

      (0)
      上一篇 2021年2月15日
      下一篇 2021年2月15日

      精彩推荐