配列のUBoundがLBoundがより小さいことはあり得るか
ツイッターでVBAのお題として出したものです。
LBound(ary) > UBound(ary)
この条件を満たすような配列は存在するか?
問題を出したツイート
変数aryについて、
LBound(ary) > UBound(ary)
この条件を満たすような配列は存在するかについての問題です。
以下の文章で正しいものはどれか?
・そんな配列は存在しない
・存在するがVBAで意図的に作ることはできない
・存在するしVBAで簡単に作ることができる
・にゃんともいえない

https://twitter.com/yamaoka_ss/status/1300811819997491202
回答・解説のツイート

https://twitter.com/yamaoka_ss/status/1301146057494024193
「にゃんともいえない」もうこれは正解とも言えるけど、、、
LBound(ary) > UBound(ary)
このような配列は存在するし、VBAで簡単に作成できます。
つまり実際のVBAで書くと、
If IsArray(ary) Then
If LBound(ary) > UBound(ary) Then
MsgBox "これだ"
End If
End If
このような状態の配列です。
LBound(ary) > UBound(ary)
これがどのような時に発生するかというと、
長さ0の空の配列の場合に起こります。
LBound = 0
UBound = -1
このようになっている状態です。
Stringの""と同じようなものだと考えれば良いでしょう。
UBound(ary) - LBound(ary) + 1
例えば、
Dim ary(0 to 2)
2 - 0 + 1 = 3
3個の要素を持つ配列になります。
要素数0の空の配列は、
-1 + 0 + 1 = 0
0個の要素を持つ配列という事になります。
ary1 = Array()
※ary1は、VariantもしくはVariant配列でなければなりません。
ary2 = Split("")
※ary2は、VariantもしくはString配列でなければなりません。
1年前のアプデで問題が発生したのは記憶に新しいところです。
説明は以上です。
https://twitter.com/yamaoka_ss/status/1162215395723399169

同じテーマ「ツイッター出題回答 」の記事
囲碁で相手の石を囲んで取るアルゴリズム
VBAで「3Lと5Lのバケツで4Lの水を作る」を解く
言語依存の関数を使用できるFormulaLocal
配列のUBoundがLBoundがより小さいことはあり得るか
コレクションの要素を削除する場合
greeenはgreenに、greeeeeNをGReeeeNに変換
数値変数の値を別の変数を使わずに入れ替える
Rangeオブジェクトを受け取り"行数,列数"で埋める
数式の関数の使用回数、関数名を配列で返す
日付型と通貨型のValueとValue2について
小文字"abc"を大文字"ABC"に変換する方法
新着記事NEW ・・・新着記事一覧を見る
WshNetwork(ネットワークドライブの割り当て等)|VBA技術解説(2025-04-09)
TRANSLATE関数(翻訳) DETECTLANGUAGE関数(言語識別)|エクセル入門(2025-04-08)
QRコード、バーコード作成の覚え書き|エクセル関数応用(2025-04-05)
TRIMRANGE関数(セル範囲をトリム:端の空白セルを除外)|エクセル入門(2024-08-30)
正規表現関数(REGEXTEST,REGEXREPLACE,REGEXEXTRACT)|エクセル入門(2024-07-02)
エクセルが起動しない、Excelが立ち上がらない|エクセル雑感(2024-04-11)
ブール型(Boolean)のis変数・フラグについて|VBA技術解説(2024-04-05)
テキストの内容によって図形を削除する|VBA技術解説(2024-04-02)
ExcelマクロVBA入門目次|エクセルの神髄(2024-03-20)
VBA10大躓きポイント(初心者が躓きやすいポイント)|VBA技術解説(2024-03-05)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.繰り返し処理(For Next)|VBA入門
4.変数宣言のDimとデータ型|VBA入門
5.RangeとCellsの使い方|VBA入門
6.ひらがな⇔カタカナの変換|エクセル基本操作
7.セルのクリア(Clear,ClearContents)|VBA入門
8.メッセージボックス(MsgBox関数)|VBA入門
9.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
10.条件分岐(Select Case)|VBA入門
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。