>백엔드 개발 >C#.Net 튜토리얼 >C 언어의 6가지 기본 명령문은 무엇입니까?

C 언어의 6가지 기본 명령문은 무엇입니까?

coldplay.xixi
coldplay.xixi원래의
2020-07-06 10:47:3516258검색

C 언어의 6가지 기본 명령문은 다음과 같습니다. 1. 산술 연산자 및 산술 표현식 2. 대입 연산자 및 할당 표현식 3. 관계 연산자 및 관계 표현식 5. 조건 연산자 및 조건 표현식 6. 쉼표 연산자 및 쉼표 표현.

C 언어의 6가지 기본 명령문은 무엇입니까?

C 언어의 6가지 기본 명령문은 다음과 같습니다.

1. 산술 연산자 및 산술 표현식

1. 기본 산술 연산자

+ ( 추가) , - (빼기), * (곱하기), / (나누기) 및 % (나머지 찾기)+ (加)、 - (减) 、 * (乘) 、 / (除) 和 % (求余数)

这五个运算符的优先级为:

             */ %同级,但比+和-高。即先乘除后加减。  

 

两个整数相除,结果为一整数;分子小于分母,结果为零。

 例如:  5/2    结果为 2

               2/5    结果为 0

 

 

这五个运算符的结合性为:自左至右。

例如:10+6- 4*2

第一步先计算10+6,得结果16,第二步计算4*2,得结果8,然后用第一步计算的结果减第二步计算的结果,得结果8。

 

余数计算方法:

 

             5%3   余数是2

            5%8   余数是5

           -5%3  余数是 –2    (注意:符号位取bfb5a2eeb51a8f736295d11466f9a362的符号)

      5%-3  余数是 2      (注意:符号位取bfb5a2eeb51a8f736295d11466f9a362的符号)

 

  2.算术表达式

         算术表达式是由算术运算符和操作数组成的表达式。表达式的值是一个数值,表达式的类型具体由运算符和操作数确定。

   例如:  5+3*(6-2)    表达式的类型为int 型。

               3+4.0-3/2.0  表达式的类型为double型。

  3.数据类型转换

   通常参与运算的数据类型不完全一致,操作时应先将其转换成相同的数据类型,然后操作。

     2.1强制类型转换,直接将某数据强制转换成指定的数据类型

 

       强制类型转换,变量值本身未变化

           (double)a;  
       (int)(x+y);注意区别:(int)x+y 先把x的值转换成int型,然后再加y
       (float)(5%3)    
        int  i;
        …
        i=i+(int)9.801;

       2.2在编译时由编译程序按照一定规则自动完成,不需人为干预

 

       数据参加运算前要进行下列转换:

       char,short→int→float→double

 

       混合运算时数据类型由低级→高级

       unsigned → int → long → double

 

       以上并不意味着unsigned必须到int再到long的依次转换,而是由算式中的最高级进行转换的。

二、赋值运算符和赋值表达式

  1.赋值运算符

      赋值符号:=   将赋值符右边表达式的值赋给赋值符左边的一个变量。

 

赋值运算符的数据类型若不一致,则要进行类型转换。转换方式为:

将实型数据赋给整型变量时,舍弃实数的小数部分。

  如:int i;   i=5.65;  i 的值为 5。

将整型数据赋给实型变量时,数值不变。

 float f  ;  f=23;

(先23→23.00000 再存储在f 中)

  double  d;  d=23;

(先23→23.000000000000000再存储在d中)

将字符数据赋给整型变量时,将字符数据放到整型变量低8位中

          int i;char ch = '0';        i = ch;   // i = 48

将整型变量赋给字符数据时,将整型变量低8位放到字符数据中

        int i = 4656;char ch;        ch = i;   // ch = 48

  2.复合的赋值运算符

     复合的赋值运算符:(共十个)

  += ,  -= ,  *= ,  /=  ,   %= , 

  639770e382bf3731d804014418c1bbd1>= ,  &= ,  ^= ,  |=

5개 운영자의 우선순위는 다음과 같습니다.

                                                                                 ~ 즉, 먼저 곱하고 나눈 다음 더하고 빼는 것입니다.

두 개의 정수를 나눌 때 결과는 정수이고, 분자가 분모보다 작으면 결과는 0입니다.

예: 5/2 결과는 2

2/5 결과는 0

