Javaの変数宣言マスター講座|基本の型から命名規則、実践テクニックまで網羅

2025年8月12日火曜日

Java

Javaの変数宣言は、プログラミング学習で誰もが通る最初の関門です。ここでつまずいてしまうと、その後の学習効率が大きく下がってしまうかもしれません。
しかし、変数宣言のルールと役割を正しく理解すれば、コードは驚くほど読みやすく、エラーも格段に減ります。

Javaの変数の扱い方を基礎から学び、プログラミングの土台を固めていきましょう。あなたの書くコードが、きっと変わります。

この記事で学べること

  • Javaの変数とは何か、なぜ必要なのか
  • 変数宣言の基本的な書き方とルール
  • 主要なデータ型の種類と使い分け
  • 現場で通用する変数名の付け方
  • コードが綺麗になる実践的なテクニック

Javaの変数宣言はプログラミングの第一歩

Javaでプログラミングを始めるにあたり、まず理解すべき概念が「変数」です。ここでは、変数がどのようなもので、なぜ必要なのか、その本質的な役割について解説します。

  • 変数とは?なぜ必要なの?
  • Javaプログラミングにおける変数の役割

変数とは?なぜ必要なの?

変数とは、データを一時的に入れておくための「箱」のようなものです。プログラミングでは、数値や文字列といった様々なデータを扱います。それらのデータを何度も使ったり、計算して変化させたりする場合に、変数という箱に入れておくことで管理がしやすくなります。

例えば、料理で考えてみましょう。切った野菜や混ぜた調味料を、一時的にボウルに入れておきますよね。この「ボウル」が変数にあたります。材料(データ)を適切なボウル(変数)に入れておくことで、調理(処理)がスムーズに進むのです。

Javaプログラミングにおける変数の役割

Javaのプログラムは、たくさんのデータ処理の連続で動いています。
ユーザーが入力した名前、計算した商品の合計金額、Webサイトから取得した情報など、あらゆるデータがメモリという場所で管理されます。

変数には、そのメモリ上にあるデータに分かりやすい名前を付ける役割があります。単なるメモリ上の番地ではなく、「userName」や「totalPrice」といった意味のある名前を付けることで、後から見返したときに何のためのデータなのかが一目でわかるようになります。

正しく変数を使うことは、バグの少ない、メンテナンスしやすいコードを書くための基本スキルです。

Javaの変数宣言、基本の「型」

変数の役割を理解したところで、次はJavaで変数を宣言する具体的な方法を学びます。Javaでは、変数に入れるデータの種類に応じて「型」を指定する必要があります。基本構文と主要な型をしっかり押さえましょう。

  • まずは基本の構文を覚えよう
  • これだけは覚えたい!基本のデータ型4選
  • 「宣言」と「初期化」と「代入」の違い

まずは基本の構文を覚えよう

Javaの変数宣言は、以下の形式で記述するのが基本です。

// 型名 変数名 = 初期値;
int age = 20;

この一行は、いくつかの要素で構成されています。

  • 型名 (int): 変数に入れるデータの種類を指定します。この場合は「整数型」です。
  • 変数名 (age): 変数に付ける名前です。好きな名前を付けられますが、分かりやすい名前が推奨されます。
  • = (イコール): 右辺の値を左辺の変数に入れる「代入」を意味します。
  • 初期値 (20): 変数を作成する際に最初に入れておく値です。
  • ; (セミコロン): 文の終わりを示します。Javaでは文末に必ず記述します。

この「型名 変数名 = 初期値;」という構文が、Javaの変数宣言における最も重要な基本形です。

これだけは覚えたい!基本のデータ型4選

Javaには多くのデータ型がありますが、初心者がまず覚えるべき代表的な型は以下の4つです。

説明 コード例
int 整数を扱う型(例: 10, -5, 0)
int price = 1500;
double 小数を扱う型(例: 3.14, -0.5)
double taxRate = 1.1;
String 文字列を扱う型(" "で囲む)
String name = "山田";
boolean 真偽値(trueかfalse)を扱う型
boolean isFinished = true;

「宣言」と「初期化」と「代入」の違い

変数を使う上で、似たような言葉がいくつか出てきます。それぞれの意味を正確に区別しましょう。

  • 宣言: `int age;` のように、変数の型と名前を決めて存在を知らせること。箱を用意するイメージです。
  • 初期化: `age = 20;` のように、宣言した変数に初めて値を入れること。用意した箱に最初のデータを入れる作業です。宣言と同時に `int age = 20;` と書くのが一般的です。
  • 代入: 一度値が入っている変数に、新しい値を入れる(上書きする)こと。箱の中身を入れ替えるイメージです。
