トップ->Java Applet入門

Java入門内検索

目次
Javaトップ
0. はじめに

1. Javaの基礎
   1. コンパイル方法・実行方法
   2. 予約語
   3. 構成
   4. データの型と宣言
   5. 定数と変数
   6. 簡単な演算
   7. ディスプレイへの表示
   8. 文字列

2. 制御文
   1. 順次構造
   2. 単一分岐
   3. 多重分岐
   4. ケース構造
   5. 反復構造(while)
   6. 反復構造(do)
   7. 反復構造(for)
   8. 補助制御文
   9. 練習問題
   10.練習問題
   11.多重ループの抜け方

3. 配列
   1. 配列とは
   2. 配列の宣言と初期化
   3. 配列の使用法
   4. 練習問題
   5. 2次配列と多次元配列
   6. 練習問題

4. クラスの基礎
   1. クラスとは
   2. クラスの作成
   3. コンストラクタ
   4. 例題
   5. 演算子==とequalsメソッド

5. 演算子
   1. 演算子の種類
   2. インクリメント演算子とデクリメント演算子
   3. 複合代入演算子
   4. ビット演算子
   5. シフト演算子
   6. キャスト演算子
   7. 順次演算子
   8. 条件演算子(三項演算子)
   9. instanceof演算子
   10.演算子の優先順位
   11.式と値
   12.条件式と値
   13.練習問題

6. オブジェクト指向とは
   1. オブジェクト指向とクラス
   2. 継承
   3. カプセル化
   4. ポリモーフィズム

7. クラス
   1. thisキーワード
   2. public, protected, private
   3. 静的変数・静的メソッド・静的ブロック
   4. ローカル変数
   5. メソッドの引数
   6. null
   7. 練習問題
   8. インナークラス(内部クラス)
   9. 無名インナークラス(無名内部クラス)
   10. クラスの包含
   11. 練習問題

8. 継承
   1. 継承とは
   2. スーパークラスのコンストラクタ
   3. 継承とキャスト
   4. スコープ
   5. クラスの作成
   6. abstract
   7. 例題)お絵かきソフト
   8. 継承と包含

9. インターフェース
   1. インターフェースとは
   2. インターフェースの宣言
   3. インターフェースの参照
   4. インターフェースの修飾子
   5. インターフェースの継承
   6. インターフェースとinstanceof演算子

10. パッケージ
   1. パッケージとは
   2. パッケージの宣言
   3. クラスパス
   4. import

11. 例外
   1. 例外とは
   2. 例外が起きたら
   3. 例外の種類
   4. catchブロックの検索
   5. throw
   6. throws
   7. エラーと例外
   8. 独自の例外

12. マルチスレッド
   1. スレッドとは
   2. スレッドのライフサイクル
   3. スレッドの作成(Threadクラス)
   4. Threadクラスのメソッド
   5. スレッドの作成(Runnableインターフェース)
   6. 同期
   7. デッドロック
   8. スレッド間の通信

13. ガーベージコレクター
   1. ガーベージコレクターとは
   2. ガーベージコレクターの実行
   3. finalize

14. 有用な(?)クラス群
   1. Math
   2. Random
   3. System
   4. Vector
   5. Stack
   6. Hashtable
   7. Enumeration
   8. String
   9. StringTokenizer
   10. Object
   11. Number
   12. Byte
   13. Short
   14. Integer
   15. Long
   16. Float
   17. Double
   18. BigInteger
   19. BigDecimal
   20. Character
   21. Date
   22. Calendar

