为了测试出来一个准确的值,程把来自之前加到电脑上的系统30G内存给下掉了,新得到的5G内存他还没有分配。
之前加了这些内存之后,启动程度快了不少,但是编译速度提升的不是特别明显,程想只用系统本身的一些资源来看看这个优化能到什么程度。
之前程记得打开这个软件需要6秒,后来用了系统给的内存之后,打开软件和项目的时间平均用时缩短到了2秒。
再之后,用上更多的内存并不见有什么效果,程感觉可能是这个软件用不了太多的内存,再多的内存也不可能让他的速度再提升,除非是预先把要加载的项目都加到内存中。
但是这有一个问题,这个软件又不知道你要提前加载哪个项目,再说了,浪费那个内存还不如把内存用到其它更实用的地方。
毕竟打开项目这个操作又不是经常性的,只是在开发的时候单次的,一天可能就打开一次,甚至全职的mac软件开发人员可能这个软件打开后就一直不关闭,可能是基于这个考虑,他们没有怎么去优化这个打开速度吧。
不过程觉得他们可能是优化不了。
这一次程再次试了下这个软件的打开速度,重启了一次电脑,来了一次冷启动。
程怀疑自己看错了,因为在他点击那个软件的瞬间,就已经启动了。
应该用时不到一秒,什么时间这样大的软件启动的速度也可以这么快了。
程感觉到不可思议。
接着他打开了一个项目,也是秒开。
amazing,unbevabe
程看了下面的状态栏,确实没有正在进行的操作,这说明这个是真的完全打开了。
之前他也试过,有的软件是ui快速打开,还有在后台跑的任务去建立索引什么的。
你看件的内容是没有什么问题的,但是在开发中,有的时候会根据一个方法名字中转到他的定义,有时跳转会有问题。
这就是因为软件还没有完全把这个项目加载全,只是把他的本地的目录给加过来了。
再试了一下编译,也是一秒就好了。
快的让程都产生了一个错觉,他怀疑自己是不是写错了什么东西。
因为以往的经验告诉他,如果一个软件平时运行的编译的很长时间,突然有\b一次编译特别快,通常情况下,是编译有错,或者是代码和之前大不一样了,比如只有一行,不需要花费那么长的时间了。
但是他新建了一个脑图,发现他的脑图可能建立成功,也能保存,也能打开之前保存的。
程又看了看这个软件,发现他的功能还是那些功能,并没有多也没有少。
这个优化应该\b只是优化现有的功能,把慢的地方给加快了,需要吃很多资源的地方给优化的不需要那么多的资源了。
“这个很不错,不过,能不能给其它人用呢?”程有了这个想法之后,就把整个软件的目录打了个包。
然后转给了陆丹雪一份,让她试验了一下,果然在她那里也是秒开。
不过之所以能这么搞,也是因为mac电脑上的软件隔离的比较好,涉及到的所有件都在是一起的。
程有一个想法,他想把这个优化之后的软件发给苹果公司的人。