// 変数の「宣言」
String message;

// 変数の「初期化」
message = "こんにちは";

// 変数への「代入」(値を上書き)
message = "こんばんは";

Javaの変数で使える主要なデータ型

Javaのデータ型は、大きく「プリミティブ型」と「参照型」の2種類に分類されます。それぞれの特徴とメモリ上での扱いの違いを理解すると、より深いレベルでJavaを扱えるようになります。

  • 数値を扱うプリミティブ型
  • 文字やオブジェクトを扱う参照型
  • プリミティブ型と参照型の違いとは?

数値を扱うプリミティブ型

プリミティブ型は、Javaにあらかじめ用意されている基本的なデータ型です。全部で8種類あり、主に数値や真偽値などを直接格納します。変数の中にデータそのものが入っているイメージです。

分類 説明 サイズ
整数型 byte -128から127までの整数 1バイト
short -32,768から32,767までの整数 2バイト
int 約-21億から21億までの整数(最も一般的) 4バイト
long 非常に大きな整数(末尾にLを付ける) 8バイト
浮動小数点型 float 小数(末尾にFを付ける) 4バイト
double より精度の高い小数(最も一般的) 8バイト
文字型 char 1文字(' 'で囲む) 2バイト
論理型 boolean trueまたはfalse 1ビット

文字やオブジェクトを扱う参照型

参照型は、プリミティブ型以外のすべての型を指します。代表的なものに `String`(文字列)や `配列` 、自作した `クラス` などがあります。

参照型の変数は、データそのものではなく、データがメモリ上のどこに保存されているかという「住所情報(参照値)」を格納します。オブジェクトの実体は別の場所にあり、変数はその場所を指し示しているだけ、というイメージです。

// String型(参照型)の変数を宣言
String greeting = "おはよう";

// int型の配列(参照型)を宣言
int[] numbers = {10, 20, 30};

プリミティブ型と参照型の違いとは?

プリミティブ型と参照型の最も大きな違いは、データをコピーしたときの挙動です。

プリミティブ型は、変数を別の変数に代入すると、中の値そのものがコピーされます。そのため、コピー元の変数を変更してもコピー先の変数に影響はありません。

// プリミティブ型(int)の例
int a = 100;
int b = a; // aの「値」100がbにコピーされる
a = 200;   // aの値を変更

System.out.println(a); // 実行結果: 200
System.out.println(b); // 実行結果: 100 (bの値は変わらない)

一方、参照型は、変数を別の変数に代入すると、データの「住所情報」がコピーされます。結果として、2つの変数がメモリ上の同じデータを指し示す状態になります。そのため、どちらか一方の変数を通じてデータを変更すると、もう一方の変数から見たデータも変わってしまいます。

// 参照型(配列)の例
int[] arrayA = {1, 2, 3};
int[] arrayB = arrayA; // arrayAの「住所」がarrayBにコピーされる

arrayA[0] = 99; // arrayAを通じてデータを変更

// 実行結果: 99 (arrayBから見てもデータが変わっている)
System.out.println(arrayB[0]);

読みやすいコードの秘訣!Java変数名の付け方

プログラムは一度書いたら終わりではありません。後から修正したり機能を追加したりします。その際に、変数名が分かりやすいかどうかで、作業効率が大きく変わります。ここでは、誰が見ても分かりやすい変数名を付けるためのルールとコツを紹介します。

  • 変数名を付けるときの基本ルール
  • 推奨される書き方「キャメルケース」
  • 【NG例あり】分かりやすい変数名を付けるコツ

変数名を付けるときの基本ルール

Javaの変数名には、守らなければならないルールがあります。

  • 利用できる文字
    • 半角のアルファベット、数字、アンダースコア(_)、ドル記号($)が使えます。
  • 先頭の文字
    • 先頭に数字は使えません。
  • 大文字と小文字の区別
    • `age`と`Age`は別の変数として扱われます。
  • 予約語は使えない
    • `int` や `class` など、Javaの文法で意味を持つ単語(予約語)は変数名にできません。
  • 長さの制限
    • 事実上ありませんが、長すぎる名前は避けるべきです。

推奨される書き方「キャメルケース」

Javaの変数名は、複数の単語をつなげる場合に「キャメルケース」で書くのが一般的です。

キャメルケースとは、先頭の単語は小文字で始め、後続の単語の先頭を大文字にする書き方です。見た目がラクダのこぶ(Camel)のように見えることから名付けられました。

  • 良い例: `userName`, `totalPrice`, `isEditable`
  • 悪い例: `username`, `totalprice`, `iseditable` (単語の区切りが分かりにくい)
  • 悪い例: `user_name`, `total_price` (スネークケースと呼ばれ、別の言語で使われることが多い)
