C/C++(基础-运算符详解)
运算符
任何表达式是有值的
int a = 2;
int b = 3;
a*=b+4;//a=a*(b+4);"*"*=的优先级层次和=号的层次一样。
printf("%d\n",a);//14
%求与运算符号,等同于被求余数的数。而且运算符必须是整数。有时也能用于求整除的数(i%5==0)。
++自增运算:
++自己独立构成表达式的时候,前后++没有区别,如果++构成的表达式参与了其他表达式的构成运算,前++相当于加一运算,后++先使用后加一,完结后加1
int a = 5;
int b = 6;
printf("%d\n",a+++b);//12,编译原理编译到a后看能否构成表达式,a++构成表达式
关系表达式的运算结果只有1和0,常用语判断。
int x = 5;
int y = 6;
if(x == y ) {
printf("x == y\n");
}else{
printf("x != y\n");
}
//x != y;
if(x=y) {//y的值赋给x,if的条件除了0其余为真,内部是以非0判断为真的。
printf("x==y\n");
}else{
printf("x!=y\n");
}
//x==y;
[5,100)的表示:
5<= x <100错误的原因:
优先级相同,则从左至右算,5 <= x,先运算,运算之后将5 <= x的值(0或者1)再和100进行运算。
5 <= x && x < 100;
&&:将两侧的操作数逻辑化,0为假,非0为真。```c
int a = 3;
int b = 5;
if(a && 5 ) {//3为真,5为真
printf("xxxx\n");
}
if((a-a) && (b-a) ) {//a-a=0w为假
printf("xxxx\n");
}else{
printf("oooo\n");
}
!的优先级高于&&,||
```c
int a = 3;
int b = 5;
!a < b;//0 < 5 ==== !0
!(a < b);//==== 0
短路现象:
int a = 44;
int b = 55;
if( (a > 40 ) || (b = 66) ) {
printf("xxxxx%d\n",d);
} else{
printf("ooooo%d\n",d);
}
//a>40为真,(||只要有一个为真全真)发生短路d=55(d=66的赋值运算没有执行)
if( (a < 40) || (b =66 ) ) {
printf("xxxxxd%\n",d);
}else{
printf("ooooo%d\n",d);
}
//xxxxx66,第一个不成立,继续判断第二个,b=66,为真。
int a = 44;
int b = 55;
if( (a < 40 ) && (b = 66) ) {
printf("xxxxx%d\n",d);
} else{
printf("ooooo%d\n",d);
}
//a<40为假,(&&只有两个为真全真)发生短路d=55(d=66的赋值运算没有执行)
if( (a > 40) && (b =66 ) ) {
printf("xxxxxd%\n",d);
}else{
printf("ooooo%d\n",d);
}
//xxxxx66,第一个不成立,(&&只有两个为真全真)不会判断第二个直接为假。
短路提高了效率。
三元运算
a>b? c:(d>55?10:20);//从右至左
int t;
if(d>55)
t = 10;
else
t = 20;
if(a>b)
printf("%d",c);
else
printf("%d",t);
逗号表达式:
int xx;
xx = 1+1,2+1,3+2,5*5,5*7;//顺序求值遇到","相当于一个表达式,做赋值运算
printf("xx%d\n",xx);//2
xx = (1+1,2+1,3+2,5*5,5*7);//顺序求值,括弧优先级高,一次根据","最右边赋值。
printf("xx%d\n",xx);//35
printf("xx%d\n",1+1,2+1,3+2,5*5,5*7);//根据第一个,但是有问题
printf("aa%d xx%d\n",aa 1+1,2+1,3+2,5*5,5*7);//这样是有问题
printf("xx%d\n",(1+1,2+1,3+2,5*5,5*7 ) );
sizeof:类型大小运算
sizeof是一个关键字而不是一个函数,走关键字的路,让别人去说函数吧。
char c = 1;
int i = 10;
printf("sizeof(c+i)%d\n",sizeof(c+i));//4显示int的类型
printf("sizeof c+i %d\n",sizeof c+i );//11,sizeof没有括弧的时候它的运算符的游戏那几高于+,先算出c的类型长度位1,在参与运算
总结:() !,sizeof 算数 > 关系 > 逻辑(除!)?,:,= ,
C/C++(基础-运算符详解)的更多相关文章
- Net is as typeof 运行运算符详解 net 自定义泛型那点事
Net is as typeof 运行运算符详解 概述 在了解运行运算符的前提我们需要了解什么是RTTI ,在任何一门面向对象的语言中,都有RTTI这个概念(即 运行时). RTTI(Run-Ti ...
- I2C 基础原理详解
今天来学习下I2C通信~ I2C(Inter-Intergrated Circuit)指的是 IC(Intergrated Circuit)之间的(Inter) 通信方式.如上图所以有很多的周边设备都 ...
- python 3.x 爬虫基础---Urllib详解
python 3.x 爬虫基础 python 3.x 爬虫基础---http headers详解 python 3.x 爬虫基础---Urllib详解 前言 爬虫也了解了一段时间了希望在半个月的时间内 ...
- RabbitMQ基础知识详解
什么是MQ? MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.MQ是消费-生产者模型的一个典型的代表,一端往消息队列中不断写入消息,而另一端则可以读取队列中 ...
- Nmap扫描教程之基础扫描详解
Nmap扫描教程之基础扫描详解 Nmap扫描基础扫描 当用户对Nmap工具了解后,即可使用该工具实施扫描.通过上一章的介绍,用户可知Nmap工具可以分别对主机.端口.版本.操作系统等实施扫描.但是,在 ...
- jmeter 基础功能详解
jmeter 基础功能详解 thread group:包含一组线程,每个线程独立地执行测试计划. sampler:采样器,有多种不同的sample实现,用来发起各种请求,如http请求,jdbc请求, ...
- hadoop基础-SequenceFile详解
hadoop基础-SequenceFile详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.SequenceFile简介 1>.什么是SequenceFile 序列文件 ...
- Cisco路由技术基础知识详解
第一部分 请写出568A的线序(接触网络第一天就应该会的,只要你掐过,想都能想出来) .网卡MAC地址长度是( )个二进制位(16进制与2进制的换算关系,只是换种方式问,不用你拿笔去算) A.12 ...
- RabbitMQ,Apache的ActiveMQ,阿里RocketMQ,Kafka,ZeroMQ,MetaMQ,Redis也可实现消息队列,RabbitMQ的应用场景以及基本原理介绍,RabbitMQ基础知识详解,RabbitMQ布曙
消息队列及常见消息队列介绍 2017-10-10 09:35操作系统/客户端/人脸识别 一.消息队列(MQ)概述 消息队列(Message Queue),是分布式系统中重要的组件,其通用的使用场景可以 ...
随机推荐
- mongodb 的数据备份与恢复
导入/导出可以操作是本地的或远程的,所以都有以下通用选项[如果是操作本地机并且没有密码的话可以省去]: 1.-h host 主机 ...
- 洛谷1462 通往奥格瑞玛的道路 最短路&&二分
SPFA和二分的使用 跑一下最短路看看能不能回到奥格瑞玛,二分收费最多的点 #include<iostream> #include<cstdio> #include<cs ...
- java解析json文件(省,市,区)
[{"code":"11","name":"北京市"},{"code":"12" ...
- 如何使用Java创建Excel(.xls 和 .xlsx)文件 并写入数据
1,需要依赖的jar包, <!-- POI(operate excel) start --> <!-- the version of the following POI packag ...
- PKU 3281 Dining 网络流 (抄模板)
题意: 农夫约翰为他的牛准备了F种食物和D种饮料.每头牛都有各自喜欢的食物和饮料,而每种食物或饮料只能分配给一头牛.最多能有多少头牛可以同时得到各自喜欢的食物和饮料? 思路: 用 s -> 食物 ...
- 洛谷 P1542 包裹快递
P1542 包裹快递 题目描述 小K成功地破解了密文.但是乘车到X国的时候,发现钱包被偷了,于是无奈之下只好作快递员来攒足路费去Orz教主…… 一个快递公司要将n个包裹分别送到n个地方,并分配给邮递员 ...
- 二 HTable 源码导读
户端调优的方法里面无非就这么几种:1)关闭autoFlush2)关闭WAL日志3)把writeBufferSize设大一点,一般说是设置成5MB 经过实践,就第二条关闭日志的效果比较明显 ...
- NYOJ 541 最强的战斗力
最强DE 战斗力 时间限制:1000 ms | 内存限制:65535 KB 难度: 描写叙述 春秋战国时期,赵国地大物博,资源很丰富.人民安居乐业.但很多国家对它虎视眈眈.准备联合起来对赵国发起一 ...
- uvalive 6669 hidden tree(好壮压dp)
题目见option=com_onlinejudge&Itemid=8&page=show_problem&problem=4681">here 题意:给一个序列 ...
- TCP/IP具体解释--TCP的分段和IP的分片
写在前面: 分组能够发生在运输层和网络层.运输层中的TCP会分段,网络层中的IP会分片.IP层的分片很多其它的是为运输层的UDP服务的,因为TCP自己会避免IP的分片,所以使用TCP传输在IP层都不会 ...