ASPN ActiveState Programmer Network
ActiveState
/ Home / Perl / PHP / Python / Tcl / XSLT /
/ Safari / My ASPN /
Cookbooks | Documentation | Mailing Lists | Modules | News Feeds | Products | User Groups


Recent Messages
List Archives
About the List
List Leaders
Subscription Options

View Subscriptions
Help

View by Topic
ActiveState
.NET Framework
Open Source
Perl
PHP
Python
Tcl
Web Services
XML & XSLT

View by Category
Database
General
SOAP
System Administration
Tools
User Interfaces
Web Programming
XML Programming


MyASPN >> Mail Archive >> ruby-talk
ruby-talk
Re: A method that doesn't change its arguments
by Josh Cheek other posts by this author
Nov 8 2009 8:45AM messages near this date
Re: A method that doesn't change its arguments | [ANN] bones-extras 1.0.1
On Sun, Nov 8, 2009 at 6:38 AM, lith <minilith@[...].com>  wrote:

>  > "Inefficient" can also refer to memory.  If the array has 4 million
>  > entries, to copy it 100 times might be considered inefficient in that
>  > sense.
> 
>  Well, maybe you shouldn't use an array then anyway -- which is more or
>  less what you're doing by introducing a layer of indirection.
> 
>  BTW how does your approach behave if you delete 4 million from
>  MyArray? I'd rather go for something tree-like and exchange selected
>  branches, I guess.
> 
> 
Arrays in Ruby get unbearably slow when you get into the millions, it would
definitely be worth considering alternative implementations at that point.

require 'benchmark'

def remove_1millionth_index(old_ary)
  new_ary = old_ary.clone
  new_ary.delete_at 1_000_000
  new_ary
end

ary = Array(1..4_000_000)

Benchmark.bm do |b|
  b.report {
    100.times do
      remove_1millionth_index ary
    end
  }
end


# =================  output  =================
#        user     system      total        real
#  7.875000   0.938000   8.813000 (  8.984000)
Thread:
Timo Jeranko
Harry Kakueki
Ken Bloom
Phrogz
Lith
7stud --
Lith
Josh Cheek

Privacy Policy | Email Opt-out | Feedback | Syndication
© ActiveState Software Inc. All rights reserved