teratail header banner
teratail header banner
質問するログイン新規登録

回答編集履歴

2

補足追加

2016/11/23 11:32

投稿

KSwordOfHaste
KSwordOfHaste

スコア18404

answer CHANGED
@@ -2,4 +2,17 @@
2
2
 
3
3
  一方リスト(=List<T>)は実装クラスによって性質が変わりますが、大抵の場合要素数を動的に変更できます。ランダムアクセススピードはList<T>の実装クラスによって異なります。シーケンシャルアクセスならどの実装でも概ね同じだと思います。
4
4
 
5
- この性質を把握した上で使い分ければよいです。
5
+ この性質を把握した上で使い分ければよいです。
6
+
7
+ ---
8
+ 追記:
9
+
10
+ Javaの制約として書かねばならないことが一点あります(いつか制約が解除されるといいのですが)。List<T>は型引数Tを用いたジェネリック型なので要素型Tとしてプリミティブ型が使えません。つまりintなどは直接格納できずそれらの型に対応したIntegerなどの型を使う必要があります。Integerなどの型をプリミティブ型intに対してのwrapper型などといいます。
11
+ wrapper型はboxing/unboxingというjavaの言語仕様によりあたかも中身がプリミティブ型であるかのように扱えるのですが特にboxingにはより多くのコスト(メモリーをより多く消費する)がかかります。
12
+
13
+ ```java
14
+ List<int> intList; // <===コンパイルエラー
15
+ List<Integer> list = new ArrayList<>();
16
+ list.add(1); // intを直接追加できる
17
+ int e1 = list.get(0); // 要素はInteger型だがint型へキャストを書かなくても代入できる
18
+ ```

1

補足

2016/11/23 11:32

投稿

KSwordOfHaste
KSwordOfHaste

スコア18404

answer CHANGED
@@ -1,3 +1,5 @@
1
1
  配列は要素のランダムアクセススピードが最速ですが確保後にサイズを変更できません。
2
2
 
3
- 一方リスト(=List<T>)は実装クラスによって性質が変わりますが、大抵の場合要素数を動的に変更できます。ランダムアクセススピードはList<T>の実装クラスによって異なります。シーケンシャルアクセスならどの実装でも概ね同じだと思います。
3
+ 一方リスト(=List<T>)は実装クラスによって性質が変わりますが、大抵の場合要素数を動的に変更できます。ランダムアクセススピードはList<T>の実装クラスによって異なります。シーケンシャルアクセスならどの実装でも概ね同じだと思います。
4
+
5
+ この性質を把握した上で使い分ければよいです。