이 다섯 연산자의 연관성은 왼쪽에서 오른쪽입니다. 🎜🎜예: 10+6- 4*2🎜🎜첫 번째 단계에서 10+6을 계산하여 결과 16을 얻습니다. 두 번째 단계에서 4*2를 계산하여 결과 8을 얻습니다. 그런 다음 다음에서 계산된 결과를 사용합니다. 첫 번째 단계에서 두 번째 단계를 빼면 계산된 결과는 8입니다. 🎜🎜 🎜🎜나머지 계산 방법: 🎜🎜 🎜🎜 5%3 나머지는 2🎜🎜 5%8 나머지는 5🎜🎜 5%3 나머지는 -2입니다(참고: 부호 비트는 1ffbf7853c015b534c6af811c7259b2e )🎜🎜 5%-3 나머지는 2입니다(참고: 부호 비트는 af9d9fb6c4ef830dbd506bda5f8c9046의 부호를 가집니다)🎜🎜🎜🎜🎜 2. 산술 표현식🎜🎜🎜 산술 표현식은 산술 연산자와 피연산자 표현. 표현식의 값은 숫자 값이고 표현식의 유형은 연산자와 피연산자에 의해 결정됩니다. 🎜🎜 예: 5+3*(6-2) 표현식 유형은 int 유형입니다. 🎜🎜 3+4.0-3/2.0 표현형은 더블입니다. 🎜🎜 3. 데이터 유형 변환 🎜🎜 일반적으로 연산에 포함된 데이터 유형은 완전히 일치하지 않습니다. 연산 중에는 먼저 동일한 데이터 유형으로 변환한 후 연산해야 합니다.型 2.1 강제 유형 변환, 데이터를 지정된 데이터 유형으로 직접 변환 🎜🎜 🎜🎜 강제 유형 변환, 변수 값 자체는 변경되지 않습니다. R
                             a += 3        等价于     a=a+3
                    x *= y+8    等价于     x=x*(y+8)
                    x %= 3       等价于     x=x%3
E🎜 2.2는 컴파일 중 특정 규칙에 따라 컴파일 프로그램에 의해 자동으로 완료됩니다. 🎜🎜 🎜🎜 데이터가 연산에 참여하기 전에 다음 변환을 수행해야 합니다: char, short→int→float→double 🎜🎜 🎜🎜 혼합 연산 중에는 데이터 유형이 하위 수준에서 상위 수준으로 변경됩니다. 🎜🎜 double unsigned → int → long → 🎜🎜🎜 🎜 위의 내용은 unsigned를 반드시 int로 변환한 뒤 long으로 순차적으로 변환해야 한다는 뜻은 아니며 변환은 계산상 최상위 레벨에서 수행됩니다. 🎜🎜🎜 2. 대입 연산자와 대입식 🎜🎜🎜 🎜 1. 대입 연산자 🎜🎜🎜 대입 기호: = 대입 연산자 오른쪽에 있는 식의 값을 대입 연산자의 오른쪽에 대입합니다. 할당 연산자 변수의 왼쪽. 🎜🎜 🎜🎜대입 연산자의 데이터 유형이 일치하지 않는 경우 유형 변환이 필요합니다. 변환 방법은 다음과 같습니다. 🎜🎜실제 데이터를 정수 변수에 할당할 때 실수의 소수 부분을 버립니다. 🎜🎜 예: int i; i=5.65; 🎜🎜실수 변수에 정수 데이터를 할당하면 값이 변경되지 않습니다. 🎜
int x,y,z;
      x=y=z=5+6;
 
              int  x=3,y=4;
              x*=y+1;    
              ( x=等价与  x*(y+1);)
 
             int x;
             x='a';
🎜(23→23.00000 먼저 f에 저장)
🎜
                         a=b=c=5       a=(b=(c=5))   a,b,c值都是5
            a=5+(c=6)      c值为6, a值为5+6 (即11)
            a=(b=4)+(c=6)    b值为4,c值为6,a值为4+6 (即10)
            a=(b=10)/(c=2)    a值为5
🎜(23→23.000000000000000 다음에 d에 저장)
🎜🎜정수형 변수에 문자 데이터를 대입할 때, 문자 정수변수의 하위 8비트에 데이터를 넣습니다🎜
有int x=2,y=3,z=5;
则:x>y     结果为0。
z>=y    结果为1。 
z==y    结果为0。
🎜정수변수를 문자데이터에 대입할 때 정수변수의 하위 8비트를 문자데이터에 넣습니다🎜
若  a=3,b=2,c=1
     f=a>b>c 
    f=?
