![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?e8efa67)
No.7ベストアンサー
- 回答日時:
>a=0 or 6が実は定数-1になってしまいます。
>というのはどうしてなのでしょうか
a = 0 or 6 と普通にaに代入すると
これはビット演算ですから a に6が入ります。
しかし、if文の中では a=0 と 6 の論理演算になります。
演算子の優先順序など、詳しいことは#6の方の説明の中にあります。
そして (( a = 0 ) or 6 ) の評価が-1(True)となります。
上記でも分かると思いますが、6が単独で残ってしまうのが問題で、
必ずTrueになってしまいます。
No.6
- 回答日時:
> 0 or 6 では単純な計算式ですから 6 となります。
Or演算子は論理和ではなくbit和で計算されます。
00000000と00000110のbit和で00000110
一方、=演算子はbool値を帰します。
また、演算子には優先順位があって、= の方が Or より強い。
> If a = 0 Or 6 Then
は
((a = 0) Or 6)
が評価され
aが0の場合は
(a=0)の値はTrue
2進で書くと
1111111111111111 Or 0000000000000110
でbit和は
1111111111111111
つまり
if True then
aが0以外は
(a=0)の値はFalse
2進で書くと
0000000000000000 Or 0000000000000110
でbit和は
0000000000000110
つまり
if 6 then
if文は0以外はthen節を実行される。
No.5
- 回答日時:
かなり派手に間違っていますね^^;
正しい書き方は#1の方の通りですが、
0 or 6 では単純な計算式ですから 6 となります。
すると 上記のコードは if a = 6 then と同じことになり・・・
ちょっとおかしいですよね。
a = 6と同じなら a が6のときしかifの中に入らないはず!?
実は上記の使い方は二重に論理ミスを犯していまして、
かなりおかしなことになっています。
a = 0 or 6 が実は定数 -1 になってしまっています。
で上記のコードは if -1 then と同じになっています。
この回答への補足
回答ありがとうございます。
かなり派手に間違ってしまいました。
ところで、
>a=0 or 6が実は定数-1になってしまいます。
というのはどうしてなのでしょうか?もうちょっと教えてもらえないでしょうか?
No.4
- 回答日時:
> If a = 0 Or 6 Then
の6というのは、常に6なのでそのif条件には必ず合格(?)します。
正しくは、
If a = 0 Or a = 6 Then
私なら
If (a = 0) Or (a = 6) Then
としますね。
a = (0 Or 6)
というのも無理なんじゃないかなあ。
まあ、VB6にもデバッガがあるので、ifステートメントの条件式の値をウォッチするとよいでしょう。
プリントさせるなら、aだけでなく、条件式の中身も画面上に出すと分かります。
ありがとうございます。
納得できました。
0 or 6が6になるというのは、
00000000
00000110
をorすると6になるからTrueになる、ということであってるでしょうか?
No.2
- 回答日時:
正解は#1の方の書き方で良いと思います。
要は以下のように書いた時、
If [評価式A] Or [評価式B] Then
処理X
ELSE
処理Y
END IF
評価式Aが真 または 評価式Bが真 の時に処理Xが行われます。
質問者さんのような書き方をしてしまうと
a=0が偽と判定されてもBの評価式が「6」としか書いてないので常に真となってしまいます。
※真偽の判断は内部的には 偽が0、真はそれ以外 というようになってます。
その為、0以外の数値などは真と判定されます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) エクセルのマクロについて教えてください。 7 2023/07/04 09:18
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Excel(エクセル) VBAで “:” を含むセルの特定 2 2023/05/11 16:30
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- Visual Basic(VBA) Excel VBA ユーザーフォーム 複数のユーザーフォームの閉じ方。 2 2022/04/27 11:29
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2023/05/23 16:28
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/07/03 09:11
- Visual Basic(VBA) VBAで最新のデータを別シートに転記する方法をお教えください。 3 2022/04/07 19:20
このQ&Aを見た人はこんなQ&Aも見ています
-
「環境が人を育てる」って本当?環境によって人格や生き方は本当に変わるのか
環境が人生に与える影響は実際どれほどのものなのか、専門家の田宮由美さんに伺った。
-
VB6でのファイル作成方法
Visual Basic(VBA)
-
VBの画面サイズについて
Visual Basic(VBA)
-
VB6.0 のformat関数について
Visual Basic(VBA)
-
-
4
SPREAD(GrapeCity)のセルにフォーカスを設定するにはどうしたらいいのでしょうか?
Visual Basic(VBA)
-
5
Flexgridで選択行の列の値を取得したい
Visual Basic(VBA)
-
6
VB6のプロジェクトロードエラーについて
Visual Basic(VBA)
-
7
VB6のメモリ解放に関して
Visual Basic(VBA)
-
8
vb6のVSFlexGridで選択行、列の値を取得し構造体に入れたい
Visual Basic(VBA)
-
9
上下の位置揃えについて
Visual Basic(VBA)
-
10
テキストボックスの入力制限
Visual Basic(VBA)
-
11
MSDNのコレクションがありません。MSDNを再インストールしてください。
Visual Basic(VBA)
-
12
VB6.0の「vbFromUnicode」はVB.NETではどれに相当しますか?
Visual Basic(VBA)
-
13
Visual Basic 6.0 のテキストボックスの最大容量について
Visual Basic(VBA)
-
14
他のモジュールのプロシージャの呼び出したい。
Visual Basic(VBA)
-
15
frxファイルの役目
Visual Basic(VBA)
-
16
ウォッチ式の文字数制限について
Visual Basic(VBA)
-
17
特定行の色を変えたい(FlexGrid)
Visual Basic(VBA)
-
18
Visual Basic 6.0 コンボボックスのChangeイベントが発生しません
Visual Basic(VBA)
-
19
VB6 配列を初期化したい
Visual Basic(VBA)
-
20
Chr(13)とChr(10)の違いは?
PowerPoint(パワーポイント)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
javaのCSVデータ読込についてです
-
VB6,論理演算子Orの使い方がわ...
-
直し方について教えて頂きたい...
-
CASLIIの問題なんですが
-
Excel VBA マクロ 変数を用いた...
-
wsprintf関数の使い方について
-
全取得したデータをjspで順番に...
-
実数からの小数部の取得
-
c# デリゲート関連の命名について
-
javaで電卓を作りたいのですが...
-
ダブルクォーテーションのrepla...
-
C# タスクバーを隠したフォーム...
-
ArrayList内HashMapの取得
-
文字コード判別ルーチンGet...
-
ArrayListを利用する問題
-
csv出力について
-
Selenium IDEでexportしたコー...
-
ページング
-
yyyymmddからyyyy/mm/d...
-
ArrayList でスタックを
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ダブルクォーテーションを含む...
-
wsprintf関数の使い方について
-
ArrayListの要素数の上限
-
BCD形式で時刻を!
-
javaのCSVデータ読込についてです
-
DateTimePickerに値を入れたい...
-
C言語の変数(LSB)の合わせ込...
-
JSPでHashMap・配列の変数の値...
-
matchesを否定文として使う方法...
-
JSPでの計算結果表示
-
hiddenの値を消したくない!
-
結合した文字列をファイル名に...
-
excel vba 時間計算と条件分岐...
-
実行シェルからCOBOLへパラメー...
-
long型に値を代入したい。
-
【Excel VBA】繰り返し処理がで...
-
Stringクラスの変数の格納アド...
-
PSQLExceptionが発生する
-
ResultSetの内部構造(Java)
-
String str = "a\\\\b\\\\c";
おすすめ情報