OC 浮点数转化整数
1.简单粗暴,直接转化
float f = 1.5;
int a;
a = (int)f;
NSLog("a = %d",a);
输出结果是1。(int)是强制类型转化,丢弃浮点数的小数部分。
2.高斯函数,向下取整
float f = 1.6;
int a;
a = floor(f);
NSLog("a = %d",a);
输出结果是1。floor()方法是向下取整,类似于数学中的高斯函数 [].取得不大于浮点数的最大整数,对于正数来说是舍弃浮点数部分,对于复数来说,舍弃浮点数部分后再减1.
3.ceil函数,向上取整。
float f = 1.5;
int a;
a = ceil(f);
NSLog("a = %d",a);
输出结果是2。ceil()方法是向上取整,取得不小于浮点数的最小整数,对于正数来说是舍弃浮点数部分并加1,对于复数来说就是舍弃浮点数部分.
4.通过强制类型转换四舍五入。
float f = 1.5;
int a;
a = (int)(f+0.5);
NSLog("a = %d",a);
其中原理非常简单,所以就不做详细说明了。
--------------------------------------
Objective-C基本数据类型取值范围、字节
类型限定修饰词
一些类型限定修饰词
short短型,修饰int、double;
long长型,修饰int、double;
signed有符号型,修饰int、char;
unsigned 无符号型,修饰int、char;
1.这些限定词经常用来限定int型,在限定int类型时int可以省略;
2.short和long会改变int型的长度,在不同编译器长度不相同,但是一般short长度不大于int,int长度不大于long;
3.signed和unsigned不会改变类型长度,仅表示最高位是否为符号位,其中unsigned表示大于等于0的正数;
取值范围
为了以后开发中能够方便查找,并正确的使用数据类型,下面是部分数据类型的取值范围:
int: -2147483648~2147483647
unsigned int: 0~4294967295
short: -32768~32767
unsigned short: 0~65535
long: -2147483648~2147483647
unsigned long: 0~4294967295
存储空间
下面列出的是常用数据类型占用的存储空间
数据类型 16位编译器 32位编译器 64位编译器
char 1byte 1byte 1byte
int 2byte 4byte 4byte
float 4byte 4byte 4byte
double 8byte 8byte 8byte
short int 2byte 2byte 2byte
unsigned int 2byte 4byte 4byte
long 4byte 4byte 8byte
unsigned long 4byte 4byte 8byte
long long 8byte 8byte 8byte
————————————————
参考链接 https://blog.csdn.net/MinggeQingchun/article/details/52230467
posted on 2016-06-17 15:00 🌞Bob 阅读(363) 评论(0) 编辑 收藏 举报