C 语言——运算符基础知识浅析(c语言 ?运算符)

yumo6667个月前 (05-08)技术文章41

关于这个运算符,这是一个很常见的知识,从在座的各位会数数起,我们就接触到了最 简单的十以内的加减法。所以,我写这篇文章的主要目的依然和前面的基础知识一样,主要 是把它拿过来,在 C 语言的基础上进行理解、实践。然后,下面我会在 Linux 环境下,实践 C 语言所有的运算符,理解它的算法、规则。

那么 C 语言中有哪些运算符呢?算术运算符、关系运算符、逻辑运算符、位运算符、赋 值运算符、特殊运算符。下面我会一一通过程序例子的形式来实现每一个运算符的用法。

  • 算术运算符浅析

如上图所示,算术运算符包含了“+、-、*、/(除)、%(取余)、++、--”。唯一要注意 的是,浮点型,也就是 float/double 类型不能进行取余操作。其次要注意的是,++(自增) 和—(自减)运算,后面它们有一个前加加、后加加,还有前减减、后减减。至于它们有何 区别呢?下面我将通过一个例程来为大家讲解一下。

#include<stdio.h>
int main(int argc, const char *argv[])
{
    int a = 20, b = 20;
    int c = 20, d = 20;
    int sum1 = 0, sum2 = 0;
    int sum3 = 0, sum4 = 0;
    a++;
    sum1+=a;
    printf("sum1=%d\n" , sum1);
    ++b;
    sum2+=b;
    printf("sum2=%d\n" , sum2);
    c--;
    sum3+=c;
    printf("sum3=%d\n" , sum3);
    --d;
    sum4+=d;
    printf("sum4=%d\n" , sum4);
    return 0;
}

好了,上述就是直接定义一个“++、--”运算符,然后直接拿下来用。就是无论如何,在定义 a++、++b、c--、--d 时,然后直接拿到下一行语句上用,它们只会该减则减,该加则 加,没有什么特殊的地方。但是,要想特殊一点,请看下面这个程序。

#include<stdio.h>
int main(int argc, const char *argv[])
{
    int a = 20, b = 20;
    int c = 20, d = 20;
    int sum1 = 0, sum2 = 0;
    int sum3 = 0, sum4 = 0;
    a++;
    sum1 += a;
    printf("sum1=%d\n" , sum1);
    printf("a++=%d\n" , a++);
    ++b;
    sum2 += b;
    printf("sum2=%d\n" , sum2);
    printf("++b=%d\n" , ++b);
    c--;
    sum3 += c;
    printf("sum3=%d\n" , sum3);
    printf("c--=%d\n" , c--);
    --d;
    sum4 += d;
    printf("sum4=%d\n" , sum4);
    printf("--d=%d\n" , --d);
    return 0;
}

上面我直接加了四条 printf 语句,就是直接输出“a++、++b、c--、--d”的结果,这时的 结果就和上面的程序得到的结果不同。我们可以看出,a++(后加加)不会先运算,它会先 赋值再运算;++a(前加加)不会先赋值,它会先运算再赋值;后面的“--”运算也是这个原理。

  • 关系运算符与逻辑运算符浅析

对于关系运算符和逻辑运算符,我们主要是从上面两张图来了解并应用一下,自己试着 编个程序,首先定义一下两个变量,对这两个变量进行关系运算并赋值,再通过 printf 打印 输出出来。而逻辑运算符,我们要在关系运算符的基础上,进一步对其进行比较,比如,逻 辑非遵从的原则是,非 0 即 1、非 1 即 0;逻辑与运算符,则是用“&&”表示,遵从短路特性、 逢 0 截止的原则,也就是,只要左右两个表达式有一个为 0,则全为 0(全 0 则 0);逻辑或 运算符,则是用“||”表示,也是遵从短路特性、逢 1 截止的原则,也就是,只要左右两个表达 式有一个为 1,则全为 1(全 1 则 1)。

#include<stdio.h>
#define X 29
#define Y 23
int main(int argc, const char *argv[])
{
    int a = 29, b = 23;
    int c,d,e,f,g,h;
    c = (a > b);
    printf("c=%d\n" , c);
    d = (a >= X);
    printf("d=%d\n" , d);
    e = (a < b);
    printf("e=%d\n" , e);
    f = (a <= Y);
    printf("f=%d\n" , f);
    g = (a == b);
    printf("g=%d\n" , g);
    h = (a != b);
    printf("h=%d\n" , h);
    return 0;
}
#include<stdio.h>
#define X 29
#define Y 23
int main(int argc, const char *argv[])
{
    int a = 29, b = 23;
    int c,d,e,f,g,h;
    c = ((a > b) && (b > a));
    printf("c=%d\n" , c);
    d = ((a >= X) && (b <= Y));
    printf("d=%d\n" , d);
    e = ((a < b) || (b < a));
    printf("e=%d\n" , e);
    f = ((a <= Y) || (b >= X));
    printf("f=%d\n" , f);
    g = (!(a == b));
    printf("g=%d\n" , g);
    h = (!(a != b));
    printf("h=%d\n" , h);
    return 0;
}
  • 位运算符运算符的优先级浅析