15. 入出力
   1. ファイルとディレクトリ
   2. ストリームの種類
   3. 文字ストリーム
   4. Reader
   5. CharArrayReader
   6. StringReader
   7. InputStreamReader
   8. FileReader
   9. BufferedReader
   10. Writer
   11. CharArrayWriter
   12. StringWriter
   13. OutputStreamWriter
   14. FileWriter
   15. PrintWriter
   16. BufferedWriter
   17. バイトストリーム
   18. InputStream
   19. ByteArrayInputStream
   20. FileInputStream
   21. FilterInputStream
   22. BufferedInputStream
   23. DataInputStream
   24. OutputStream
   25. ByteArrayOutputStream
   26. FileOutputStream
   27. FilterOutputStream
   28. BufferedOutputStream
   29. PrintStream
   30. DataOutputStream
   31. ランダムアクセスファイル
   32. スレッド間通信
       PipedInputStream
       PipedOutputStream
   33. クラスの保存
       ObjectInputStream
       ObjectOutputStream
       Serializable
   34. StreamTokenizer
   35. 標準入出力
       キーボードからの入力(標準入力)
       標準出力
       標準エラー出力
   36. 練習問題

16. ネットワーク
   1. インターネットアドレス
   2. TCP/IP通信
   3. UDP通信
   4. URL
   5. 練習問題
   6. マルチキャスト
   7. RMI

17. 中間試験
   1. 問題:Webサーバーを作りなさい
   2. HTTPプロトコル
   3. クラス設計
   4. 解答例

18. AWT
   1. AWTとは
   2. Component
   3. Container
   4. Frame
   5. Button
   6. レイアウト
   7. BorderLayout
   8. FlowLayout
   9. GridLayout
   10. CardLayout
   11. nullレイアウト
   12. イベントとイベントリスナー
   13. ActionListener
   14. Panel
   15. Label
   16. CheckBoxとItemListener
   17. CheckBoxGroup
   18. Choice
   19. List
   20. TextFieldとTextListener
   21. TextArea
   22. ScrollbarとAdjastmentListener
   23. Canvas
   24. 練習問題(計算機)
   25. Point
   26. Dimension
   27. Color
   28. Font
   29. Graphics
   30. 練習問題
   31. 練習問題
   32. ダブルバッファ
   33. イベント その2
       ActionEvent
       ItemEvent
       AdjustmentEvent
   34. KeyListenerとKeyEvent
       InputEvent
   35. MouseListenerとMouseEvent
   36. MouseMotionListener
   37. FocusListenerとFosusEvent
   38. WindowListenerとWindowEvent
   39. ComponentListenerとComponentEvent
   40. ContainerListenerとContainerEvent
   41. アダプタクラスとインナークラス
   42. 無名インナークラス
   43. 練習問題 お絵かき
   44. WindowとDialog、FileDialog
   45. メニュー
   46. ポップアップメニュー
   47. ショートカット
   48. カーソル

19. Java Applet
   1. Java Appletとは
   2. 最初のJava Applet
   3. Appletクラス
   4. Appletクラスのライフサイクル
   5. AppletContext
   6. イメージ
   7. パラメーター
   8. 練習問題 スライドショー
   9. Jarファイル
   10. 練習問題 時計

20. その他のチップス
   1. Javaから別のプログラムを実行させる
   2. StringBuffer
   3. 環境変数の取得
   4. 基数表記
   5. インスタンスのコピー
   6. 値渡しと参照渡し
   7. クラスオブジェクトの比較

21. 修了試験 ↓これより下は工事中です。
   1. 考え中
   2. 考え中
   3.
   4.

22. そしてその後は・・・
   1. ヒューマンアカデミー Javaプログラマー本科
   2. Appli-Style.com iアプリ作成に挑戦
   3. SJC-A 受験チケット申込


・ このページの先頭に戻る
・ トップページに戻る



・ このページの先頭に戻る
・ トップページに戻る

トップ-> Java入門:20章 その他のチップス-> 7.値渡しと参照渡し

←前ページへ :  トップへ :  次章へ→

7. クラスオブジェクトの比較

  Vectorクラスという可変長の配列クラスを紹介しました。このクラスはただ単に格納する以外の機能を備えていません。しかしソフトを作っているとソートしたいというのはよくあることですので、ソート機能を追加したSortableVectorクラスを作ってみることにします。

  格納するデータはKionDataというクラスで、String型の場所と、float型の気温データからなるクラスです。ソートはこの気温によってソートできるようにします。

  そう言うと経験のない人は下記のように、SortableVectorクラスの中でKionDataの比較を行う人も多々います。

