質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Q&A

解決済

2回答

142閲覧

pushメソッドが動かない

rowarubchinsky

総合スコア20

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

0グッド

0クリップ

投稿2018/07/26 07:13

an = [1, 2, 3]

an.each do |a|
an.push(a)
end

p an

ターミナルで上記を動かすと、止まってしまいます。
pushメソッドはあまり使わない方がいいのでしょうか。
改善点あれば教えてください!!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

ruby

1an = [1, 2, 3] 2 3an.each do |a| 4 an.push(a) 5end

の処理ですが、anにpushしてしまうと(破壊的メソッドなので)anの要素が一つ後ろに追加されます。
ですので、eachの1週目の処理は

an.each do |a| an.push(a) # aは1 # => an == [1, 2, 3, 1] end

2週目の処理は

an.each do |a| an.push(a) # aは2 # => an == [1, 2, 3, 1, 2] end

と、ループする要素自体がループを回るごとに増えるため、ループから抜けなくなります。
実際にされたい処理がどういうものかわかりませんが、以下サンプルです

an = [1, 2, 3] an2 = an.dup an.each do |a| an2.push(a) end p an2 #=> [1, 2, 3, 1, 2, 3]

投稿2018/07/27 13:55

satoshih

総合スコア797

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ruby

1an = [1,2,3] 2an.each{|it| 3 an.push(10) if it == 1 4 p it 5} 6p an

結果は

1 2 3 10 [1, 2, 3, 10]

となります。

つまり、eachで回している配列を内部で拡張すると
その分までループされるので、無条件に要素が1増えるとループが終わらなくなります。


ちなみに、要素を2倍にしたいだけならば

ruby

1an = [1,2,3] 2p(an * 2) 3# => [1, 2, 3, 1, 2, 3]

掛け算してやればいいです。

投稿2018/07/26 07:22

asm

総合スコア15147

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問