文章责编:柳絮随风
看了本文的网友还看了学历| 高考 中考 考研 自考 成考 外语| 四六级 职称英语 商务英语 公共英语 资格| 公务员 报关员 银行 证券 司法 导游 教师 计算机| 等考 软考
工程|一建 二建 造价师 监理师 咨询师 安全师 结构师 估价师 造价员 会计| 会计证 会计职称 注会 经济师 税务师 医学| 卫生资格 医师 药师 [更多]
首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 求职招聘 论文下载 | ||
2011中考 | 2011高考 | 2012考研 | 考研培训 | 在职研 | 自学考试 | 成人高考 | 法律硕士 | MBA考试 MPA考试 | 中科院 |
||
四六级 | 职称英语 | 商务英语 | 公共英语 | 托福 | 雅思 | 专四专八 | 口译笔译 | 博思 | GRE GMAT 新概念英语 | 成人英语三级 | 申硕英语 | 攻硕英语 | 职称日语 | 日语学习 | 法语 | 德语 | 韩语 |
||
计算机等级考试 | 软件水平考试 | 职称计算机 | 微软认证 | 思科认证 | Oracle认证 | Linux认证 华为认证 | Java认证 |
||
公务员 | 报关员 | 银行从业资格 | 证券从业资格 | 期货从业资格 | 司法考试 | 法律顾问 | 导游资格 报检员 | 教师资格 | 社会工作者 | 外销员 | 国际商务师 | 跟单员 | 单证员 | 物流师 | 价格鉴证师 人力资源 | 管理咨询师考试 | 秘书资格 | 心理咨询师考试 | 出版专业资格 | 广告师职业水平 驾驶员 | 网络编辑 |
||
卫生资格 | 执业医师 | 执业药师 | 执业护士 | ||
会计从业资格考试(会计证) | 经济师 | 会计职称 | 注册会计师 | 审计师 | 注册税务师 注册资产评估师 | 高级会计师 | ACCA | 统计师 | 精算师 | 理财规划师 | 国际内审师 |
||
一级建造师 | 二级建造师 | 造价工程师 | 造价员 | 咨询工程师 | 监理工程师 | 安全工程师 质量工程师 | 物业管理师 | 招标师 | 结构工程师 | 建筑师 | 房地产估价师 | 土地估价师 | 岩土师 设备监理师 | 房地产经纪人 | 投资项目管理师 | 土地登记代理人 | 环境影响评价师 | 环保工程师 城市规划师 | 公路监理师 | 公路造价师 | 安全评价师 | 电气工程师 | 注册测绘师 | 注册计量师 |
||
缤纷校园 | 实用文档 | 英语学习 | 作文大全 | 求职招聘 | 论文下载 | 访谈 | 游戏 |
12、C++操作符优先级:
记忆方法:
去掉一个最高的,去掉一个最低的,剩下的是一、二、三、赋值;双目运算符中,顺序为算术、关系和逻辑,移位和逻辑位插入其中。
--摘自《C语言程序设计实用问答》
问题:如何记住运算符的15种优先级和结合性?
解答:C语言中运算符种类比较繁多,优先级有15种,结合性有两种。
如何记忆两种结合性和15种优先级?下面讲述一种记忆方法。
结合性有两种,一种是自左至右,另一种是自右至左,大部分运算符的结合性是自左至右,只有单目运算符、三目运算符的赋值运算符的结合性自右至左。
优先级有15种,记忆方法如下:
记住一个最高的:构造类型的元素或成员以及小括号。
记住一个最低的:逗号运算符。
剩余的是一、二、三、赋值——意思是单目、双目、三目和赋值运算符。
在诸多运算符中,又分为:算术、关系、逻辑。
两种位操作运算符中,移位运算符在算术运算符后边,逻辑位运算符在逻辑运算符的前面。
再细分如下:
算术运算符*,/,%高于+,-。
关系运算符中:>,>=,<和<=高于==,!=。
逻辑运算符中,除了逻辑求反(!)是单目外,逻辑与(&&)高于逻辑或(||)。
逻辑位运算符中,除了逻辑按位求反(~)外,按位与(&)高于按位半加(^),高于按位或(|)。
Prece dence | Operator | Description | Example | Over loadable | Associativity |
1 | :: | Scope resolution operator | Class::age = 2; | no | left to right |
2 | () | Function call | printf(“Hello world\n”); | yes | left to right |
() | Member initalization | c_tor(int x, int y) : _x(x), _y(y * 10) {} | yes | ||
[] | Array access | array[4] = 2; | yes | ||
-> | Member access from a pointer | ptr->age = 34; | yes | ||
. | Member access from an object | obj.age = 34; | no | ||
++ | Post-increment | for (int i = 0; i < 10; i++) cout << i; | yes | ||
-- | Post-decrement | for (int i = 10; i > 0; i--) cout << i; | yes | ||
dynamic_cast | Runtime-checked type conversion | Y& y = dynamic_cast<Y&>(x); | no | ||
static_cast | Unchecked type conversion | Y& y = static_cast<Y&>(x); | no | ||
reinterpret_cast | Reinterpreting type conversion | int const* p = reinterpret_cast<int const*>(0x1234); | no | ||
const_cast | Cast away/Add constness | int* q = const_cast<int*>(p); | no | ||
typeid | Get type information | std::type_info const& t = typeid(x); | no | ||
3 | ! | Logical negation | if (!done) ... | yes | right to left |
not | Alternate spelling for ! | ||||
~ | Bitwise complement | flags = ~flags; | yes | ||
compl | Alternate spelling for ~ | ||||
++ | Pre-increment | for (i = 0; i < 10; ++i) cout << i; | yes | ||
-- | Pre-decrement | for (i = 10; i > 0; --i) cout << i; | yes | ||
- | Unary minus | int i = -1; | yes | ||
+ | Unary plus | int i = +1; | yes | ||
* | Dereference | int data = *intPtr; | yes | ||
& | Address of | int *intPtr = &data; | yes | ||
sizeof | Size (of the type) of the operand in bytes | size_t s = sizeof(int); | no | ||
new | Dynamic memory allocation | long* pVar = new long; | yes | ||
new [] | Dynamic memory allocation of array | long* array = new long[20]; | yes | ||
delete | Deallocating the memory | delete pVar; | yes | ||
delete [] | Deallocating the memory of array | delete [] array; | yes | ||
(type) | Cast to a given type | int i = (int)floatNum; | yes | ||
4 | ->* | Member pointer selector | ptr->*var = 24; | yes | left to right |
.* | Member object selector | obj.*var = 24; | no | ||
5 | * | Multiplication | int i = 2 * 4; | yes | left to right |
/ | Division | float f = 10.0 / 3.0; | yes | ||
% | Modulus | int rem = 4 % 3; | yes | ||
6 | + | Addition | int i = 2 + 3; | yes | left to right |
- | Subtraction | int i = 5 - 1; | yes | ||
7 | << | Bitwise shift left | int flags = 33 << 1; | yes | left to right |
>> | Bitwise shift right | int flags = 33 >> 1; | yes | ||
8 | < | Comparison less-than | if (i < 42) ... | yes | left to right |
<= | Comparison less-than-or-equal-to | if (i <= 42) ... | yes | ||
> | Comparison greater-than | if (i > 42) ... | yes | ||
>= | Comparison greater-than-or-equal-to | if (i >= 42) ... | yes | ||
9 | == | Comparison equal-to | if (i == 42) ... | yes | left to right |
eq | Alternate spelling for == | ||||
!= | Comparison not-equal-to | if (i != 42) ... | yes | ||
not_eq | Alternate spelling for != | ||||
10 | & | Bitwise AND | flags = flags & 42; | yes | left to right |
bitand | Alternate spelling for & | ||||
11 | ^ | Bitwise exclusive OR (XOR) | flags = flags ^ 42; | yes | left to right |
xor | Alternate spelling for ^ | ||||
12 | | | Bitwise inclusive (normal) OR | flags = flags | 42; | yes | left to right |
bitor | Alternate spelling for | | ||||
13 | && | Logical AND | if (conditionA && conditionB) ... | yes | left to right |
and | Alternate spelling for && | ||||
14 | || | Logical OR | if (conditionA || conditionB) ... | yes | left to right |
or | Alternate spelling for || | ||||
15 | ? : | Ternary conditional (if-then-else) | int i = a > b ? a : b; | no | right to left |
16 | = | Assignment operator | int a = b; | yes | right to left |
+= | Increment and assign | a += 3; | yes | ||
-= | Decrement and assign | b -= 4; | yes | ||
*= | Multiply and assign | a *= 5; | yes | ||
/= | Divide and assign | a /= 2; | yes | ||
%= | Modulo and assign | a %= 3; | yes | ||
&= | Bitwise AND and assign | flags &= new_flags; | yes | ||
and_eq | Alternate spelling for &= | ||||
^= | Bitwise exclusive or (XOR) and assign | flags ^= new_flags; | yes | ||
xor_eq | Alternate spelling for ^= | ||||
|= | Bitwise normal OR and assign | flags |= new_flags; | yes | ||
or_eq | Alternate spelling for |= | ||||
<<= | Bitwise shift left and assign | flags <<= 2; | yes | ||
>>= | Bitwise shift right and assign | flags >>= 2; | yes | ||
17 | throw | throw exception | throw EClass(“Message”); | no | |
18 | , | Sequential evaluation operator | for (i = 0, j = 0; i < 10; i++, j++) ... | yes | left to right |
相关推荐:
北京 | 天津 | 上海 | 江苏 | 山东 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
广东 | 河北 | 湖南 | 广西 | 河南 |
海南 | 湖北 | 四川 | 重庆 | 云南 |
贵州 | 西藏 | 新疆 | 陕西 | 山西 |
宁夏 | 甘肃 | 青海 | 辽宁 | 吉林 |
黑龙江 | 内蒙古 |