【VBAスタンダード対策】配列の多様な宣言構造を攻略!
VBAの配列には、宣言時に要素数を固定する「静的配列」と、後からサイズを変更できる「動的配列」があります。それぞれの宣言文法と、インデックス(添字)の構造的な決まりを整理しましょう。
1. 問題:配列の宣言方法と要素数の関係
【 問題 】 下記のA~Dの宣言のうち、VBAの文法として誤っているもの、または実行時にエラーとなる可能性が高い構造はどれでしょうか?
A: Dim List(5) As String
B: Dim List() As Integer
C: Dim List(1 To 10) As Double
D: Dim List(X) As Variant ' ※Xは変数とする
B: Dim List() As Integer
C: Dim List(1 To 10) As Double
D: Dim List(X) As Variant ' ※Xは変数とする
① A:要素数が5つの静的配列として宣言されている
② B:後でReDimが必要な動的配列として正しく宣言されている
③ C:添字の下限を1、上限を10として正しく宣言されている
④ D:宣言時に変数を使ってサイズを指定することはできない
2. 正解:配列宣言の制約に関する正解
正解: ④ D(および ① の解釈)
3. 解説:静的と動的、それぞれの宣言ルール
VBAの配列構造において、最も注意すべきは「Dimによる宣言時に変数を使えるか」という点です。
[ 配列宣言の構造ルール図 ]
■ A:静的配列 Dim List(5)
実は要素数は 6つ です(0,1,2,3,4,5)。試験では「5」と書くと0番目を含めて6つになる構造がよく問われます。
■ B:動的配列 Dim List()
カッコの中を空にするのが動的配列の構造です。この時点ではメモリは確保されず、後で ReDim を使ってサイズを決定します。
■ C:範囲指定 Dim List(1 To 10)
「1から始まる」とはっきり指定する構造です。Option Base 1 を使わずに下限を固定できるため、実務で推奨される書き方です。
■ D:変数による指定 Dim List(X)
【重要】 Dimステートメントで要素数を指定する際、変数を使うことはできません。変数の値に応じてサイズを決めたい場合は、一度「B」の形で宣言し、その後 ReDim List(X) とする必要があります。
■ A:静的配列 Dim List(5)
実は要素数は 6つ です(0,1,2,3,4,5)。試験では「5」と書くと0番目を含めて6つになる構造がよく問われます。
■ B:動的配列 Dim List()
カッコの中を空にするのが動的配列の構造です。この時点ではメモリは確保されず、後で ReDim を使ってサイズを決定します。
■ C:範囲指定 Dim List(1 To 10)
「1から始まる」とはっきり指定する構造です。Option Base 1 を使わずに下限を固定できるため、実務で推奨される書き方です。
■ D:変数による指定 Dim List(X)
【重要】 Dimステートメントで要素数を指定する際、変数を使うことはできません。変数の値に応じてサイズを決めたい場合は、一度「B」の形で宣言し、その後 ReDim List(X) とする必要があります。
1. ここが試験に出る!: スタンダード試験では「静的配列の宣言に変数を使っていないか」「動的配列なのにカッコの中に数字を書いていないか」といった、DimとReDimの使い分けが厳格に問われます。
2. エンジニアの視点: Java 17などの言語では `int[] list = new int[x];` のように変数での初期化が当たり前ですが、VBAは「コンパイル時にサイズが決まるもの(Dim)」と「実行時に決まるもの(ReDim)」を構造的に区別しています。この「理系NEO」な厳密さを理解すると、メモリ管理のミスが減りますね。
4. まとめ
「Dimで変数は不可、サイズ変更はReDim」。この配列宣言のルールを守ることで、実行時のエラー(「定数式が必要です」など)を未然に防ぐことができます。配列もまた、宣言という「設計図」を正しく書くことで、初めて大量のデータを安全に格納する器として機能するのです。
PR