import java.util.*;

/* 気温データ */
class KionData{
    String  strChimei;
    double  dKion;

    KionData(String chimei, double kion){
        strChimei = chimei;
        dKion     = kion;
    }

    public String toString(){
        return "(" + strChimei+" : " + dKion + "℃)";
    }

    public double getKion(){
        return dKion;
    }
}

/* ソート機能付きVectorクラス */
class SortableVector extends Vector{
    /* 交換法によるソート */
    public void sort(){
        for( int i = 0 ; i < size() - 1 ; i++ ){
            int      j    = i + 1;
            KionData data = (KionData)elementAt(i);
            int      k    = i;
            for( ; j < size() ; j++ ){
                if( data.getKion() > ((KionData)elementAt(j)).getKion() ){
                    data = (KionData)elementAt(j);
                    k = j;
                }
            }
            insertElementAt(elementAt(i), k);
            removeElementAt(k+1);
            insertElementAt(data, i);
            removeElementAt(i+1);
        }
    }

    /* Vectorの中身を表示 */
    public void disp(){
        for( int i = 0 ; i < size() ; i++ ){
            System.out.println(elementAt(i));
        }
        System.out.println();
    }
}


public class Test{
    public static void main(String[] args){
        SortableVector v = new SortableVector();
        v.insertElementAt( new KionData("札幌",  5.2), 0);
        v.insertElementAt( new KionData("沖縄", 25.9), 0);
        v.insertElementAt( new KionData("東京", 15.3), 0);
        v.insertElementAt( new KionData("大阪", 16.0), 0);
        v.insertElementAt( new KionData("熊谷", 21.1), 0);

        v.disp();    /* ソート前を表示 */
        v.sort();    /* ソート実行 */
        v.disp();    /* ソート後を表示 */
    }
}
C:\java>java Test
(熊谷 : 21.1℃)
(大阪 : 16.0℃)
(東京 : 15.3℃)
(沖縄 : 25.9℃)
(札幌 : 5.2℃)

(札幌 : 5.2℃)
(東京 : 15.3℃)
(大阪 : 16.0℃)
(熊谷 : 21.1℃)
(沖縄 : 25.9℃)

C:\java>

  もちろんこれでも動作しますが、大小の比較をするというのはVectorクラスではなく、データを持っているKionDataクラスで実装すべきです。ですからcompareTo(KionData)メソッドを実装します。これは自分が引数で与えられたオブジェクトよりも気温が低ければ-1を、同じなら0を、高ければ+1を返すメソッドです。

  次にSoratbleVectorクラスです。
  なお、ソートのアルゴリズムについてはアルゴリズム入門を参照してください。


import java.util.*;

/* 気温データ */
class KionData{
    String  strChimei;
    double  dKion;

    KionData(String chimei, double kion){
        strChimei = chimei;
        dKion     = kion;
    }

    public String toString(){
        return "(" + strChimei+" : " + dKion + "℃)";
    }

    /* 比較メソッド */
    public int compareTo(KionData data){
        if( dKion < data.dKion )
            return -1;
        else if( dKion == data.dKion )
            return 0;
        else
            return 1;
    }
}

/* ソート機能付きVectorクラス */
class SortableVector extends Vector{
    /* 交換法によるソート */
    public void sort(){
        for( int i = 0 ; i < size() - 1 ; i++ ){
            int      j    = i + 1;
            KionData data = (KionData)elementAt(i);
            int      k    = i;
            for( ; j < size() ; j++ ){
                if( data.compareTo((KionData)elementAt(j)) > 0 ){
                    data = (KionData)elementAt(j);
                    k = j;
                }
            }
            insertElementAt(elementAt(i), k);
            removeElementAt(k+1);
            insertElementAt(data, i);
            removeElementAt(i+1);
        }
    }

    /* Vectorの中身を表示 */
    public void disp(){
        for( int i = 0 ; i < size() ; i++ ){
            System.out.println(elementAt(i));
        }
        System.out.println();
    }
}


