Swift学习笔记_数据类型_浮点类型

浮点类型

是有小数部分的数字。表示的范围比整数类型更大,可存储比Int类型更大或更小的数字。

提供了3种表示形式:

(1)Float 表示32位浮点数,可精确到小数点后6位。

(2)Double 表示64位浮点数,可精确到小数点后15位。

(3)Float80 表示80位浮点数,可精确到小数点后17位。

※Float32和Float64分别是Float和Double的类型别名

var floatv:Float = 0.12345678912345  //0.1234568
var floatv2:Float = 123.123456789 // 123.1235
var doublev:Double = 0.1234567890123456789123 //0.1234567890123457
var doublev2:Double = 1234.1234567890456789 //1234.123456789046
var float80v:Float80 = 0.12345678901234567891234 //0.123456789012345679
var float80v2:Float80 = 1234.1234567890456789 //1234.12345678904568

float80v = 0.123456789123456789123456789678 //0.123456789123456789
float80v = 3.123456789123456789123456  //3.12345678912345679
float80v = 3.1234567890123456789123456  //3.12345678901234568

var float32v:Float32 = 32.14159  //Float typealias
var float64v:Float64 = 3.141591242342342343 //Double typealias

选用何种浮点类型,取决于所存储的浮点数的范围,通常情况下,推荐使用Double类型。

如果声明变量或常量时,不指定数据类型,系统默认将浮点类型的变量或常量推断为Double类型。

var tmpva = 3.14159 //Double type

浮点类型的直接数有两种表示形式:

(1)10进制 没有前缀

(2)16进制 前缀是0x

小数点两边必须有至少一个10进制数字或是16进制数字。

还有一个可选的指数(exponent),在10进制浮点数中通过大写或小写的e来指定,如:men = m乘以10的n次方

在16进制浮点数中通过大写或小写的p来指定,如:0xmpn = m对应的10进制数乘以2的n次方

var tmpv1 = 3.14159e2 //314.159
var tmpv2 = 3.14159E-4 //0.000314159
var tmpv3 = 0xC.12p3 //96.5625
var tmpv4 = 0x0.12P3 //0.5625

和整数类型一样,可以给浮点类型的直接数添加若干个0或_,以提供可读性。

计算机在存储浮点数的时候是不准确,对于浮点数的比较需要格外小心。

比较可靠的做法是:比较其差的绝对值是否小于一个非常小的数值。

如果两个不同浮点类型的变量或常量进行运算时,必须进行显式的类型转换,否则会产生编译错误。

var fv1:Float = 3.14159
var dv1:Double = 3.14159

//fv1 = dv1 //cannot assign value of type Double to type Float
//dv1 = fv1 //cannot assign value of type Float to type Double
fv1 = Float(dv1)
dv1 = Double(fv1)

// error binary operator + cannot be applied to operands of type Float and Double
//fv1 + dv1
fv1 + Float(dv1)
Double(fv1) + dv1

如果整数类型和浮点类型的变量或常量进行运算时,必须进行显式的类型转换,否则会产生编译错误。

当把浮点类型转换成整数类型时,在该浮点数类型值不超出该整数类型所表示数值范围的前提下,

浮点类型的值的小数部分会被截掉。

var intv:Int = 10
var dblv:Double = 3.14159

//intv = dblv  //error cannot assign value of type Double to type Int
intv = Int(dblv) //3
//dblv = intv //erro cannot assign value of type Int to type Double
dblv = 3.14159
dblv = Double(intv)

// error binary operator + cannot be applied to operands of type Int and Double
//intv + dblv 
dblv = 3.14159
intv + Int(dblv) //6
Double(intv) + dblv ///6.14159

可以把整数类型的直接数直接赋值给浮点类型的变量或常量,

也可把整数类型的直接数和浮点类型的直接数进行运算,系统都会进行隐式类型转换。

但是把浮点类型的直接数赋值给整数类型的变量或常量,会产生编译错误。

dblv = 3
10 / 0.3
3.14159 + 10 //13.14159

//let cintv:Int = 4.14159 //cannot convert value of type Double to specified type Int
//var tmpint:Int = 3.14159
时间: 2024-10-07 19:57:50

Swift学习笔记_数据类型_浮点类型的相关文章

swift学习笔记之数据类型

前言:这份学习笔记是写给有编程经验的人看的,因为内容方面很多基础知识被省略掉了,所以请初学者们勿怪我写得不详尽. swift包括如下数据类型: 1.整型 Int var age:Int = 20 let age:Int = 20 [注]在此说一下swift较Objective-C的改变. 1)以前定义一个变量如整型的,我们会想下面这样写 NSInteger age = 20; 现在定义变量得用var关键字,然后在变量名称后面使用冒号加变量类型的方式,或者声明类型,如下: var age = 20

Swift学习笔记(二)参数类型