// キャメルケースで書かれた変数名
String firstName = "太郎";
int userAge = 25;
boolean hasLicense = true;

【NG例あり】分かりやすい変数名を付けるコツ

ルールを守るだけでなく、意味が伝わりやすい名前を付けることも同じくらい重要です。

  • 具体的に書く
    • `data` や `value` のような曖昧な名前ではなく、`customerName` や `productPrice` のように、何を表すデータなのかが分かる名前にします。
  • 省略しすぎない
    • `usrNm` のような過度な省略は、意味が分からなくなる原因です。`userName` と書きましょう。
  • boolean型の名前
    • `is~` `has~` `can~` で始めると、`true/false` の状態を表す変数だと分かりやすくなります。(例: `isLogin`, `hasPermission`)

このような命名規則は、チーム開発を円滑に進めるための共通認識です。例えば、Google社が公開している Google Java Style Guide なども参考にすると、より実践的な命名スキルが身につきます。

【実践】Javaの変数宣言でコードを綺麗にする7つのコツ

基本をマスターしたら、次はコードの品質を一段階上げるための実践的なテクニックを学びましょう。ここでは、コードをより綺麗で、安全で、読みやすくするための7つのコツを紹介します。

  1. 変数の使い回しを避ける
  2. スコープは最小限を意識する
  3. 「マジックナンバー」は定数(final)にする
  4. 型推論「var」を賢く使う
  5. 関連する変数はまとめて宣言する
  6. 初期化は宣言と同時に行う
  7. 適切なデータ型を選ぶ

① 変数の使い回しを避ける

一つの変数を、プログラムの途中で全く異なる目的のために使い回すのはやめましょう。変数の役割は一つに絞るべきです。

悪い例:

// 最初に「一時的な計算結果」として使う
double temp = price * tax;
// ...しばらくして...
// 今度は「ユーザーの体温」として使う(NG!)
temp = 36.5;

良い例:

// それぞれ別の変数として宣言する
double calculatedPrice = price * tax;
double userTemperature = 36.5;

② スコープは最小限を意識する

スコープとは、変数が有効な範囲のことです。変数は、できるだけ狭い範囲で使うのが理想です。これを「スコープを最小限にする」と言います。

ループの中でしか使わない変数は、ループの直前ではなく、ループの中で宣言しましょう。これにより、変数が意図しない場所で変更されるのを防ぎ、コードが読みやすくなります。

悪い例:

// ループの外で宣言している
String itemName;
for (Product p : productList) {
  itemName = p.getName(); // ループのたびに代入
  System.out.println(itemName);
}

良い例:

// ループの中で宣言・初期化する
for (Product p : productList) {
  String itemName = p.getName(); // スコープがこのループ内に限定される
  System.out.println(itemName);
}

③ 「マジックナンバー」は定数(final)にする

コードの中に突然現れる、意味の分からない数字を「マジックナンバー」と呼びます。例えば、消費税率の `1.1` などです。

このような値は、`final` を付けて「定数」にしましょう。定数にすると、値が変更できなくなり、名前が付くことで意味も明確になります。定数名はすべて大文字で、単語間をアンダースコアで区切るのが慣例です。

悪い例:

int priceWithTax = 1000 * 1.1; // 1.1が何なのか分からない

良い例:

// finalで定数を宣言
final double TAX_RATE = 1.1;
int priceWithTax = 1000 * TAX_RATE; // 意味が明確になる

④ 型推論「var」を賢く使う

Java 10から、ローカル変数(メソッド内で使う変数)の宣言に `var` を使えるようになりました。`var` を使うと、コンパイラが右辺の型から自動的に変数の型を推測してくれます。

// 従来の書き方
String message = "Hello, Java!";
// varを使った書き方
var message = "Hello, Java!"; // messageはString型と推論される

// 複雑な型名で特に有効
var userList = new ArrayList<User>();

`var` を使うとコードが簡潔になりますが、右辺から型が明らかでない場合に使うと、逆に可読性が下がることがあります。`var user = findUser(id);` のように、メソッドの返り値が何か分からないケースでは、`User user = findUser(id);` と明記した方が親切です。

⑤ 関連する変数はまとめて宣言する

関連性の高い変数は、コードの近い場所にまとめて宣言すると、ブロックとして認識しやすくなり可読性が向上します。

// ユーザー情報をまとめて宣言
String userName = "Taro";
int userAge = 30;
String userAddress = "Tokyo";

// 商品情報をまとめて宣言
String productName = "Apple";
int productPrice = 150;

⑥ 初期化は宣言と同時に行う

