If you are using a ternary operator like that, presumably it could be replaced by:
if (a) { b; }
which is much, much better. (The intent is clearer, so the code is easier to read, and there will be no performance loss.)
However, if you are using the ternary operator as an expression, i.e.
printf("%d cat%s", number_of_cats, number_of_cats != 1 ? "s" : <nothing>);
a = b*c + (d == 0 ? 1 : <nothing>);
then the <nothing>
value depends on the context it is being used in. In my first example, <nothing>
should be ""
, and in the second it should be 0
.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…