素早い文字列
Swift 文字列は文字のコレクションです。たとえば、「Hello, World!」は順序付けられた文字型値のコレクションであり、そのデータ型は String です。
文字列を作成する
文字列リテラルまたは String クラスのインスタンスを使用して文字列を作成できます:
import Cocoa // 使用字符串字面量 var stringA = "Hello, World!" print( stringA ) // String 实例化 var stringB = String("Hello, World!") print( stringB )
上記のプログラム実行の出力は次のとおりです:
Hello, World! Hello, World!
空の文字列
空を使用できます文字列リテラルを変数に割り当てるか、String クラスのインスタンスを初期化して空の文字列を初期化します。 文字列属性 isEmpty を使用して、文字列が空かどうかを判断できます:
import Cocoa // 使用字符串字面量创建空字符串 var stringA = "" if stringA.isEmpty { print( "stringA 是空的" ) } else { print( "stringA 不是空的" ) } // 实例化 String 类来创建空字符串 let stringB = String() if stringB.isEmpty { print( "stringB 是空的" ) } else { print( "stringB 不是空的" ) }
上記のプログラム実行出力は次のとおりです:
stringA 是空的 stringB 是空的
文字列定数
文字列を変数または定数に割り当てることができ、その変数は変更可能です。定数は変更できません。
import Cocoa // stringA 可被修改 var stringA = "php中文网:" stringA += "http://www.php.cn" print( stringA ) // stringB 不能修改 let stringB = String("php中文网:") stringB += "http://www.php.cn" print( stringB )
上記のプログラムの実行出力は、stringB が定数であり変更できないと考えて、エラーを報告します:
error: left side of mutating operator isn't mutable: 'stringB' is a 'let' constant stringB += "http://www.php.cn"
文字列への値の挿入
文字列補間は、新しい文字列を構築する方法です。定数、変数、リテラル、式を含めることができます。 挿入する文字列リテラルの各項目は、前にバックスラッシュが付いたかっこで囲まれます。
import Cocoa var varA = 20 let constA = 100 var varC:Float = 20.0 var stringA = "\(varA) 乘于 \(constA) 等于 \(varC * 100)" print( stringA )
上記のプログラム実行の出力は次のとおりです:
20 乘于 100 等于 2000.0
文字列の連結
文字列は接続するために + 数値を渡すことができます (例)
import Cocoa let constA = "php中文网:" let constB = "http://www.php.cn" var stringA = constA + constB print( stringA )
上記のプログラム実行の出力結果は次のとおりです:
php中文网:http://www.php.cn
文字列の長さ
文字列の長さはString.characters.count属性を使用して計算されます。例は次のとおりです:
import Cocoa var varA = "www.php.cn" print( "\(varA), 长度为 \(varA.characters.count)" )
上記のプログラムの実行 出力結果は次のとおりです:
www.php.cn, 长度为 14
文字列比較
2 つの文字列が等しいかどうかを比較するには == を使用できます:
import Cocoa var varA = "Hello, Swift!" var varB = "Hello, World!" if varA == varB { print( "\(varA) 与 \(varB) 是相等的" ) } else { print( "\(varA) 与 \(varB) 是不相等的" ) }
上記のプログラム実行の出力結果は次のとおりです:
Hello, Swift! 与 Hello, World! 是不相等的
Unicode string
Unicode はテキストをエンコードするための国際標準であり、Swift の String 型は Unicode に基づいて構築されています。文字列内の UTF-8 と UTF-16 のエンコーディングをループして反復できます。例は次のとおりです。
import Cocoa var unicodeString = "php中文网" print("UTF-8 编码: ") for code in unicodeString.utf8 { print("\(code) ") } print("\n") print("UTF-16 编码: ") for code in unicodeString.utf16 { print("\(code) ") }
上記のプログラムの実行の出力結果は次のとおりです:
UTF-8 编码: 232 143 156 233 184 159 230 149 153 231 168 139 UTF-16 编码: 33756 40479 25945 31243
文字列関数と演算子
Swift は、次のタイプの文字列関数と演算子をサポートします:
シリアル番号 | 関数/演算子と説明 |
---|---|
1 | isEmpty は、文字列が空かどうかを判断し、ブール値を返します |
2 | hasPrefix(prefix: String) 文字列に特定の接頭辞があるかどうかを確認します |
3 | hasSuffix(suffix: String) 文字列に次があるかどうかを確認します特定の接尾辞。 |
4 | Int(String) 文字列数値を整数に変換します。
例: let myString: String = "256" let myInt: Int? = Int(myString) |
5 | String.characters.count 文字列の長さをカウントする |
6 | ut f 8 を横断することができますUTF-8 エンコーディングにアクセスするための文字列 utf8 属性 |
7 | utf16 utf8 プロパティを反復処理することで、文字列の UTF-16 エンコーディングにアクセスできます |
8 | unicodeScalars 文字列を反復処理できます値 unicodeScalars プロパティを使用して、その Unicode スカラー エンコーディングにアクセスします。 = |
11 == | |
12 < ; | |
13 != | |