当然是传指针比较好了, 方法1效率高, 方法2 当hash,list 大的就效率低了,
2012/7/1 De-Jian Zhao <[email protected]> > 各位好,请教一个问题。最近写了一个subroutine,**尝试了两种方法,主要区别是 子例程的返回值不同。一个是返回hash > reference(方法1),一个是直接返回 hash(方法2)。在运行时感觉方法2会稍有停顿。因此,**想问一个问题:方法2 > 中%fasseq在接收子 例程的返回值时是不是要复制一份结果,并不是直接操作子例 程中的那块内存地址?方法1中my %fasseq = > %$fasseq;是不是直接把地址传 给%fasseq进行操作?应当如何设置这个返回值? > > 还有一个问题是:**Perl自带的函数根据上下文的不同可以返回scalar或者l**ist,自 己写子例程时如何实现? > > > 方法1: > sub read_fasta_into_hash() { > my $fasfile = shift @_; > my %fasseq; > ..... > return \%fasseq; > } > my $fasseq = &read_fasta_into_hash($**fasfile); > my %fasseq = %$fasseq; > > > 方法2: > sub read_fasta_into_hash() { > my $fasfile = shift @_; > my %fasseq; > ..... > return %fasseq; > } > my %fasseq = &read_fasta_into_hash($**fasfile); > > > -- > 您收到此邮件是因为您订阅了 Google 网上论坛的“PerlChina Mongers 讨论组”论坛。 > 要向此网上论坛发帖,请发送电子邮件至 [email protected]。 > 要取消订阅此网上论坛,请发送电子邮件至 > perlchina+unsubscribe@**googlegroups.com<perlchina%[email protected]> > 。 > 若有更多问题,请通过 > http://groups.google.com/**group/perlchina?hl=zh-CN<http://groups.google.com/group/perlchina?hl=zh-CN>访问此网上论坛。 > > -- Yours Sincerely Zeng Hong -- 您收到此邮件是因为您订阅了 Google 网上论坛的“PerlChina Mongers 讨论组”论坛。 要向此网上论坛发帖,请发送电子邮件至 [email protected]。 要取消订阅此网上论坛,请发送电子邮件至 [email protected]。 若有更多问题,请通过 http://groups.google.com/group/perlchina?hl=zh-CN 访问此网上论坛。
