百科狗-知识改变命运!
--

c语言中=和==有什么区别?

梵高1年前 (2023-12-04)阅读数 9#综合百科
文章标签字符表达式

1、含义不同:

“=”是赋值的意思。

它的作用是将一个表达式的值赋给一个左值。一个表达式或者是一个左值,或者是一个右值。所谓左值是指一个能用于赋值运算左边的表达式。左值必须能够被修改,不能是常量。我们用变量作左值,还可以看到,指针和引用也可以作左值。

“==”是等一操作符,判断两边是否相等。利用相等运算符,如果希望相等运算符返回true,则运算符两侧的值或语句必须使相等的;如果不相等,则==运算符返回false。

2、返回值的结果不同:

“=”的结果实际上意味着把右边表达式的值赋给左边的运算数。赋值运算表达式的值也就是所赋的值。也就是说,“$a = 3”的值是 3。

“==”则不同,它会返回false或true值。所以例如“4”==4这样的语句将返回true,因为JavaScript会将字符“4”转换成数字4。如果希望该语句返回false,则需要使用恒等运算符(===)。

c语言中 a++和++a的具体区别是什么

表达式它是由常量、变量、运算符组合,计算以后返回一个结果值。表达式的结束标志是分号(;),C语言中所有的语句和声明都是用分号结束,在分号出现之前,语句是不完整的。语句与表达式这两者有何区别呢?下面就跟着我一起来看看吧。

一、表达式

表达式本身什么事情都不做,只是返回结果值。在程序不对返回的结果值做任何操作的情况下,返回的结果值不起任何作用,表达式的作用有两点,一个是放在赋值语句的右边,另一个是作为函数的参数(以后再介绍)。

 表达式返回的结果值是有类型的。表达式隐含的数据类型取决于组成表达式的变量和常量的类型。因此,表达式的返回值有可能是某种大小的整型,或者是某精度的浮点型,或者是某种指针类型。

 这里面就有类型转化的问题了,在前面说整型运算的时候也提到过。类型转化的原则是从低级向高级自动转化(除非人为的加以控制)。计算的转换顺序基本是这样的:

 字符型-->整型-->长整型-->浮点型-->单精度型-->双精度型

 就是当字符型和整型在一起运算时,结果为整型,如果整型和浮点型在一起运算,所得的结果就是浮点型,如果有双精度型参与运算,那么答案就是双精度型了。

 强制转换是这样的,在类型说明符的两边加上括号,就把后面的变量转换成所要的类型了。如:

 (int) a;

 (float) b;

 第一个式子是把a转换成整型,如果原先有小数部分,则舍去。

 第二个式子是把b转换成浮点型,如果原先是整数,则在后面补0。

 每一个表达式的返回值都具有逻辑特性。如果返回值为非0,则该表达式返回值为真,否则为假。这种逻辑特性可以用在程序流程控制语句中。

 有时表达式也不参加运算,如:

 if(a||b)

 5>3?a++:b++;

 当a为真时,b就不参加运算了,因为不管b如何,条件总是真。

二、语句

 (一)、赋值语句

 其实这个问题,在讲赋值运算符的时候已经讲了一些了。

 Amount=1+2;

