热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C语言学习笔记——操作符总结

分类算术操作符移位操作符位操作符赋值操作符单目操作符关系操作符逻辑操作符条件操作符逗号表达式下标引用,函数调用和结构成员算数操作符求两个数的和-求两个数的差*求

分类


  1. 算术操作符
  2. 移位操作符
  3. 位操作符
  4. 赋值操作符
  5. 单目操作符
  6. 关系操作符
  7. 逻辑操作符
  8. 条件操作符
  9. 逗号表达式
  10. 下标引用,函数调用和结构成员

算数操作符


+求两个数的和
-求两个数的差
*求两个数的积
/求两个数的商
%取模(两个数相除的余数)

注意事项:

  • 注意基本规则,如0不能做除数,这在编译时不会报错,但程序在执行时往往会出错。
  • 除了 % 操作符之外,其他的几个操作符可以作用于整数和浮点数。
  • 对于 / 操作符如果两个操作数都为整数,执行整数除法。而只要有浮点数执行的就是浮点数除法。
  • % 操作符的两个操作数必须为整数。返回的是整除之后的余数。

移位操作符


左移操作符<<
右移操作符>>

  • 左移操作符移位规则&#xff1a; 左边抛弃、右边补0
    例如&#xff1a; 定义一个整型变量a&#xff1b;
    int a &#61; 5;
    其二进制序列是&#xff1a;
    0000 0000 0000 0000 0000 0000 0000 0101
    左移一位的结果就是&#xff1a;
    0000 0000 0000 0000 0000 0000 0000 1010 &#xff08;a<<1&#xff09;
  • 右移操作符移位规则&#xff1a;
    首先右移运算分两种&#xff1a;
    1. 逻辑移位 左边用0填充&#xff0c;右边丢弃
    2. 算术移位 左边用原该值的符号位填充&#xff0c;右边丢弃

逻辑移位和左移类似
int a &#61; 5;
其二进制序列是&#xff1a;
0000 0000 0000 0000 0000 0000 0000 0101
右移一位的结果就是&#xff1a;
0000 0000 0000 0000 0000 0000 0000 0010 &#xff08;a>>1&#xff09;

算数移位左边不能直接用0填充&#xff0c;要根据数据的符号位来决定
int a &#61; -1&#xff1b;
其二进制序列&#xff08;补码&#xff09;是&#xff1a;
1111 1111 1111 1111 1111 1111 1111 1111
由于a是负数&#xff0c;在移位时右边填充的不是0&#xff0c;而是最高位的符号位&#xff1a;1&#xff1b;
所以右移一位的结果是&#xff1a;
1111 1111 1111 1111 1111 1111 1111 1111 &#xff08;a>>1&#xff09;

注意事项&#xff1a;

  • 对于移位运算符&#xff0c;不能移动负数位&#xff0c;这个是标准未定义的

位操作符


&按位与
按位或
^按位异或

& 按位与
0 & 0为0&#xff1b; 0 & 1 为0&#xff1b; 1 & 1为1&#xff1b;
int a &#61; 5;
int b &#61; 6;
二进制序列分别是&#xff1a;
0000 0000 0000 0000 0000 0000 0000 0101
0000 0000 0000 0000 0000 0000 0000 0110
a & b的结果就是:
0000 0000 0000 0000 0000 0000 0000 0100
| 按位或
0 | 0为0&#xff1b; 0 | 1为1&#xff1b; 1 | 1为1&#xff1b;
int a &#61; 5;
int b &#61; 6;
a | b的结果就是:
0000 0000 0000 0000 0000 0000 0000 0111
^ 按位异或
0 ^ 0为0&#xff1b; 0 ^ 1为1&#xff1b; 1 ^ 1为0&#xff1b;
int a &#61; 5;
int b &#61; 6;
a ^ b的结果就是:
0000 0000 0000 0000 0000 0000 0000 0011

注意事项&#xff1a;

  • 操作变量必须是整数

赋值运算符

&#61;
把一个变量的值或者一个数值复制给另一个变量&#xff1b;
int a &#61; 1&#xff1b;
把1赋值给a变量&#xff1b;
int b &#61; a&#xff1b;
把a变量的值赋值给b变量&#xff1b;
赋值运算符可以连续使用&#xff08;不推荐&#xff09;&#xff1b;
int c &#61; b &#61; a &#xff1b;

复合赋值符


&#43;&#61;“x &#43;&#61; y” &#61;&#61; “x &#61; x &#43; y”
-&#61;“x -&#61; y” &#61;&#61; “x &#61; x - y”
*&#61;“x *&#61; y” &#61;&#61; “x &#61; x * y”
/&#61;“x /&#61; y” &#61;&#61; “x &#61; x / y”
%&#61;“x %&#61; y” &#61;&#61; “x &#61; x % y”
>>&#61;“x >>&#61; y” &#61;&#61; “x &#61; x >> y”
<<&#61;“x <<&#61; y” &#61;&#61; “x &#61; x <

单目运算符


&#xff01;逻辑反操作
-负值
&#43;正值
&取地址
sizeof操作数类型长度&#xff08;以字节为单位&#xff09;
~对一个数的二进制按位取反
前置&#xff0c;后置–
&#43;&#43;前置&#xff0c;后置&#43;&#43;
*间接访问操作符&#xff08;解引用操作符&#xff09;
&#xff08;类型&#xff09;强制类型转换

注意事项&#xff1a;sizeof不是函数&#xff0c;是一个运算符&#xff01;

关系操作符


