こんにちは、Stringクラスのlengthメソッドについて質問させてください。
今まで配列のlengthは、宣言時に長さが決定するからメソッドではなく、finalフィールドで十分。
ArrayListだとかは長さが変わるからメソッドという意識を持っていました。
(カプセル化の概念とも関わりますが)
先日その話しをしていたら、「でも文字列(Stringオブジェクト)の長さも不変だよね。」と言われました。
確かに文字列の長さは不変なのに、長さの取得にはメソッドを使っています。
言語仕様として一貫性を持たせるなら、配列もlengthメソッドにするか、文字列をlengthフィールドにしたほうが綺麗だと思うんです。
Stringクラスのソースコードを見ていたら、文字列の長さは内部的に
private int count; と宣言されていました。
そして、lengthメソッドは return count; しているだけでした。
ただ、このcountフィールドに値を代入しているのはコンストラクタ内だけだったので、
public final int length; とすれば、良かったのでは?と思いました。
この考えについて、
それは間違っている、とか歴史的な背景などご存知でしたらご教授ください。
よろしくお願致します。
No.1ベストアンサー
- 回答日時:
あくまで想像ですが・・・
長さを問い合せる場合、括弧付きの「length()」である方がオブジェクト指向
らしい方法と思います。
配列のlenghthは、あくまでフィールドです。
つまり、いくつ配列に格納したか、ではなく、配列として準備した個数を格納
しているにすぎません。
Stringの長さが「不変である」というのは、Stringの性質ではなく、たんに
そういうクラスを作っただけのことなので、結果論からfinalにするのは
設計上正しいとは思えません。
可変のStringクラスだってあってもいいのでは?
説得力のある説明、ありがとうございます。
もうひとつ質問になってしまうんですが、
配列はlengthフィールドで長さを取得しますが、設計の段階でこれをlengthメソッドにするわけにはいかなかったんですかね?
そのほうがオブジェクト志向らしくはなりませんか・・・?
No.5
- 回答日時:
>この考えについて、
>それは間違っている、とか歴史的な背景などご存知でしたらご教授ください。
歴史的背景については分かり兼ねますが、ここのカテにて歴史的に繰り返されている質問の一つであることだけは周知済みです。
「配列変数のlengthプロパティは、どうしてそのまま参照できるのですか?」
http://oshiete1.goo.ne.jp/qa2491628.html
「String(文字列)と配列の length の違いについて」
http://oshiete1.goo.ne.jp/qa3519349.html
>ということは1.0の時点ではlengthをフィールドにしても問題はなかったと思うんですが・・・
以前ググった時には、上記のような内容をJavaHouseのメーリングリスト内でチラッと見かけました。ただ、「なんで?」とか「どうして?」などのような思想に関わってくるものに関しては、国内のサイトだけで理解しようとするのは非常に困難であるように思います。
No.4
- 回答日時:
ANo.2です
指摘を受けてStringクラスを見てきました。そもそもcountフィールド自体が
private final int count;
と宣言されていますね・・・
finalか、privateのどちらかなら、間違った変更を防止するため、と言えるのですが、finalだけあれば外からの変更を防止できるはずなので、public finalとしてもいい気がします。
ただ、直接参照させないときの利点について、仕様変更のときのことが考えられるんじゃないかなぁ、と思ったわけです。
たとえば、今まではStringクラスは内部に文字数と同じだけのChar配列を持っていましたが、新たな機能を追加するにいたって、1文字表すのにCharを2つ使うようになったとか、なんかうまい例が思いつかないけど・・・
とにかくChar配列の大きさと文字の長さが食い違うような状況になったときにメソッドにしておけば変更できるから。ということではないでしょうか
No.3
- 回答日時:
StringクラスはCharSequenceインタフェースを実装しています。
length()メソッドはここで宣言されているのですが、
上記のインタフェースを実装しているのはStringクラスだけでなく
StringBufferクラスも実装しています。
StringBufferクラスは可変文字列なので
そちらの方にも対応させる為ではないでしょうか。
参考URL:http://java.sun.com/j2se/1.5.0/ja/docs/ja/api/ja …
ありがとうございます
確かにご指摘の通りStringクラスはCharSequenceインターフェースを実装しています。
しかしそれは1.4からの話しであって、1.3まではありませんでした。
恐らく標準ライブラリに正規表現のクラス(PatternやMatcher)を導入するために、追加したインターフェースだと思います。
ということは1.0の時点ではlengthをフィールドにしても問題はなかったと思うんですが・・・
No.2
- 回答日時:
自信を持ってはいえませんが・・・
まず、String#replaceAll(String, String)というメソッドがあるので、
Stringの文字の長さは可変だと思います。
ですので、finalには出来ませんよね
それではprivateにするのはなぜかというと、フィールドを直接よびだして勝手な値を代入されるという危険性を避けるためです。
要はバグ防止ということでしょうか。
フィールドのカプセル化 で検索してみると色々でてきますよ
参考URL:http://milkyway.merseine.nu/100java/Java/Java997 …
ありがとうございます。
カプセル化については理解している(つもり)なので問題ありません。
指摘にあったString#replaceAll(String, String)メソッドなんですが、
内部的に新しいStringオブジェクトを生成しているのであって、長さを変えているわけではないと思うんですが・・・?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(プログラミング・Web制作) pythonのプログラムについての質問です。 1 2023/05/26 10:31
- Java java 次の機能を有するメソッドを自クラスに作成し、実装したいです。 機能 名前判定機能 →名前が 3 2022/06/16 16:08
- その他(プログラミング・Web制作) pythonリストの特定の値を表示htmlで表示できない 2 2022/05/14 05:48
- Java java final 1 2022/06/10 22:49
- Java java 飾子を付けること(public static・・・) ・コンソールへの出力処理はmainメ 2 2022/06/16 19:34
- Java JavaのSingletonパターンのprivateの持つ意味が分かりません。 5 2022/06/12 10:38
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- Java javaの質問です 次の機能を有するメソッド4つを自クラスに作成し、実装したいです 【機能】 足し算 1 2022/06/15 17:49
- その他(プログラミング・Web制作) どういうプログラムで組みますか?google colabでやってるんですけど、出来る方お願いします。 1 2022/07/17 18:41
- 英語 SPECS の所の LENGTH というのは、BARREL LENGTH なのか?全体の長さなのか? 1 2022/04/27 20:05
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンドライン引数のチェック
-
Java初級 引数に適用できません
-
abstract と static を一緒に付...
-
レコード件数の表示
-
public static void main (Stri...
-
Google Apps Script で getRang...
-
privateのメソッドをリフレクシ...
-
Java初心者です。例外のキャッ...
-
なぜprotected overrideなのか
-
JUnitのテストメソッドごとのメ...
-
初歩的な メソッドの引数について
-
Javaの関数名が長い?
-
Javaの文法
-
戻り値の異なるメソッドの多重...
-
contextってなんですか?
-
Java ゲームプログラミング 例外
-
javaに"search"という関数 or ...
-
String.containsの反対機能はあ...
-
C言語での文字列より値を抜き出す
-
Javaの公式メソッドの中身を見...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Java初級 引数に適用できません
-
String.containsの反対機能はあ...
-
なぜprotected overrideなのか
-
Strutsでチェックボックスの値...
-
Google Apps Script で getRang...
-
abstract と static を一緒に付...
-
C# 点の描き方をおしえてくだ...
-
レコード件数の表示
-
public static void main (Stri...
-
StringBufferからStringへキャ...
-
YYYYMMDD書式の日付に対する適...
-
C# でメソッドに送られてきたOb...
-
シェルスクリプトからのJavaメ...
-
C# の ByVal と ByRef について
-
Fileの読み取り専用の解除
-
CSVから読み込んだデータの保持...
-
メソッドの引数に指定されてい...
-
javaに"search"という関数 or ...
-
Javaのメモリの管理
-
Java初心者です、エラーの意味...
おすすめ情報