🎜 🎜 2. 복합 대입 연산자🎜🎜🎜 복합 할당 연산자: (총 10개) 🎜🎜 += , -= , *= , /= , %= , 🎜🎜 59b6c0ac84b5cbca7160a4b88268d9d0>= , &= , ^= , |=🎜🎜 🎜🎜예: 🎜
                   (a>b)&&(x>y)           可以写成  a>b&&x>y
              (a==b)||(x==y)          可以写成    a==b||x==y
              (!a)||(a>b)             可以写成   !a||a>b
              5>3&&2||8<4-!0          的值为     1
              &#39;c&#39;&&&#39;d&#39;              的值为      1
🎜 할당 연산자로 변수와 표현식을 연결하는 표현식입니다. 🎜🎜             형식은 다음과 같습니다: 704c21b4c1ce22a3c61c4a42f60bae1e할당 연산자> 🎜🎜예: 🎜
                         a=b=c=5       a=(b=(c=5))   a,b,c值都是5
            a=5+(c=6)      c值为6, a值为5+6 (即11)
            a=(b=4)+(c=6)    b值为4,c值为6,a值为4+6 (即10)
            a=(b=10)/(c=2)    a值为5

三、关系运算符和关系表达式

  1.关系运算符

   关系运算符用于两个数值之间的比较运算。C语言提供6种关系运算符:

d2714fbb0e49a95306c2048bc19e4f2b、>=、  优先级相同高

==、!=  优先级相同低

 

关系运算符的结合率为:“自左而右”。

(即当优先级相同时按自左而右结合a>b>c,当优先级不同时按优先级高低结合a=b+c)

关系运算符、算术运算符和赋值运算符的优先级为:

 

  例如:  1、c>a+b          等效于     c>(a+b)

  2.关系表达式

   由关系运算符和操作数组成的表达式称为关系表达式。

关系表达式的值是一个逻辑型的值,即只有两个值(真和假)。

C语言是用1作为真,用0作为假。但是进行运算时,非0即认为真,0才认为假。而表达式的结果为真时,给出真值1。为假时,给出假值0。

 例1:

有int x=2,y=3,z=5;
则:x>y     结果为0。
z>=y    结果为1。 
z==y    结果为0。

例2: 

若  a=3,b=2,c=1
     f=a>b>c 
    f=?

四、逻辑运算符和逻辑表达式

  1.逻辑运算符

   

  2.逻辑表达式

用逻辑运算符将关系表达式或逻辑量连接起来的式子。

运算结果为:“真”或“假”值。

系统在运算时以非0即为真,以0为假。

 

 

例如:  4  && 0 || 2   的值为1

                 5  && !0     的值为1

 

例如:

                   (a>b)&&(x>y)           可以写成  a>b&&x>y
              (a==b)||(x==y)          可以写成    a==b||x==y
              (!a)||(a>b)             可以写成   !a||a>b
              5>3&&2||8<4-!0          的值为     1
              &#39;c&#39;&&&#39;d&#39;              的值为      1

 

#include <stdio.h>
int main()
{
    int a = 10;
    int b = 10;
    if (++a > 100 || ++b >0)
    {
    }
    printf("a = %d, b = %d\n", a, b); 
    a = 10;
    b = 10;
    if (++a > 100 && ++b >0)
    {
    }
    printf("a = %d, b = %d\n", a, b);
    return 0;
}

五、条件运算符和条件表达式

  1.条件运算符

   条件运算符:  ? : 它是唯一的一个三目运算符

  2.条件表达式

    条件表达式的一般格式为:表达式1  ?  表达式2  :    表达式3       

运算过程:表达式1的结果为真(非0)时,表达式2的计算结果作为条件表达式的值;否则,取表达式3的计算结果为条件表达式的值。

 

如: a>b?a:b  

 

条件运算符的优先级低于逻辑、关系、算术运算符高于赋值运算符。

如: a>b?a:b+1     相当于     (a>b)?a:(b+1)  

六、逗号运算符和逗号表达式

逗号运算符:  ,

格式: 表达式1, 表达式2, 表达式3, LL, 表达式n

优先级: 最低

从左向右计算每个表达式的值,逗号表达式的值为表达式n的值。

例如:

                     y=(x=3,5+6,x+5) 逗号表达式的值为?

相关学习推荐:C视频教程

위 내용은 C 언어의 6가지 기본 명령문은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.