Como imprimir um sinalizador booleano no NSLog?

311

Existe uma maneira de imprimir o valor do sinalizador booleano no NSLog?

Devang
fonte

Respostas:

503

Aqui está como eu faço:

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

?: é o operador condicional ternário do formulário:

condition ? result_if_true : result_if_false

Substitua as seqüências de log reais de acordo, quando apropriado.

BoltClock
fonte
55
Também é fácil fazer disso uma macro:#define StringFromBOOL(b) ((b) ? @"YES" : @"NO")
jscs
3
Como isso tem tantos votos? NÃO é como registrar um valor booleano, é como registrar valores diferentes, dependendo de um valor booleano.
Acey
7
@Acey: Aparentemente, as pessoas (incluindo o solicitante original) estavam mais interessadas no último. Se eu arriscar um palpite, é porque imprimir o valor diretamente (0/1) não é muito significativo.
BoltClock
1
@BoltClock 0/1 não é significativo na saída do log? Pensei que estávamos todos os programadores aqui lol
ACB
298

%d, 0 é FALSO, 1 é VERDADEIRO.

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

ou

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

Com base no tipo de dados, as %@alterações são as seguintes

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

Os booleanos nada mais são do que números inteiros, são apenas valores do tipo cast ...

typedef signed char     BOOL; 

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

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

Se a saída for 1, SIM caso contrário NÃO

Chandan Shetty SP
fonte
1
Não, bool é signed char. Sua expressão pode ser avaliada incorretamente se um valor diferente de 0 ou 1 for fornecido.
CodaFi
Não, o tipo de BOOL depende do seu compilador (32 x 64 bits) e geralmente não é do mesmo tipo que bool. bool, por outro lado, é bool, que é um tipo padrão e não é o mesmo que char assinado.
gnasher729
14

Observe que no Swift, você pode simplesmente fazer

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

Isso registrará testBool = true

arcticmatt
fonte
No Swift você pode apenas usar print().
Dmitry
10

Embora essa não seja uma resposta direta à pergunta de Devang, acredito que a macro abaixo pode ser muito útil para pessoas que desejam registrar BOOLs. Isso fará o logout do valor do bool e o rotulará automaticamente com o nome da variável.

#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
fonte
Uma macro útil, especialmente com o truque de exibir o nome da variável. Pessoalmente, eu não usaria BOOL como um nome de parâmetro para evitar confusão.
Jk7
8

O FixIt da Apple forneceu% hhd, o que me deu corretamente o valor do meu BOOL.

green_knight
fonte
4

Podemos verificar por quatro maneiras

A primeira maneira é

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

A segunda maneira é

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

A terceira maneira é

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

O quarto caminho é

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

No Swift, você pode simplesmente imprimir um valor booleano e ele será exibido como trueou false.

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

Aqui está como você pode fazê-lo:

BOOL flag = NO;
NSLog(flag ? @"YES" : @"NO");
SAQIB SOHAIL BHATTI
fonte
Isso é basicamente uma repetição de parte da resposta da @BoltClock de quatro anos atrás.
Jk7
0
//assuming b is BOOL. ternary operator helps us in any language.
NSLog(@"result is :%@",((b==YES)?@"YES":@"NO"));
Kursat Turkay
fonte
(b == SIM) é o mesmo que apenas b. conforme listado, você está confiando em otimizador do compilador para reduzi-la de volta para (b @ "SIM":? @ "NÃO")
Armand