Jak wydrukować flagę logiczną w NSLog?

311

Czy istnieje sposób na wydrukowanie wartości flagi Boolean w NSLog?

Devang
źródło

Odpowiedzi:

503

Oto jak to robię:

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

?: jest trójskładnikowym operatorem warunkowym formy:

condition ? result_if_true : result_if_false

W razie potrzeby odpowiednio zastąp ciągi dziennika.

BoltClock
źródło
55
Łatwo też zrobić z tego makro:#define StringFromBOOL(b) ((b) ? @"YES" : @"NO")
jscs
3
Jak to ma tyle głosów? To NIE jest sposób rejestrowania wartości logicznej, to sposób rejestrowania różnych wartości w zależności od wartości logicznej.
Acey
7
@Acey: Najwyraźniej ludzie (w tym pierwotny pytający) byli bardziej zainteresowani tym ostatnim. Jeśli miałbym zaryzykować zgadywanie, to dlatego, że bezpośrednie drukowanie wartości (0/1) nie ma większego znaczenia.
BoltClock
1
@ BoltClock 0/1 nie ma znaczenia w danych wyjściowych dziennika? Myślałem, że wszyscy jesteśmy tutaj programistami lol
Cbas
298

%d, 0 to FAŁSZ, 1 to PRAWDA.

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

lub

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

Na podstawie typu danych %@zmienia się w następujący sposób

For Strings you use %@
For int  you use %i
For float and double you use %f
SashaQbl
źródło
16

Wartości logiczne to tylko liczby całkowite, są to po prostu wartości rzutowane, takie jak ...

typedef signed char     BOOL; 

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

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

Jeśli wyjście wynosi 1, TAK w przeciwnym razie NIE

Chandan Shetty SP
źródło
1
Nie, bool jest signed char. Twoje wyrażenie może potencjalnie zostać ocenione nieprawidłowo, jeśli zostanie podana wartość inna niż 0 lub 1.
CodaFi
Nie, typ BOOL zależy od twojego kompilatora (32 vs 64 bit) i często nie jest tego samego typu co bool. bool, z drugiej strony, to bool, który jest typem standardowym, a nie tym samym co znak podpisany.
gnasher729
14

Pamiętaj, że w Swift możesz to zrobić

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

To się zaloguje testBool = true

arcticmatt
źródło
W Swift możesz po prostu użyć print().
Dmitry
10

Chociaż nie jest to bezpośrednia odpowiedź na pytanie Devanga, uważam, że poniższe makro może być bardzo pomocne dla osób chcących rejestrować BOOL-y. Wyloguje to wartość bool, a także automatycznie oznaczy ją nazwą zmiennej.

#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
źródło
Przydatne makro, szczególnie przy wyświetlaniu nazwy zmiennej. Osobiście nie użyłbym BOOL jako nazwy parametru, aby uniknąć nieporozumień.
jk7
8

Apple FixIt dostarczył% hhd, co poprawnie dało mi wartość mojego BOOL.

green_knight
źródło
4

Możemy to sprawdzić na cztery sposoby

Pierwszy sposób to

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

Drugi sposób to

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

Trzeci sposób to

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

Czwarty sposób to

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

W Swift możesz po prostu wydrukować wartość logiczną, która zostanie wyświetlona jako truelub false.

let flag = true
print(flag) //true
Tamás Sengel
źródło
1

Oto jak możesz to zrobić:

BOOL flag = NO;
NSLog(flag ? @"YES" : @"NO");
SAQIB SOHAIL BHATTI
źródło
Jest to w zasadzie powtórzenie części odpowiedzi @BoltClock sprzed czterech lat.
jk7
0
//assuming b is BOOL. ternary operator helps us in any language.
NSLog(@"result is :%@",((b==YES)?@"YES":@"NO"));
Kursat Turkay
źródło
(b == TAK) to to samo co tylko b. zgodnie z listą, polegasz na optymalizatorze kompilatora, aby zredukować go z powrotem do (b? @ „TAK”: @ „NIE”)
Armand