C++中,bool怎么用?

举个例子,不要太简单,也不要太复杂的... 举个例子,不要太简单,也不要太复杂的 展开
 我来答
White_MouseYBZ
2015-10-22 · TA获得超过4万个赞
知道大有可为答主
回答量:2.1万
采纳率:82%
帮助的人:6575万
展开全部

这是两个风马牛不相及的变量类型关键字,只是因为拼法相同,仅区别于大小写,题目才把它们拼凑在了一起。它们区别大了:

  1. 类型不同:bool是C++定义的布尔类型,BOOL是微软定义的int类型(就是int的别名);

  2. 取值不同:bool的取值只有0(false)、1(true)两个,而BOOL的取值是int范围;

  3. 长度不同:bool是单字节(8位二进制)类型,BOOL与int长度相同。

下面就2作进一步说明:有一种说法认为bool是两值类型——这没错,它的取值只有0和1,而BOOL是三值逻辑(取FALSE(0)、TRUE(>0)和ERROR(-1))——这错误的,它的取值与int完全吻合,因为它是用typedef int BOOL;定义的int的别名。下面的代码能验证以上表述:

//#include "stdafx.h"//If the vc++6.0, with this line.
#include <iostream>
#include "windows.h"
using namespace std;
int main(void){
    bool x=(bool)8;//必须强制,因类型不匹配
    BOOL y=47819,z=-78;//无需强制,它就是int
    cout << "bool: x = " << x << endl;//输出是1而非8,因bool型只取0和1
    cout << "BOOL: y = " << y << "  z = " << z << endl;//赋什么值就输出什么
    return 0;
}

输出是:

BOOL类型常常用作windows的API函数的返回值,这些函数大都返回TRUE(>0)/FALSE(0)/ERROR(-1),但这不是BOOL类型就是三值逻辑的理由,就像strcmp函数返回int类型的-1、0和1三个值,总不能说int是三值逻辑吧!windows的API使用BOOL完全是体现一种代码风格和拉高阅读性能。

海菜家的北北
2018-04-12 · TA获得超过2225个赞
知道小有建树答主
回答量:14
采纳率:25%
帮助的人:2187
展开全部

bool类型在每一种语言中都是有相同的含义,即真那就是true,是假就为false,但在不同的语言中判断一个布尔值是否为真有所不同。

C++中如果值非零就为True,为零就是False。比如:bool b;b=(12) //此时b为false

【C语言中BOOL命令的使用方法】

一般来说 bool 作为boolean类型来使用,不是命令,是一种类型,表示真/假。

C语言里面没有bool(布尔)类型
C++里面才引入bool类型
C语言里面用数值0表示假,非0整数表示真(一般是1)

C语言中bool类型可以自定义:
#define bool int
#define false 0
#define true 1

示例代码:


#include <iostream>using namespace std; int main(int argc, char* argv[]){ bool test = true;cout << "the output is number " << test << endl;cout << "the output is bool(use boolalpha) " << boolalpha << test << endl;cout << "the output is number(use noboolalpha) " << noboolalpha << test << endl;return 0;}

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2013-04-23
展开全部
只要是涉及到两个选项的,都可以用bool,当然主要还是用在“是否”判断上,例如判断循环是否需要中止等。
bool condition=true;
while(condition)
{
.....
if (某个变量a==1 && 某个变量b>13) //当然这个条件可以是很复杂的条件 condition = false;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
乡巴佬哈哈巨蟹
2017-12-11
知道答主
回答量:4
采纳率:0%
帮助的人:3574
展开全部
为什么要用bool类型、
因为我曾经看到过C++程序员,使用着C++的编译器,却仍然在使用BOOL、TRUE、FALSE等宏来表达现实世界中的二值事物,令我很不解,前去询问才知是“习惯”。显然,它以前是使用C语言编程的,而且使用这些宏做了很多事,也从来没有感觉到不好,为什么要用内置的bool类型呢,至少有两个优点,下面分别讨论。
学习C语言阔以莱这个裙,前面是497,中间是594,最后是374,组合起来就可以找到,我想说的是,除非你是对学习日语非常热爱,如果只是凑热闹的话,就不要来了。

1.1.1. 提高程序的可读性
Boolean(布尔)数据在C++中使用内置类型bool表示。bool类型的变量只可能有两个值true或false,在现实世界中它用于表示“是”或“否”、“高”或“低”等这种只有两个状态的事物再自然不过。例如用于表示检测某年是否润年的函数,其返回值类型显示只有两种情况“是”或“否”,如代码1 -1所示。
// 代码 1-1
bool IsLeapYear( const unsigned int year)
{
return (year % 4==0 && year % 100 !=0) || (year %400 ==0);
}
这样用一个bool型变量来表示该函数的返回值,看起来非常自然。而在C语言(C99之前,而且目前很多编译器没有完整实现C99)中没有内置boolean类型,只能使用宏、typedef、enum等手段模拟出bool类型来,如代码1-2使用enum模拟。
// 代码 1-2
typedef enum {
false = 0,
true = 1
}bool;
有了这样的定义,使得在C语言的编译器中代码1-1中的代码也是可以编译的,而在Windows的API中则使用typedef了宏定义了一种类型BOOL,其实实现了与bool同样的效果。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ORDRO1314
2017-11-12 · TA获得超过100个赞
知道答主
回答量:20
采纳率:33%
帮助的人:3.7万
展开全部
这个类型也就是用来判断一个条件是真或者是假,只有两个值。true 或者false;对应的值分别为1 或者 0;举例:
#include <iostream>
using namespace std;
BOOL fucn(int a, int b)//一般在C++中使用大写。小写也可用
{ return a<b?TRUE:FALSE; }
int main()
{
int x=8,y=-5;
if(fucn(x,y))//可以用来作if语句的判断
...
while(fucn(x,y))//也可以做循环条件的判断
...
//等等各种判断
return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(16)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式