NSLogでブールフラグを印刷する方法


回答:


503

ここに私がそれをする方法があります:

BOOL flag = YES;
NSLog(flag ? @"Yes" : @"No");

?: 次の形式の3項条件演算子です。

condition ? result_if_true : result_if_false

必要に応じて、実際のログ文字列を適宜置き換えてください。


55
:あまりにもこのマクロ、作るのは簡単#define StringFromBOOL(b) ((b) ? @"YES" : @"NO")
jscs

3
これはどのようにして非常に多くの票を持っていますか?これはブール値を記録する方法ではなく、ブール値に応じて異なる値を記録する方法です。
Acey 2014年

7
@Acey:どうやら、人々(元の質問者を含む)は後者にもっと興味を持っていたようです。私が推測を危険にさらしたとしたら、それは値を直接出力すること(0/1)があまり意味がないためです。
BoltClock

1
@BoltClock 0/1はログ出力で意味がありませんか?私たちはここにいるすべてのプログラマーだと思いましたlol
Cbas

298

%d0はFALSE、1はTRUEです。

BOOL b; 
NSLog(@"Bool value: %d",b);

または

NSLog(@"bool %s", b ? "true" : "false");

データ型に基づい%@て次のように変更します

For Strings you use %@
For int  you use %i
For float and double you use %f

16

ブール値は整数のみであり、単なるタイプキャスト値です...

typedef signed char     BOOL; 

#define YES (BOOL)1
#define NO (BOOL)0

BOOL value = YES; 
NSLog(@"Bool value: %d",value);

出力が1の場合はYES、それ以外の場合はNO


1
いいえ、ブールはsigned charです。0または1以外の値が指定されている場合、式が誤って評価される可能性があります。
CodaFi

いいえ、BOOLのタイプはコンパイラー(32ビットと64ビット)に依存し、多くの場合boolと同じタイプではありません。一方、boolは標準型のboolであり、signed charとは異なります。
gnasher729

14

Swiftでは、あなたはただ行うことができることに注意してください

let testBool: Bool = true
NSLog("testBool = %@", testBool.description)

これはログに記録されます testBool = true


Swiftではそのまま使用できますprint()
ドミトリー

10

これはDevangの質問への直接の回答ではありませんが、BOOLをログに記録することを検討しているユーザーには、以下のマクロが非常に役立つと思います。これにより、ブール値がログアウトされ、変数の名前で自動的にラベルが付けられます。

#define LogBool(BOOLVARIABLE) NSLog(@"%s: %@",#BOOLVARIABLE, BOOLVARIABLE ? @"YES" : @"NO" )

BOOL success = NO;
LogBool(success); // Prints out 'success: NO' to the console

success = YES;
LogBool(success); // Prints out 'success: YES' to the console

特に変数名を表示するトリックを備えた便利なマクロ。個人的には、混乱を避けるためにパラメーター名としてBOOLを使用しません。
jk7

8

AppleのFixItは%hhdを提供しましたが、これは私のBOOLの値を正しく与えてくれました。


4

4つの方法で確認できます

最初の方法は

BOOL flagWayOne = TRUE; 
NSLog(@"The flagWayOne result is - %@",flagWayOne ? @"TRUE":@"FALSE");

2番目の方法は

BOOL flagWayTwo = YES; 
NSLog(@"The flagWayTwo result is - %@",flagWayTwo ? @"YES":@"NO");

3番目の方法は

BOOL flagWayThree = 1;
NSLog(@"The flagWayThree result is - %d",flagWayThree ? 1:0);

4番目の方法は

BOOL flagWayFour = FALSE; // You can set YES or NO here.Because TRUE = YES,FALSE = NO and also 1 is equal to YES,TRUE and 0 is equal to FALSE,NO whatever you want set here.
NSLog(@"The flagWayFour result is - %s",flagWayFour ? YES:NO);

2
NSArray *array1 = [NSArray arrayWithObjects:@"todd1", @"todd2", @"todd3", nil];
bool objectMembership = [array1 containsObject:@"todd1"];
NSLog(@"%d",objectMembership);  // prints 1 or 0

2

Swiftでは、ブール値を出力するだけで、trueまたはとして表示されfalseます。

let flag = true
print(flag) //true

1

これを行う方法は次のとおりです。

BOOL flag = NO;
NSLog(flag ? @"YES" : @"NO");

これは基本的に、4年前の@BoltClockの回答の一部の繰り返しです。
jk7

0
//assuming b is BOOL. ternary operator helps us in any language.
NSLog(@"result is :%@",((b==YES)?@"YES":@"NO"));

(b == YES)は、bと同じです。リストにあるように、コンパイラーのオプティマイザーを使用して(b?@ "YES":@ "NO")に戻します
Armand
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.