逗号表达式与自增自减运算符和类型转换的规则

逗号运算符

逗号运算符优先级最低;

逗号运算符是用来分割多个表达式的;

由逗号运算符组成的逗号表达式的运算结果是:最后一个表达式的结果

注意:

int i;

i = 3,4,5,;

以上语句得到的i的值为3

i = (3, 4, 5);

得到的i的值为5

总结:

++i置前自增:先对i的值加1,然后用增1后的值参加所有的后续运算

i++滞后自增自减:先用变量原来的值参加所有的后续运算,直到本条语句所有的运算全部运算完毕后,才对变量值加减1

滞后自增减在条表中的特殊表现:先利用原值参与条件判断,然后立刻自增减;

滞后自增减在逗号表达式中的特殊表现:

int i = 3, j = 4, k;

k = (++i, j++, i++ * ++j);

printf("%d %d %d\n", i, j, k);

结果:

i = 5;

j = 6

k = 24

总结:

滞后自增遇到逗号运算符时立刻自增减,但是函数中的参数逗号除外

数据类型转换

1.1)自动类型转换

在某一次运算中,如果参与运算的两个运算数的数据类型不一致,则C语言会对其自定进行数据类型转换,且遵循如下原则:

短整型向长整型靠拢;

简单数据类型向复杂数据类型靠拢;

如下两个例子:

5.0 + 1/2

=5.0 +0

=5.0+0.0=5.0

5+1/2.0=5+1.0/2.0=5+0.5=5.0+0.5=5.5

数学运算式:1/1+1/2+1/3+.....+1/n

int i;

double s = 0;

for(i = 1; i <= n; i++)

s += 1.0/i;

1.2.强制类型转换

语法:

(数据类型转化)表达式

s += (double)1 / i;//强制类型转换也是运算符,是单目运算符最低的

强制类型转换以人类的意志为原则

s +=(double)(1/i);//只是得到0.0

强制类型转换运算绝对不可能改变变量的数据类型

1.3自动强制类型转换

这种运算只发生在赋值运算中

char c = 97.14159;

在赋值时候会丢失一些精度,输出小写字母a

double f = ‘A‘;

输出65.000

转换原则:若赋值运算符两侧的数据类型不一致,则,由C语言对赋值运算符右侧表达式时的值,进行自动类型转换工作;且是按照赋值运算符左侧的左值数据类型为依据转换的;


逗号表达式与自增自减运算符和类型转换的规则

时间: 2024-10-25 23:03:08

                    逗号表达式与自增自减运算符和类型转换的规则的相关文章

[转]C语言中自增自减运算符教学探究-中国论文网

摘要:C语言教学中,自增自减运算符运用得非常广泛,且具有一定的使用技巧和难度.在诸多运算符中,自增自减运算符是学生最难理解和最易出错的运算符.对自增自减运算符的功能和具体应用进行探究,以期为提高C语言教学效果提供帮助.中国论文网 http://www.xzbu.com/8/view-3865031.htm 关键词:C语言:自增自减运算符:教学效果 中图分类号:G434文献标识码:A文章编号:1672-7800(2012)012-0188-02 0引言 C语言编程设计中,若合理使用自增自减运算符,

【转】 C语言自增自减运算符深入剖析

转自:http://bbs.csdn.net/topics/330189207 C语言的自增++,自减--运算符对于初学者来说一直都是个难题,甚至很多老手也会产生困惑,最近我在网上看到一个问题:#include <stdio.h> void main()  /*主函数*/ { int a,b,c,d;  a=5; b=5;  c=(a++)+(a++)+(a++);  d=(++b)+(++b)+(++b);  printf("a=%d,b=%d,c=%d,d=%d\n",

自增自减运算符练习

自增自减运算符练习第一题int x = 1,y = 1; if(x++==2 & ++y==2) {x =7;}System.out.println("x="+x+",y="+y); 输出结果:x=2,y=2 第二题int x = 1,y = 1; if(x++==2 && ++y==2){x =7;}System.out.println("x="+x+",y="+y);输出结果:x=2,y=1 第三题

自增/自减运算符

因为做以下题有感...原来简单的自增运算符也有这么多猫腻 http://blog.csdn.net/zdarks/article/details/8767087 第五题  参考:c程序设计语言2.8章   Vs2015测试: a[6]={0};t=h=0; a[0]=a[0]++ 1 a[1]=++a[1] 1 a[2]=t++ 0 a[3]=++h 1 COUT<<a[4]++ 0 COUT<<++a[5] 1 自增自减只能作用于变量,不能作用于表达式 在不需要使用任何具体值且仅

C++学习30 重载++和--(自增自减运算符)

自增“++”和自减“--”都是一元运算符,它的前置形式和后置形式都可以被重载.请看下面的例子: #include <iostream> #include <iomanip> using namespace std; class stopwatch{ //秒表 private: int min; //分钟 int sec; //秒钟 public: stopwatch(): min(0), sec(0){ } void setzero(){ min = 0; sec = 0; } s

java自增自减运算符

除了这+ - * / % 这5个算术运算符之外其实还有2种 ++ - - 这两个也可以属于算术运算符.他是自增自减运算的,例如:int i = 10; i++; i- - 或 ++i - -i但是这2个比较特殊,他有先运算和后运算一说.++ - -符号在后面的为后运算,++ - -符号在前面的为先运算例如:i++ i- - 这为后运算,++i - -i这为先运算. ++ - - 他是一个缩写的方式,融合了2句代码的缩写. 例如:int i = 100; int a = i; i = i+1; 意

C++学习笔记(5)----重载自增自减运算符

自增运算符“++”和自减运算符“--”分别包含两个版本.即运算符前置形式(如 ++x)和运算符后置形式(如 x++),这两者进行的操作是不一样的.因此,当我们在对这两个运算符进行重载时,就必须区分前置和后置形式.C++根据参数的个数来区分前置和后置形式.如果按照通常的方法来重载 ++ 运算符(即作为成员函数重载时不带参数,或者作为非成员函数重载时带有一个参数),那么重载的是前置版本.要对后置形式进行重载,即 x++ 或 x--,就必须为重载函数再增加一个 int 类型的参数.该参数仅仅用来告诉编

自增自减运算符

如果n值为3,那么执行语句"m=-n++"后,m和n的值各为多少? m=-n++; 相当于 m=-(n++); 而不是 m=(-n)++; 因为运算符++的运算对象只能是变量,不能是表达式,对一个表达式使用增1或减1运算是一个语法错误,因此"m=(-n)++;"本身也是不合法的. 由于在表达式"-(n++)"中,++是运算对象即变量n的后缀运算符,因此它表示先使用变量n的值,使用完n以后再将n的值增1.也就是说,上面这条语句实际上等效于下面两条语

自增自减运算符的重载(强制类型转换运算符重载)

前置运算符重载为一元运算符,后置运算符重载为二元运算符. Operator int() { return n; } int作为一个强制类型转换运算符被重载, Demo s; (int)s;       //等效于s.int(): 强制类型转换运算符重载时, 不能写返回值类型 实际上其返回值类型----强制类型转换运算符代表的类型 只能作为成员函数,不能作为友元函数或普通函数 转换构造函数和类型转换运算符有一个共同的功能:当需要的时候,编译系统会自动调用这些函数,建立一个无名的临时对象(或临时变量