split 抽象方法

List<String> split(
  1. Pattern pattern
)

根据 pattern 的匹配位置来分割字符串,并返回一个包含子字符串的列表。

查找此字符串中所有 pattern 的匹配项,就像使用 Pattern.allMatches 一样,并返回匹配项之间的子字符串列表、第一个匹配项之前和最后一个匹配项之后的子字符串。

const string = 'Hello world!';
final splitted = string.split(' ');
print(splitted); // [Hello, world!];

如果模式在此字符串中没有匹配项,则结果始终是一个仅包含原始字符串的列表。

如果 pattern 是一个 String,则以下情况始终成立:

string.split(pattern).join(pattern) == string

如果第一个匹配项是字符串开头的空匹配,则不包括其之前的空子字符串。如果最后一个匹配项是字符串结尾的空匹配,则不包括其之后的空子字符串。如果一个匹配项是空的,并且它紧接在先前的匹配项之后(它从先前的匹配项结束的位置开始),则不包括两个匹配项之间的空子字符串。

const string = 'abba';
final re = RegExp(r'b*');
// re.allMatches(string) will find four matches:
// * empty match before first "a".
// * match of "bb"
// * empty match after "bb", before second "a"
// * empty match after second "a".
print(string.split(re)); // [a, a]

字符串开头或结尾的空匹配,或在其他匹配项之后,不会被特别处理,这会在结果中引入空子字符串。

const string = 'abbaa';
final splitted = string.split('a'); // ['', 'bb', '', '']

如果此字符串是空字符串,且 pattern 匹配空字符串,则结果是一个空列表,因为第一个和最后一个空匹配之前和之后的空字符串不会包括在内。(如果模式不匹配,它仍然是一个仅包含原始空字符串的列表 [""])。

const string = '';
print(string.split('')); // []
print(string.split('a')); // []

使用空模式进行分割会将字符串分割成单个代码单元字符串。

const string = 'Pub';
print(string.split('')); // [P, u, b]

// Same as:
var codeUnitStrings = [
  for (final unit in string.codeUnits) String.fromCharCode(unit)
];
print(codeUnitStrings); // [P, u, b]

分割发生在UTF-16代码单元边界处,而不是在rune(Unicode码点)边界处。

// String made up of two code units, but one rune.
const string = '\u{1D11E}';
final splitted = string.split('');
print(splitted); // ['\ud834', '\udd1e'] - 2 unpaired surrogate values

要获取包含字符串中单个runes的字符串列表,请不要使用split。您可以通过以下方式获取每个runes的字符串:

const string = '\u{1F642}';
for (final rune in string.runes) {
  print(String.fromCharCode(rune));
}

实现

List<String> split(Pattern pattern);