>大于
<小于
>&#61;大于等于
<&#61;小于等于
!&#61;不相等
&#61;&#61;等于

注意事项&#xff1a;不要将“&#61;&#61;”和“&#61;”搞混了&#xff01;

逻辑运算


&&逻辑与
逻辑或

逻辑与 && &#xff0c;当 && 符号两边表达式的值都为真的时候&#xff0c;结果为真&#xff1b;否则都为假。
逻辑或 || &#xff0c;当 || 符号两边表达式的值都为0的时候&#xff0c;结果为假&#xff1b;否则都为真。

注意事项&#xff1a;

&&在运算时&#xff0c;从左到右依次判断&#xff0c;如果左边的表达式为假&#xff1b;则不会再判断右边的表达式&#xff08;如果右边是一个赋值表达式&#xff0c;也不会被止执行&#xff09;。
同理&#xff0c;||在运算时如果左边的表达式为真&#xff0c;则不会再判断右边的表达式

条件运算符

exp1 ? exp2 : exp3

若exp1的值为真&#xff0c;则执行exp2&#xff0c;否则执行exp3。

逗号表达式

逗号表达式&#xff0c;就是用逗号隔开的多个表达式。从左向右依次执行。整个表达式的结果是最后一个表达式的结果。
int a &#61; 2;
int b &#61; 3;
int c &#61; (a, b, a &#43; b);
执行结束后c的值为5&#xff1b;

下标引用、函数调用和结构成员


  • 1 . [ ] 下标引用操作符 操作数&#xff1a;一个数组名 &#43; 一个索引值
    int a[10];
    a[0] &#61; 1;
    对数组元素进行引用
    2 . ( )函数调用操作符 接受一个或者多个操作数&#xff1a;第一个操作数是函数名&#xff0c;剩余的操作数就是传递给函数的参数

#include
void test1() { printf("hehe\n"); } void test2(const char *str) { printf("%s\n", str); } int main() { test1(); //实用&#xff08;&#xff09;作为函数调用操作符。 test2("hello bit.");//实用&#xff08;&#xff09;作为函数调用操作符。 return 0; }

3.访问一个结构的成员
. 结构体.成员名
-> 结构体指针->成员名

#include
struct Stu { char name[10]; int age; char sex[5]; double score;}&#xff1b;
void set_age1(struct Stu stu)
{ stu.age &#61; 18;
}
void set_age2(struct Stu* pStu)
{ pStu->age &#61; 18;//结构成员访问
}
int main(){ struct Stu stu; struct Stu* pStu &#61; &stu;//结构成员访问 stu.age &#61; 20;//结构成员访问 set_age1(stu); pStu->age &#61; 20;//结构成员访问 set_age2(pStu); return 0;
}


推荐阅读
  • C语言判断正整数能否被整除的程序
    本文介绍了使用C语言编写的判断正整数能否被整除的程序,包括输入一个三位正整数,判断是否能被3整除且至少包含数字3的方法。同时还介绍了使用qsort函数进行快速排序的算法。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 本文由编程笔记#小编整理,主要介绍了关于数论相关的知识,包括数论的算法和百度百科的链接。文章还介绍了欧几里得算法、辗转相除法、gcd、lcm和扩展欧几里得算法的使用方法。此外,文章还提到了数论在求解不定方程、模线性方程和乘法逆元方面的应用。摘要长度:184字。 ... [详细]
  • 本文讲述了CodeForces1016C题目的解法。文章首先介绍了一种错误的理解,然后给出了正确的解法。其中,当位于一个角上时,有两种选择,一种是先一直走一行再返回来走,另一种是走到这一列的另一行上然后再往右走一列。作者给出了两种解法,一种是直接计算,一种是动态规划。最后,取两种解法的最优解作为答案。文章附上了源代码。 ... [详细]
  • 本文介绍了GTK+中的GObject对象系统,该系统是基于GLib和C语言完成的面向对象的框架,提供了灵活、可扩展且易于映射到其他语言的特性。其中最重要的是GType,它是GLib运行时类型认证和管理系统的基础,通过注册和管理基本数据类型、用户定义对象和界面类型来实现对象的继承。文章详细解释了GObject系统中对象的三个部分:唯一的ID标识、类结构和实例结构。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • c语言\n不换行,c语言printf不换行
    本文目录一览:1、C语言不换行输入2、c语言的 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • 本文介绍了一个题目的解法,通过二分答案来解决问题,但困难在于如何进行检查。文章提供了一种逃逸方式,通过移动最慢的宿管来锁门时跑到更居中的位置,从而使所有合格的寝室都居中。文章还提到可以分开判断两边的情况,并使用前缀和的方式来求出在任意时刻能够到达宿管即将锁门的寝室的人数。最后,文章提到可以改成O(n)的直接枚举来解决问题。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • 本文介绍了在Windows系统上使用C语言命令行参数启动程序并传递参数的方法,包括接收参数程序的代码和bat文件的编写方法,同时给出了程序运行的结果。 ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • C语言常量与变量的深入理解及其影响
    本文深入讲解了C语言中常量与变量的概念及其深入实质,强调了对常量和变量的理解对于学习指针等后续内容的重要性。详细介绍了常量的分类和特点,以及变量的定义和分类。同时指出了常量和变量在程序中的作用及其对内存空间的影响,类似于const关键字的只读属性。此外,还提及了常量和变量在实际应用中可能出现的问题,如段错误和野指针。 ... [详细]
author-avatar
宛如画中人需_308
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有