¿Cómo imprimir la bandera booleana en NSLog?

Respuestas:

503

Así es como lo hago:

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

?: es el operador condicional ternario de la forma:

condition ? result_if_true : result_if_false

Sustituya las cadenas de registro reales en consecuencia, según corresponda.

BoltClock
fuente
55
También es fácil hacer de esto una macro:#define StringFromBOOL(b) ((b) ? @"YES" : @"NO")
jscs
3
¿Cómo tiene esto tantos votos? Esto NO es cómo registrar un valor booleano, así es como registrar diferentes valores dependiendo de un valor booleano.
Acey
77
@Acey: Aparentemente, las personas (incluido el autor de la pregunta original) estaban más interesadas en este último. Si tuviera que adivinar, es porque imprimir el valor directamente (0/1) no es muy significativo.
BoltClock
1
@BoltClock 0/1 no es significativo en la salida del registro? Pensé que todos éramos programadores aquí lol
Cbas
298

%d, 0 es FALSO, 1 es VERDADERO.

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

o

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

Sobre la base de los %@cambios de tipo de datos de la siguiente manera

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

Los booleanos no son más que enteros, solo son valores de tipo fundido como ...

typedef signed char     BOOL; 

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

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

Si la salida es 1, SÍ, de lo contrario NO

Chandan Shetty SP
fuente
1
No, bool es signed char. Su expresión podría potencialmente evaluarse incorrectamente si se proporciona un valor distinto de 0 o 1.
CodaFi
No, el tipo de BOOL depende de su compilador (32 vs 64 bit), y a menudo no es el mismo tipo que bool. bool, por otro lado, es bool, que es un tipo estándar, y no es lo mismo que char firmado.
gnasher729
14

Tenga en cuenta que en Swift, solo puede hacer

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

Esto registrará testBool = true

Arcticmatt
fuente
En Swift solo puedes usar print().
Dmitry
10

Si bien esta no es una respuesta directa a la pregunta de Devang, creo que la siguiente macro puede ser muy útil para las personas que buscan registrar BOOL. Esto cerrará la sesión del valor de bool y lo etiquetará automáticamente con el nombre de la variable.

#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
xizor
fuente
Una macro útil, especialmente con el truco de mostrar el nombre de la variable. Personalmente, no usaría BOOL como nombre de parámetro para evitar confusiones.
jk7
8

FixIt de Apple suministró% hhd, lo que me dio correctamente el valor de mi BOOL.

green_knight
fuente
4

Podemos verificar por cuatro maneras

La primera forma es

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

La segunda forma es

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

La tercera forma es

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

La cuarta forma es

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);
usuario3182143
fuente
2
NSArray *array1 = [NSArray arrayWithObjects:@"todd1", @"todd2", @"todd3", nil];
bool objectMembership = [array1 containsObject:@"todd1"];
NSLog(@"%d",objectMembership);  // prints 1 or 0
Saqib R.
fuente
2

En Swift, simplemente puede imprimir un valor booleano y se mostrará como trueo false.

let flag = true
print(flag) //true
Tamás Sengel
fuente
1

Aquí sabrás como podrás hacerlo:

BOOL flag = NO;
NSLog(flag ? @"YES" : @"NO");
SAQIB SOHAIL BHATTI
fuente
Esto es básicamente una repetición de parte de la respuesta de @BoltClock de hace cuatro años.
jk7
0
//assuming b is BOOL. ternary operator helps us in any language.
NSLog(@"result is :%@",((b==YES)?@"YES":@"NO"));
Kursat Turkay
fuente
(b == SÍ) es lo mismo que solo b. como se indica, confía en el optimizador del compilador para reducirlo a (b? @ "YES": @ "NO")
Armand