关于参数类型,在以前的编程过程中,很多时间都忽视了形参与实参的区别.通过这两天的学习,算是捡回了漏掉的知识. 在swift中,参数有形参和实参之分,形参即只能在函数内部调用的参数,默认是不能修改的,如果想要修改就需要在参数前添加var声明. 但这样的声明过后,仍旧不会改变实参的值,这样就要用到inout了,传递给inout的参数类型必须是var类型的,不能是let类型或者字面类型,(字面类型是在swift中常提的一个术语,个人认为就是赋值语句,也不能修改)而且在传递过程中,要用传值符号"&

SWIFT学习笔记02

1.//下面的这些浮点字面量都等于十进制的12.1875: let decimalDouble = 12.1875 let exponentDouble = 1.21875e1 let hexadecimalDouble = 0xC.3p0//==12+3*(1/16) 2.//类型别名,用typealias关键字来定义类型别名 typealias AudioSample = UInt16 var maxAmplitudeFound = AudioSample.min 3.//元组 let ht

SWIFT学习笔记05

1.Swift 无需写break,所以不会发生这种贯穿(fallthrough)的情况.2.//用不到变量名,可用"_"替换 for _ in 1...power { answer *= base } 3.case 可以匹配更多的类型模式,包括区间匹配(range matching),元组(tuple)和特定类型的描述. 可以这样用case case 1...3: naturalCount = "a few" 4.如果存在多个匹配,那么只会执行第一个被匹配到的 ca

swift学习笔记(三)关于拷贝和引用

在swift提供的基本数据类型中,包括Int ,Float,Double,String,Enumeration,Structure,Dictionary都属于值拷贝类型. 闭包和函数同属引用类型 捕获则为拷贝.捕获即定义这些常量和变量的原作用域已不存在,闭包仍然可以在闭包函数体内引用和修改这些值 class属于引用类型. Array的情况稍微复杂一些,下面主要对集合类型进行分析: 一.关于Dictionary:无论何时将一个字典实例赋给一个常量,或者传递给一个函数方法时,在赋值或调用发生时,都会

Swift学习笔记

Apple 新推的Swift已经好几天了.对于向我这样的oc都还没完全琢磨透彻的菜鸟来说--(简直就是福利啊,joke) 看了几天的Swift,只是有了基本的印象.总感觉比较换混乱,可能源自与自己没怎么学过脚本语言.索性,边看边记,加深印象. 本来部分内容源自Apple的<The Swift Programming Language>以及互联网教程.其余内容均为个人理解,不保证正确. 进入正题: 1.Swift是什么? Apple唤他作:雨燕.其实英语过了四级的都应该看出来,Swift还有一层

C++学习笔记之数据类型

一.变量名 几条简单的C++命名规则: 在名称中只能使用字母,数字和下划线 名称的第一个字符不能是数字 区分大小写 不能将C++关键字用作名称 以两个下划线和大写字母打头的名称被保留给实现(编译器及其使用资源)使用.以一个下划线开头的名称被保留给实现,用作全局标识符. C++对名称长度没有限制 二.数据类型 计算机内存的最基本单元是位(bit).字节(byte)通常指的是8位内存单元,可以表示的范围0-255或者-128到127. (1)整型 short至少16位(大多数系统16位,-32768

Swift学习笔记五:循环和条件语句

一.循环语句 1. for循环 1) for -in 循环,对于数据范围,序列,集合等中的每一个元素,都执行一次 for a in 0...5{}    //循环迭代,从a=0到a=5,执行{}里的代码 注意:a只循环中存在,也就是出了{}a就不存在了 或者遍历数组 let a = [1,2,3] for b in a{} //循环迭代,从b=1到b=3 如果你不需要序列中的每一个值,可以使用_来忽略它,仅仅只是使用循环体本身: for _ in 0...5{}    //循环执行{}里的代码,

【转载】OpenStack Swift学习笔记

免责声明:     本文转自网络文章,转载此文章仅为个人收藏,分享知识,如有侵权,请联系博主进行删除.     原文作者:崔炳华      原文地址:http://blog.csdn.net/i_chips/article/details/17787017 1       概述 OpenStack Object Storage(Swift)是OpenStack开源云计算项目的子项目之一.Swift的目的是使用普通硬件来构建冗余的.可扩展的分布式对象存储集群,存储容量可达PB级. Swift并不是

Swift学习笔记十二:下标脚本(subscript)

下标脚本就是对一个东西通过索引,快速取值的一种语法,例如数组的a[0].这就是一个下标脚本.通过索引0来快速取值.在Swift中,我们可以对类(Class).结构体(structure)和枚举(enumeration)中自己定义下标脚本的语法 一.常规定义 class Student{ var scores:Int[] = Array(count:5,repeatedValue:0) subscript(index:Int) -> Int{ get{ return scores[index];