根据上图所示,我们一个一个来说明一下其作用。首先是位逻辑反,也就是对该变量取 反操作,比如,~11001000,那么它的取反是我们这个二进制 00110111;其次是位逻辑与,和逻辑与相比,它 差了一个“&”符号,只要左右两边的表达式有 0 存在,那就全为 0,要全 1 才为 1;然后是位逻辑或,和逻辑或相比,它差了一个“|”符号,只要左右两边的表达式有 1 存在,那就全为 1, 要全 0 才为 0;再然后是位逻辑异或,用符号“^”表示,它主要遵守的是相同为 0、不同为 1 的原则;最后还有右移位和左移位,右移位用两个右尖括号表示,即,“>>”,左移位用两个 左尖括号表示,即“<<”。

  • 赋值运算符、特殊运算符基础知识浅析

那么什么是特殊运算符呢?我们这里主要介绍条件运算符(又叫三目运算符)和sizeof运算符(计算关键字大小的一个函数)。条件运算符的一般形式是:

<表达式 1> ? <表达式 2> : <表达式 3>

这里sizeof运算符需要注意一点,他针对的仅是数据类型,而不针对变量!它的主要形式是:

sizeof(<类型或变量名>)

最后再来看两个代码,学习C语言嘛,要的就是代码量,希望大家也能够在熟悉这些基础知识后,自己多多敲敲代码、手写代码!!!

#include <stdio.h>
int main(int argc, char **argv)
{
     int count, sum; 
     count = 0; sum = 0;
     while (count++ < 10) 
     { 
         sum +=count; 
     } 
     printf("sum = %d\n", sum);
     return 0;
}
#include<stdio.h>
#define N 20
int main(int argc, const char *argv[])
{
    unsigned char x = 0x17 , y;
    y = ~x;
    printf("y=%d\n" , y);
//  char a = 20 , b = 30 , c , d;
//  c = (a ^ b);
//  d = (a ^ N);
//  printf("c=%d d=%d\n" , c , d);
//  char a = 0xe4 , b;
//  b = (a << 3);
//  printf("b=%d\n" , b);
    int e = 107 , f = 208 , g , h;
    g = ((f >= e) ? (f + 18) : (e - 100));
    printf("g=%d\n" , g);
    h = ((e += 5) , (f -= 10));
    printf("h=%d\n" , h);
    printf("sizeof(char)=%d\n" , sizeof(char));
    printf("sizeof(int)=%d\n" , sizeof(int));
    return 0;
}


END

相关文章

C语言学习的难点(c语言的难题)

C语言学习的主要难点可以概括为以下几点:1. **指针 (Pointers):** 这是C语言最核心也是最难掌握的概念。理解指针、指针运算、指针与数组的关系、多级指针、函数指针等需要花费大量时间和精力...

每日学习“C·语言”是什么呢?(c的语言是什么)

以下是关于 C 语言的详细信息:一、C 语言的基本特点高效性:C 语言是一种接近硬件的编程语言,它允许程序员直接访问内存地址和操作硬件,因此在性能上具有较高的效率。例如,系统级编程和嵌入式系统开发中,...

C语言char的详解(c语言中char的意思)

在C语言中,char 是一种基础数据类型,用于表示字符或小整数值。对 char 的理解和处理非常重要,尤其是在字符串操作、文件读写或其他需要直接控制内存的应用场景中。下面从基本定义、存储方式、常见用法...

C语言简介(介绍一下c语言)

C语言是一种通用、高效的结构化编程语言,由**丹尼斯·里奇(Dennis Ritchie)**于1972年在贝尔实验室开发。它最初用于重写Unix操作系统,后因其简洁性、灵活性和对硬件的直接控制能力,...

【c语言学习笔记】数据类型(c语言中数据类型有哪几大类?)

c语言学习笔记,欢迎大家能在评论区提出我学习错误的地方方便我进行改正~在计算机中,计算机用二进制来储存数据,在c语言中有许多的数据类型用来存储数据,当然不同的数据类型所用的内存占用也不一样,下面就来用...

C 语言的类型(c语言的类型和编码规则是什么)

C 语言的类型C 语言中存储在对象中的值或者由函数返回的值,其含义取决于用于访问它的表达式。声明为对象的标识符是最简单的这类表达式,类型即由标识符给出。类型分为对象类型(描述对象的类型)和函数类型(描...