public class Test{
    public static void main(String[] args){
        SortableVector v = new SortableVector();
        v.insertElementAt( new KionData("札幌",  5.2), 0);
        v.insertElementAt( new KionData("沖縄", 25.9), 0);
        v.insertElementAt( new KionData("東京", 15.3), 0);
        v.insertElementAt( new KionData("大阪", 16.0), 0);
        v.insertElementAt( new KionData("熊谷", 21.1), 0);

        v.disp();    /* ソート前を表示 */
        v.sort();    /* ソート実行 */
        v.disp();    /* ソート後を表示 */
    }
}
C:\java>java Test
(熊谷 : 21.1℃)
(大阪 : 16.0℃)
(東京 : 15.3℃)
(沖縄 : 25.9℃)
(札幌 : 5.2℃)

(札幌 : 5.2℃)
(東京 : 15.3℃)
(大阪 : 16.0℃)
(熊谷 : 21.1℃)
(沖縄 : 25.9℃)

C:\java>

  せっかく作ったSortableVectorクラスですが、例えば各店舗の売り上げデータをソートするのには使えません。そこでcompareToメソッドを実装していることがわかるように工夫します。それがインターフェースです。
  つまりCompareableインターフェースを作り、compareToメソッドが実装されていると言うことを明示すればKionDataでもTenpoUriageデータでもSortableVectorにとってはどっちでも良いわけです。


import java.util.*;

/* インターフェース */
interface Compareable{
    public int compareTo(Compareable c);
}

/* 気温データ */
class KionData implements Compareable{
    String  strChimei;
    double  dKion;

    KionData(String chimei, double kion){
        strChimei = chimei;
        dKion     = kion;
    }

    public String toString(){
        return "(" + strChimei+" : " + dKion + "℃)";
    }

    /* 比較メソッド */
    public int compareTo(Compareable data){
        if( dKion < ((KionData)data).dKion )
            return -1;
        else if( dKion == ((KionData)data).dKion )
            return 0;
        else
            return 1;
    }
}

/* ソート機能付きVectorクラス */
class SortableVector extends Vector{
    /* 交換法によるソート */
    public void sort(){
        for( int i = 0 ; i < size() - 1 ; i++ ){
            int         j    = i + 1;
            Compareable data = (Compareable)elementAt(i);
            int         k    = i;
            for( ; j < size() ; j++ ){
                if( data.compareTo((Compareable)elementAt(j)) > 0 ){
                    data = (Compareable)elementAt(j);
                    k = j;
                }
            }
            insertElementAt(elementAt(i), k);
            removeElementAt(k+1);
            insertElementAt(data, i);
            removeElementAt(i+1);
        }
    }

    /* Vectorの中身を表示 */
    public void disp(){
        for( int i = 0 ; i < size() ; i++ ){
            System.out.println(elementAt(i));
        }
        System.out.println();
    }
}


public class Test{
    public static void main(String[] args){
        SortableVector v = new SortableVector();
        v.insertElementAt( new KionData("札幌",  5.2), 0);
        v.insertElementAt( new KionData("沖縄", 25.9), 0);
        v.insertElementAt( new KionData("東京", 15.3), 0);
        v.insertElementAt( new KionData("大阪", 16.0), 0);
        v.insertElementAt( new KionData("熊谷", 21.1), 0);

        v.disp();    /* ソート前を表示 */
        v.sort();    /* ソート実行 */
        v.disp();    /* ソート後を表示 */
    }
}

  こうすることで、SortableVectorはKionDataクラス専用ではなく、汎用的なクラスにすることができました。

  なお、Java2からはCompareableインターフェース、compareToメソッドは実際にサポートされ、例えばIntegerやDoubleクラスなどにインプリメントされています。またソートもCollectionsクラスのsortメソッドによって簡単に行えるようになっています。

  私の私心ですが、本来ならばequalsメソッドが実際にサポートされているかどうかを確かめるためにEqualableインターフェースも用意した方が良いような気がするんですけどね。。。


←前ページへ :  トップへ :  次章へ→