変数は、可能な限り宣言と同時に初期化しましょう。宣言だけして初期化を後回しにすると、初期化し忘れてエラー(NullPointerExceptionなど)の原因になります。

推奨されない例:

String name;
// ...たくさんの処理...
name = "Suzuki"; // 初期化を忘れる可能性がある

良い例:

String name = "Suzuki"; // 宣言と同時に初期化

⑦ 適切なデータ型を選ぶ

変数が扱うデータの範囲や性質に合わせて、最適なデータ型を選びましょう。例えば、年齢のように明らかに21億を超えない整数には `int` を、ファイルのバイト数を扱うなら `byte` や `long` を検討します。

適切な型を選ぶことで、メモリを効率的に使い、意図しない値が混入するのを防げます。

Javaの変数宣言でよくあるエラーと解決策

Javaの学習中には、変数宣言に関するエラーが頻繁に発生します。ここでは、代表的なコンパイルエラー3つと、その原因および解決策を解説します。エラーメッセージを恐れず、原因を特定する力を養いましょう。

  • 「cannot find symbol(シンボルが見つかりません)」
  • 「incompatible types(型が一致しません)」
  • 「variable might not have been initialized(変数が初期化されていません)」

「cannot find symbol(シンボルが見つかりません)」

これは、宣言していない変数を使おうとしたり、変数名のスペルを間違えたりしたときに発生する最も一般的なエラーです。

エラーが発生するコード:

public class Main {
  public static void main(String[] args) {
    String userName = "Sakura";
    // 変数名を間違えている (userName -> useName)
    System.out.println(useName);
  }
}
// エラーメッセージ:
// Main.java:5: error: cannot find symbol
//   System.out.println(useName);
//                      ^
//   symbol:   variable useName
//   location: class Main
  • 原因
    • コンパイラが `useName` という名前の変数を見つけられなかった。
  • 解決策
    • 変数名を正しく `userName` に修正する。大文字と小文字も正確に合わせる必要があります。

「incompatible types(型が一致しません)」

このエラーは、宣言した変数の型と、代入しようとしている値の型が一致しない場合に発生します。

エラーが発生するコード:

public class Main {
  public static void main(String[] args) {
    // int型の変数に、文字列を代入しようとしている
    int userAge = "二十歳";
  }
}
// エラーメッセージ:
// Main.java:3: error: incompatible types: String cannot be converted to int
//     int userAge = "二十歳";
//                   ^
  • 原因
    • `int` 型の変数 `userAge` に `String` 型の値 `"二十歳"` を代入しようとしたため。
  • 解決策
    • 正しい型の値を代入します。`int userAge = 20;` のように修正します。

最近の統合開発環境(IDE)、例えば「IntelliJ IDEA」や「Eclipse」を使うと、コードを書いている段階でエラーを検知して教えてくれるため、ミスの早期発見に役立ちます。

「variable might not have been initialized(変数が初期化されていません)」

変数を宣言しただけで、一度も値を入れない(初期化しない)まま使おうとすると、このエラーが発生します。

エラーが発生するコード:

public class Main {
  public static void main(String[] args) {
    int price; // 宣言のみで初期化していない
    // 初期化されていない変数を使おうとしている
    System.out.println(price);
  }
}
// エラーメッセージ:
// Main.java:5: error: variable price might not have been initialized
//   System.out.println(price);
//                      ^
  • 原因
    • 変数 `price` に値が入っていない状態で、その値を表示しようとしたため。
  • 解決策
    • 変数を使う前に、必ず何らかの値を代入して初期化します。`int price = 1000;` のように修正します。

まとめ

この記事では、Javaの変数宣言に関する基礎から実践までを網羅的に解説しました。

  • 変数はデータを格納する箱であり、分かりやすい名前を付けることが重要です。
  • 「型名 変数名 = 初期値;」が基本構文です。
  • データ型にはプリミティブ型と参照型があり、挙動が異なります。
  • 命名規則はキャメルケースが基本で、意味の分かる名前にします。
  • スコープを意識し、定数やvarを適切に使うことでコード品質が向上します。

変数宣言は、Javaプログラミングにおける土台です。この土台がしっかりしていれば、これから学ぶ「配列」や「制御構文」、そしてJavaの核となる「クラスとオブジェクト」の理解もスムーズに進むでしょう。

このブログを検索

  • ()

自己紹介

自分の写真
リモートワークでエンジニア兼Webディレクターとして活動しています。プログラミングやAIなど、日々の業務や学びの中で得た知識や気づきをわかりやすく発信し、これからITスキルを身につけたい人にも役立つ情報をお届けします。 note → https://note.com/yurufuri X → https://x.com/mnao111

QooQ