Labfans是一个针对大学生、工程师和科研工作者的技术社区。 | 论坛首页 | 联系我们(Contact Us) |
![]() |
![]() |
#1 |
高级会员
注册日期: 2019-11-21
帖子: 3,006
声望力: 66 ![]() |
![]()
在MATLAB中管理大量相同类的实例的最佳方法是什么?
使用幼稚的方式会产生糟糕的结果: classdef Request properties num=7; end methods function f=foo(this) f = this.num + 4; end end end >> a=[]; >> tic,for i=1:1000 a=[a Request];end;toc Elapsed time is 5.426852 seconds. >> tic,for i=1:1000 a=[a Request];end;toc Elapsed time is 31.261500 seconds. 继承句柄可以大大改善结果: classdef RequestH < handle properties num=7; end methods function f=foo(this) f = this.num + 4; end end end >> tic,for i=1:1000 a=[a RequestH];end;toc Elapsed time is 0.097472 seconds. >> tic,for i=1:1000 a=[a RequestH];end;toc Elapsed time is 0.134007 seconds. >> tic,for i=1:1000 a=[a RequestH];end;toc Elapsed time is 0.174573 seconds. 但仍然不能令人满意,尤其是考虑到重新分配开销不断增加 有没有办法预分配类数组?关于如何有效管理对象的折线数量的任何想法? 谢谢, 丹妮 回答: 该解决方案扩展了Marc的答案 。使用repmat初始化RequestH对象的数组,然后使用循环创建所需的对象: >> a = repmat(RequestH,10000,1);tic,for i=1:10000 a(i)=RequestH;end;toc Elapsed time is 0.396645 seconds. 这是对以下方面的改进: >> a=[];tic,for i=1:10000 a=[a RequestH];end;toc Elapsed time is 2.313368 seconds. |
![]() |
![]() |