c语言中=和==有什么区别?

 Total=Counter/3+5;

 Area=Height*Width;

 也许你会发现,这些赋值语句很象代数方程,在某些情况下,我们的确可以这样理解,但有时它们是不一样的。看下面:

 Num=Num+1;

 这显然不是一个等式。

 (二)、用逗号分隔开的声明语句

 C语言可大多数语言一样,允许用逗号分隔声明语句中的标识符列表,说明这些运算符是同一变量类型。例如:

 float Area,Height,Width;

 但有些程序员喜欢把标识符写在不同的行上。如:

 float Area,

 Height,

 Width;

 这样写至少有一个好处,就是可以在每个标识符后边加上注释。

 在声明变量的时候,也可以直接给变量赋值,这叫做变量的初始化。

 如:int a;

 a=3;

 等价于:

 int a=3;

 我们也让某些变量初始化,某些不初始化,如:

 int a=3,b,c=5;

 在进行初始化时,初始化表达式可以是任意的(对全局变量和静态变量有区别),由于逗号运算符是从左到右运算的,那么看看这样行不行?

 int a=3,b=a,c=5;

 (三)、标准输入输出语句

 Turbo C 2.0标准库提供了两个控制台格式化输入、输出函数scanf();和printf();这两个函数可以在标准输入输出设备上以各种不同的格式读写数据。scanf() 函数用来从标准输入设备(键盘)上读数据,printf()函数用来向标准输出设备(屏幕)写数据。下面详细介绍这两个函数的用法。

 1.标准输入语句

 scanf()函数是格式化输入函数, 它从标准输入设备(键盘) 读取输入的信息。其调用格式为:

 scanf(, );

 格式化字符串包括以下三类不同的字符;

 (1).空白字符:空白字符会使scanf()函数在读操作中略去输入中的一个或多个空白字符。

 (2).非空白字符:一个非空白字符会使scanf()函数在读入时剔除掉与这个非空白字符相同的字符。

 (3).格式化说明符:以%开始,后跟一个或几个规定字符,用来确定输出内容格式。

 Turbo C 2.0提供的输入格式化规定符如下:

 ━━━━━━━━━━━━━━━━━━━━━━━━━━

 符号 作用

 ──────────────────────────

 %d 十进制有符号整数

 %u 十进制无符号整数

 %f 浮点数

 %s 字符串

 %c 单个字符

 %p 指针的值

 %x,%X 无符号以十六进制表示的整数

 %o 无符号以八进制表示的整数

 ━━━━━━━━━━━━━━━━━━━━━━━━━━

 地址表是需要读入的所有变量的地址,而不是变量本身,取地址符为'&'。各个变量的地址之间同,分开。

 例如:

 scanf(%d,%d,&i,&j);

 上例中的scanf()函数先读一个整型数,然后把接着输入的逗号剔除掉,最后读入另一个整型数。如果,这一特定字符没有找到,scanf()函数就终止。若参数之间的分隔符为空格,则参数之间必须输入一个或多个空格。

 说明:

 (a).对于各个变量,类型说明符是什么,输入格式化说明符就应该用对应的类型。否则会出现程序错误或输入数据和理想的不一样。

 (b).对于字符串数组或字符串指针变量,由于数组名和指针变量名本身就是地址,因此使用scanf()函数时,不需要在它们前面加上&操作符。

 char *p,str[20];

 scanf(%s, p);

 scanf(%s, str);

 具体字符串,指针的知识以后再介绍。

 (c).可以在格式化字符串中的%各格式化规定符之间加入一个整数,表示任何读操作中的最大位数。

 如上例中若规定只能输入10字符给字符串指针p,则第一条scanf()函数语句变为:

 scanf(%10s, p);

 程序运行时一旦输入字符个数大于10, p就不再继续读入。

 实际使用scanf()函数时存在一个问题, 下面举例进行说明:

 当使用多个scanf()函数连续给多个字符变量输入时, 例如:

 char c1, c2;

 scanf(%c, &c1);

 scanf(%c, &c2);

 运行该程序,输入一个字符A后回车(要完成输入必须回车),在执行scanf(%c,&c1)时,给变量c1赋值A,但回车符仍然留在缓冲区内,执行输入语句scanf(%c,&c2)时,变量c2输出的是一空行,如果输入AB后回车,那么实际存入变量里的结果为c1为A,c2为B。

 要解决以上问题, 可以在输入函数前加入清除函数fflush();(这个函数的使用方法将在本节最后讲述)。

 (d).当在格式说明符之间加入'*'时,表示跳过输入,例如:

 scanf(%3*d,&a);

 当输入12345的时候,前面三个字符跳过去不考虑,最终变量a的值为45。

 2.标准输出语句

 printf()函数是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:

 printf(, );

 其中格式化字符串包括两部分内容:一部分是正常字符,

 这些字符将按原样输出;另一部分是格式化规定字符,以%开始,后跟一个或几个规定字符,用来确定输出内容格式。

 参量表是需要输出的一系列参数,其个数必须与格式化字符串所说明的输出参数个数一样多,各参数之间用,分开,且顺序一一对应,否则将会出现意想不到的错误。

 对于输出语句,还有两个格式化说明符

 符号 作用

 %e 指数形式的浮点数

 %g 自动选择合适的表示法

 说明:

 (1).可以在%和字母之间插进数字表示最大场宽。

 例如: %3d 表示输出3位整型数,不够3位右对齐。

 %9.2f 表示输出场宽为9的浮点数,其中小数位为2,整数位为6,小数点占一位,不够9位右对齐。

 %8s 表示输出8个字符的字符串,不够8个字符右对齐。

 如果字符串的长度、或整型数位数超过说明的场宽,将按其实际长度输出。但对浮点数,若整数部分位数超过了说明的整数位宽度,将按实际整数位输出;若小数部分位数超过了说明的小数位宽度,则按说明的宽度以四舍五入输出。

 另外,若想在输出值前加一些0, 就应在场宽项前加个0。

 例如: %04d 表示在输出一个小于4位的数值时,将在前面补0使其总宽度为4位。

 如果用浮点数表示字符或整型量的输出格式,小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。

 例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9,则第9个字符以后的内容将被删除。

 (2). 可以在%和字母之间加小写字母l,表示输出的是长型数。

 例如: %ld 表示输出long整数

 %lf 表示输出double浮点数

 (3). 可以控制输出左对齐或右对齐,即在%和字母之间加入一个- 号可说明输出为左对齐,否则为右对齐。

 例如: %-7d 表示输出7位整数左对齐

 %-10s 表示输出10个字符左对齐

 一些特殊规定字符(可以参照前面说的转义字符)

 ━━━━━━━━━━━━━━━━━━━━━━━━━━

 字符 作用

 ──────────────────────────

 \n 换行

 \f 清屏并换页

 \r 回车

 \t Tab符

 \xhh 表示一个ASCII码用16进表示

猜你喜欢

1. 比较诗意的情感句子

2. 表达伤心比较有意义的句子

3. 想表达合作成功的语句

4. c语言中逻辑或的用法

5. 表达看淡一切的句子

6. 表达奋斗的句子

7. 五种常见表达句子间关系的词汇

a++是首先拷贝自己的副本,然后对真值加一。

++a是对真值加一,然后使用真值。

例子:

int a=0, b, c;

b = a++;

c = ++a;

printf("b=%d, c=%d", b, c);

上述程序段运行结果为b=0,c=2,可以证明理论。而a++和++a本身在单独使用时,与a=a+1是等价的。

扩展资料:

C语言的特性:

1、C语言是一种底层语言 为了适应系统编程的需要,C语言提供了对机器级概念(例如,字节和地址)的访问,而这些都是其他编程语言试图隐藏的内容。

2、C语言是一种小型语言 与许多其他编程语言相比,C语言提供了一套更有限特性集合。(在K&R第二版的参考手册中仅用49页就描述了整个C语言。)为了使特性较少,C语言在很大程度上依赖一个标准函数的“库”。

3、C是一种包容性语言 C假设用户知道自己在干什么,因此它提供了比其他许多语言更广阔的自由度。此外,C语言不像其他语言那样强制进行详细的错误检查。

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)