swift-day02-字符串和字符
- string 创建和操作自负串的语法和C语言操作类似,轻量易读,字符串的连接操作只需要简单的通过“+”将两个字符串相连即可
- 字符串字面量是由双引号 ("") 包裹着的具有固定顺序的文本字符集。 字符串字面量可以用于为常量和变量提供初始值
- 初始化空字符串,要创建一个空字符串作为初始值,可以将空的字符串字面量赋值给变量,也可以初始化一个新的String实例
import UIKit
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
//string 创建和操作自负串的语法和C语言操作类似,轻量易读,字符串的连接操作只需要简单的通过“+”将两个字符串相连即可
//字符串字面量是由双引号 ("") 包裹着的具有固定顺序的文本字符集。 字符串字面量可以用于为常量和变量提供初始值:
let someString = "peng";//someString常量是通过字符面亮进行初始化
//初始化空字符串,要创建一个空字符串作为初始值,可以将空的字符串字面量赋值给变量,也可以初始化一个新的String实例
var emptyString = "";//空字符串字面量
var anotherEmptyEmptyStirng = String();//初始化方法
if emptyString.isEmpty{//isEmpty属性来判断字符串是否为空
//字符串的可变性,可以通过将一个特定字符串分配给一个变量来对其进行修改,或者分配给一个常量来保证其不会被修改:
var variableString = "peng";
variableString += "I love you";
}
//字符串是值类型(Strings Are Value Types)
//Swift 的String类型是值类型。 如果您创建了一个新的字符串,那么当其进行常量、变量赋值操作,或在函数/方法中传递时,会进行值拷贝。 任何情况下,都会对已有字符串值创建新副本,并对该新副本进行传递或赋值操作。
//Swift 默认字符串拷贝的方式保证了在函数/方法中传递的是字符串的值。 很明显无论该值来自于哪里,都是您独自拥有的。 您可以确信传递的字符串不会被修改,除非你自己去修改它。
//在实际编译时,Swift 编译器会优化字符串的使用,使实际的复制只发生在绝对必要的情况下,这意味着您将字符串作为值类型的同时可以获得极高的性能。
//使用for-in循环来遍历字符串中的characters属性来获取每一个字符的值
for Character in "peng".characters{
print(Character)
/*输出结果:p
e
n
g
*/
}
//通过标明一个Character类型并用字符字面量进行赋值,可以建立一个独立的字符常量或变量
let Mark : Character = "!"
print(Mark)
//字符串可以通过传递一个值类型为Character的数组作为自变量来初始化
let pengCharcater:[Character] = ["p","e","n","g","😄"];
let pengString = String(pengCharcater)
print(pengString)//打印:peng😄
//连接字符串和字符 (Concatenating Strings and Characters),字符串可以通过加法运算符+相加在一起(或称“连接”)创建一个新的字符串:
let str1 = "hell0";
let str2 = " Wrold"
var string3 = str1 + str2;
//用append()方法将一个字符附加到一个字符串变量的尾部,注意:用此方法您不能将一个字符串或者字符添加到一个已经存在的字符变量上,因为字符变量只能包含一个字符
let eMark: Character = "!";
string3.append(eMark)
//字符串插值,字符串插值是一种构建新字符串的方式,可以在其中包含常量、变量、字面量和表达式。 您插入的字符串字面量的每一项都在以反斜线为前缀的圆括号中,注意:插值字符串中写在括号中的表达式不能包含非转义反斜杠 (\),并且不能包含回车或换行符。不过,插值字符串可以包含其他字面量。
let mp = 3;
let resulet = "\(mp)times 2 is \(3*2)";
print(resulet);//输出结果:3times 2 is 6
//计算字符数量 (Counting Characters)如果想要获得一个字符串中Character值的数量,可以使用字符串的characters属性的count属性
print(resulet.characters.count)//13
//字符串索引不同的字符可能会占用不同数量的内存空间,所以要知道Character的确定位置,就必须从String开头遍历每一个 Unicode 标量直到结尾。因此,Swift 的字符串不能用整数(integer)做索引。
// 使用startIndex属性可以获取一个String的第一个Character的索引。使用endIndex属性可以获取最后一个Character的后一个位置的索引。因此,endIndex属性不能作为一个字符串的有效下标。如果String是空串,startIndex和endIndex是相等的。
// 通过调用String.Index的predecessor()方法,可以立即得到前面一个索引,调用successor()方法可以立即得到后面一个索引。任何一个String的索引都可以通过锁链作用的这些方法来获取另一个索引,也可以调用advancedBy(_:)方法来获取。但如果尝试获取出界的字符串索引,就会抛出一个运行时错误。
//greet.endIndex = 字符串长度 greet.endIndex.predecessor() = 字符的最后索引
let greet = "swift I love i";
print( greet[greet.startIndex]);//s
print( greet[greet.startIndex.successor()]);//w
print(greet.endIndex)//14
print(greet.endIndex.predecessor())//13
let index = greet.startIndex.advancedBy(9)
print(greet[index])//o
//使用characters属性的indices属性会创建一个包含全部索引的范围(Range),用来在一个字符串中访问单个字符
for index in greet.characters.indices{
print("\(greet[index]) ", terminator: "")//s w i f t I l o v e i
}
//插入和删除,调用insert(_:atIndex:)方法可以在一个字符串的指定索引插入一个字符
var hello = "hello";
hello.insert("!", atIndex: hello.endIndex)//结果为:hello!
//调用insertContentsOf(_:at:)方法可以在一个字符串的指定索引插入一个字符串
hello.insertContentsOf(" wrold".characters, at: hello.endIndex.predecessor())//
//调用removeAtIndex(_:)方法可以在一个字符串的指定索引删除一个字符。
hello.removeAtIndex(hello.endIndex.predecessor())//hell的现在结果为“hello wrold”
//调用removeRange(_:)方法可以在一个字符串的指定索引删除一个子字符串
let range = hello.endIndex.advancedBy(-6)..<hello.endIndex
hello.removeRange(range)
print(hello)//hello
//比较字符串,Swift 提供了三种方式来比较文本值:字符串字符相等、前缀相等和后缀相等
//字符串/字符相等,字符串/字符可以用等于操作符(==)和不等于操作符(!=),
//前缀/后缀相等 (Prefix and Suffix Equality),通过调用字符串的hasPrefix(_:)/hasSuffix(_:)方法来检查字符串是否拥有特定前缀/后缀,两个方法均接收一个String类型的参数,并返回一个布尔值
// Do any additional setup after loading the view, typically from a nib.
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}