数据类型和表达式

数据类型

基本类型:int ,float, double, char 

int类型:

-134,10,0都是合法的整数常量。

要显示整型值可以用NSLog转换符%i。

数字中间不允许插入空格,并且不能使用逗号。

float类型:

3.,123.6,-. 0001都是合法的浮点常量。

要显示浮点值可用NSLog转换符%g和%f。

浮点类型也可以用科学计数法来进行,例如:12.4e9表示12.4*10^9;

double类型:

与float类型相似,但double类型的存储范围大概是float类型的两倍。

char类型:

‘a’,‘;’,‘0’都是合法的字符常量。将字符放入一对单引号中就能得到字符常量。

‘\n’是一个合法的字符常量,OC编译器将字符'\n'看作单个字符,尽管它实际实际上由两个字符组成。

限定词:long, long long, short, unsigned, signed

之所以使用short变量的原因,主要是对内存空间的考虑,当程序员需要大量的内存而可用的内存量又十分有限的时候,就可以用short变量来解决这个问题。

使用unsigned限制变量的使用,让它专门存储正数,可以扩展整形变量的范围。

id类型:

id数据类型可以存储任何类型的对象。


算数表达式

运算的优先级

优先级高的运算符首先求值,优先级相同的运算符,可按照从左向右或从右向左的方式求值。

如果要改变表达式的计算顺序,可以使用圆括号。

整数运算和一元负号运算符

负号(-)作为二元运算符,它执行两个数相减的操作,作为一元运算符,对一个对象取负。

与其他运算符相比。一元运算符具有更高的优先级,但一元正号(+)运算符除外,一元正号运算符和算术运算符的优先级相同。

模运算符

模运算符(%)只用于处理整数。就优先级而言,模运算的优先级与乘法和除法的优先级相等。

整型值和浮点值的相互转换

浮点值转换成整型值,数字的小数部分会被删节。

整型变量转换成浮点值,不会引起该数值的任何改变。

只要表达式中的两个运算数是整型(这一情况还试用于short,unsigned和long整型),该运算将在整数运算的规则下进行。因此,由乘法运算产的任何小数部分也都将删除,即使该结果赋给一个浮点变量。

只要表达式中的两个运算数,其中一个值是浮点变量或者常量,那么这一运算将看作浮点运算来处理。

类型转换运算符

f=(float) i/100;//类型强制转换符

类型转换符运算符将变量i 转换成float类型,该类型运算符永远不会影响变量的值。

类型转换运算符比其他所有的算术运算符的优先级都高,但一元减号和加号除外。

类型转换运算符通常用于将一般id类型的对象转换成特定类的对象。

例:

id myNumber;
Fraction * myFrcation;
myFraction= (Fraction) myNumber;

赋值运算符

将算术运算符和赋值运算符合并,格式为:

op=      op可以是任何算术运算符,例如:+,-,*,/,移位和屏蔽操作的位运算符。

除逗号外的所有运算符都比赋值运算符的优先级高。而所有的赋值运算符的优先级相同。

a/=b+c;等价于a=a/(b+c);

试用赋值运算符的目的:

1.程序语句更容易书写;

2.表达式通常容易阅读;

3.程序运行的速度更快,因为编译器有时在计算表达式时能够产生更少的代码。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值