Как напечатать логический флаг в NSLog?

Ответы:

503

Вот как я это делаю:

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

?: является троичным условным оператором вида:

condition ? result_if_true : result_if_false

Замените фактические строки журнала соответственно там, где это необходимо.

BoltClock
источник
55
Легко сделать этот макрос тоже:#define StringFromBOOL(b) ((b) ? @"YES" : @"NO")
JSCS
3
Откуда у этого столько голосов? Это НЕ как регистрировать логическое значение, это как регистрировать различные значения в зависимости от логического значения.
Эйси
7
@Acey: Видимо, люди (в том числе оригинальный аскер) были более заинтересованы в последнем. Если бы я рискнул предположить, это потому, что печать значения напрямую (0/1) не очень значима.
BoltClock
1
@BoltClock 0/1 не имеет смысла в выводе журнала? Я думал, что мы все здесь программисты, лол
Cbas
298

%d, 0 имеет значение ЛОЖЬ, 1 имеет значение ИСТИНА.

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
SashaQbl
источник
16

Булевы значения - это не что иное, как целые числа, это просто приведенные значения типа ...

typedef signed char     BOOL; 

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

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

Если вывод 1, ДА, иначе НЕТ

Чандан Шетти С.П.
источник
1
Нет, бул это signed char. Ваше выражение может потенциально оценить неправильно, если указано значение, отличное от 0 или 1.
CodaFi
Нет, тип BOOL зависит от вашего компилятора (32 против 64 бит) и часто не совпадает с типом bool. bool, с другой стороны, это bool, который является стандартным типом, а не тем же, что и char со знаком.
gnasher729
14

Обратите внимание, что в Swift вы можете просто

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

Это войдет testBool = true

arcticmatt
источник
В Swift вы можете просто использовать print().
Дмитрий
10

Хотя это не является прямым ответом на вопрос Деванга, я считаю, что приведенный ниже макрос может быть очень полезен для людей, которые хотят регистрировать BOOL. Это позволит выйти из значения 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

FixIt от Apple предоставил% hhd, что правильно дало мне значение моего BOOL.

green_knight
источник
4

Мы можем проверить четыре способа

Первый способ

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

Второй способ

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

Третий способ

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

Четвертый способ

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);
user3182143
источник
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");
САКИБ СОХАЙЛ БХАТТИ
источник
Это в основном повторение части ответа @BoltClock от четырехлетней давности.
jk7
0
//assuming b is BOOL. ternary operator helps us in any language.
NSLog(@"result is :%@",((b==YES)?@"YES":@"NO"));
Курсат Туркай
источник
(b == ДА) так же, как просто б. как указано выше, вы полагаетесь на оптимизатор компилятора, чтобы уменьшить его до (b? @ "YES": @ "NO")
Armand