c语言位运算符解释_c语言逻辑关系运算符

c语言位运算符解释_c语言逻辑关系运算符      位操作是程序设计中对位模式按位或二进制数的一元和二元操作,在许多古老的微处理器上,位运算比加减运算略快,通常位运算比乘除法运算要快很多。按位取反:~’~’是一元运算符,用来对一个二进制数按位取反,把0变为1,把1变为0。如下例子所示。…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

位操作是程序设计中对位模式按位或二进制数的一元和二元操作,在许多古老的微处理器上,位运算比加减运算略快,通常位运算比乘除法运算要快很多。
按位取反:~
‘~’是一元运算符,用来对一个二进制数按位取反,把0变为1,把1变为0。如下例子所示。

~(10001100)          //表达式
  (01110011)          //结果值

进行取反运算时符号位也会取反
按位与:&
‘&’是二元运算符,通过逐位比较两个运算对象,生成一个新值。对于每个位,只要两个运算对象中相同的位有一个0就是0,两个都为1时才为1。

(01101101)&(10001001)          //表达式
(00001001)                                  ;//结果值

按位或:|
‘|’是二元运算符,对应位的二进制只要有一个为1就为1,两个都为0才为0。

(10010011)  |  (00111101)          //表达式
(10111111)                                 //结果值

按位异或:^
‘^’是二元运算符,两个二进制序列进行异或运算,对应位的二进制相同为0,相异为1。

(10010011) ^ (00111101)           //表达式
(10101110)                                //结果值

逻辑运算符一般在if语句中使用,包括逻辑与(&&)、逻辑或(||)、逻辑非(!)
逻辑与(&&):
参与运算的两个表达式都为真时,结果才为真,否则为假。
在c语言中,0为假,非0就为真

	int a = 10;
	int b = 0;
	if (a && b)
	{ 
   
		printf("hehe\n");
	}

a的值是10,为真,b的值是0,为假。
此时a&&b的结果就是0,为假,不会输出hehe。

	int a = 10;
	int b = 5;
	if (a && b)
	{ 
   
		printf("hehe\n");
	}

当把b改成5时,此时b也为真,逻辑与两侧都为真,此时a&&b结果是1,输出hehe。
逻辑与运算判断出第一个表达式为假后,后面的表达式就不会再计算了

	int a = 0,b = 5,c = 10;
	int i = a && b && c;

此时a=0为假,i的值就是0,不会对b和c两个表达式进行运算了。
逻辑或(||):
参与运算的表达式有一个为真时结果就是真,全为假时才是假。

	int a = 10;
	int b = 0;
	if (a || b)
	{ 
   
		printf("hehe\n");
	}

a为真,b为假,只要有一个真结果就是真,此时输出hehe。

逻辑或运算判断出第一个表达式为真后,后面的表达式就不会再计算了
逻辑非(!):
非假即为真,非真即为假,就是指本来值的反值。

	int a = 10;
	if (!a)
	{ 
   
		printf("hehe\n");
	}

a=10为真,!a运算后结果为0,不会打印hehe。
当a = 0时,!a为1,此时打印hehe。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/186088.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • PSPNet介绍-语义分割

    PSPNet-PyramidSceneParsingNetwork核心模块是金字塔池化模块(pyramidpoolingmodule),它能够聚合不同区域的上下文信息,从而提高获取全局信息的能力。实验表明这样的先验表示(即指代PSP这个结构)是有效的,在多个数据集上展现了优良的效果。1.pyramidpoolingmodule该模块融合了4种不同金字塔尺度的特征,第一行…

    2022年4月5日
    220
  • JsonObject和JsonArray转换问题

    JsonObject和JsonArray转换问题开发过程中遇到需要将调用接口返回的JsonObject转换为JsonArray格式的数据,在使用过成中遇到转换问题,代码如下publicstaticJSONObjectgetRecJsonObj(StringstuId,StringschoolDate){Stringjson;try{json=Jsoup.connect(UrlConfig.URL+”GetStudentInfo?stuId=”+stuId+

    2022年5月31日
    39
  • Java栈结构_栈java

    Java栈结构_栈javaJava栈结构概念典型的栈结构如下图所示:栈结构只能在一端操作,该操作端叫做栈顶,另一端叫做栈底。栈结构按照“后进先出”(LastInFirstOut,LIFO)的方式处理结点数据。栈的特点:其实栈结构是一种受限制的线性数据结构。其限制是仅允许在表的一端进行插入和删除运算。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相

    2022年9月6日
    3
  • vscode自动生成html模板_vscode html插件

    vscode自动生成html模板_vscode html插件初学vue,不熟练使用vscode。发现vscode不能新建文件夹,必须从外部建好之后,在文件–打开文件夹中打开。然后在资源管理器中就可以新建文件或者文件夹了。新建文件后缀写html格式,则就是html文件。然后输入英文的!+tab键即可,或者是输入html:5+tab键。…

    2022年8月21日
    6
  • 优先队列的数据结构_低优先级队列一天只能一场

    优先队列的数据结构_低优先级队列一天只能一场目录一.PriorityQueuePriorityQueue简介继承关系PriorityQueue示例二.Comparable比较器Compara接口三.Comparator比较器Comparator接口四.底层原理一.PriorityQueuePriorityQueue简介PriorityQueue,即优先级队列。优先级队列可以保证每次取出来的元素都是队列中的最小或最大的元素<Java优先级队列默认每次取出来的为最小元素&gt.

    2022年9月23日
    0
  • SecureCRT 命令行备注「建议收藏」

    SecureCRT 命令行备注「建议收藏」&gt;查出某个域名绑定的IPnslookupapi.kaixin001.comNon-authoritativeanswer:Name:a.kaixin001.comAddresses:220.181.100.243,220.181.100.244,220.181.100.242,220.181.100.245,220.181.100.241,220…

    2022年10月21日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号