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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

2223閲覧

[Java]メモリの浪費箇所はどこ?

colonee

総合スコア13

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

2クリップ

投稿2015/07/13 09:46

現在Aize Online Judgeの問題に取り掛かり始めたものです。
取り組んでいる問題
以下のコードではメモリの使用量が多すぎてオンラインジャッジがうまくいきません。
どの部分がメモリを浪費してしまっているのでしょうか?

lang

1import java.util.Scanner; 2 3public class Main { 4 public static void main(String[] args) { 5 Scanner scan = new Scanner(System.in); 6 String text = new String(); 7 int num; 8 int count = 1; 9 while (true) { 10 num = scan.nextInt(); 11 if (num == 0) { 12 scan.close(); 13 System.out.println(text); 14 break; 15 } else { 16 text += "Case " + count + ": " + num + "\n"; 17 count++; 18 } 19 } 20 } 21 22}

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

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

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

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

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

guest

回答2

0

ベストアンサー

メモリの使用量ではなく,消費時間の問題のような気がします.主にここの.

lang

1 text += "Case " + count + ": " + num + "\n";

JavaのStringにおいて+演算子で文字列を連結すると,そのたびに新たにStringを生成する仕組みになっています.
つまり,ループごとに
0. "Case "と数値countを連結
0. 1.と": "を連結
0. 2.と数値numを連結
0. 3.と改行記号を連結
0. 文字列textと4.を連結し,textに格納
という工程を踏みます.最終的に使うのは5.だけです.
Stringの生成コストは結構あるようで,えらく時間がかかるのです→あえて言うほどではない 文字列結合 Java編
改善策として,StringBuilderを使ってはいかがでしょうか?
textを次のように定義し直します

lang

1StringBuilder text = new StringBuilder();

そして文字列連結では次のようにします

lang

1text.append("Case ").append(count).append(": ").append(num).append("\n");

StringBuilderは文字の配列を次々足しているだけで新たなStringを生成するわけではないので
高速化,省メモリできます.
最後に出力するときだけ文字列を生成します.これにはtoString()するのですが,println()にオブジェクトを渡すと自動的に内部でそのオブジェクトのtoString()を出力に使うので,このままでいいです.

投稿2015/07/13 10:13

swordone

総合スコア20651

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

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

colonee

2015/07/13 11:05

おかげさまで先に進むことができました!ありがとうございます。 JavaのGCも信頼なりませんね。。
guest

0

lang

1text += "Case " + count + ": " + num + "\n";

textは、メモリの使用効率がやや悪いうえに、入力が終わるまで無制限に容量が増え続けます。

投稿2015/07/13 10:03

Stripe

総合スコア2183

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問