zoukankan      html  css  js  c++  java
  • split(resource,limit) 中limit 的含义

    limit 参数控制模式应用的次数,因此影响结果数组的长度。如果该限制 n 大于 0,则模式将被最多应用 n - 1 次,数组的长度将不会大于 n,而且数组的最后项将包含超出最后匹配的定界符的所有输入。如果 n 为非正,则模式将被应用尽可能多的次数,而且数组可以是任意长度。如果 n 为零,则模式将被应用尽可能多的次数,数组可有任何长度,并且结尾空字符串将被丢弃。 

    例如,字符串 "boo:and:foo" 使用这些参数可生成下列结果: 

    Regex Limit 结果 
    (:,2) ->{ "boo", "and:foo" } 
    (:, 5) -> { "boo", "and", "foo" } 
    (: -2 )->{ "boo", "and", "foo" } 
    (o 5 )->{ "b", "", ":and:f", "", "" } 
    (o -2 )->{ "b", "", ":and:f", "", "" } 
    (o 0 )->{ "b", "", ":and:f" } 

    不管怎么说,最后如果原来resurce 上本身没有的 分割后就不会补 空字符,只有resource 本身 有的 ,而且limit 又符合情况的,自后分割出的额string 数组 最后才会补 空字符。

    比如上边 (:,5) 规定最后数组应该为5个元素,可分割只能有三个元素,所以最后不可能补 2个空字符。又如上边(o,5)规定最后数组为5个元素,而分割也刚好为5个元素,只不过最后2个元素本身就是空字符,所以最终就是这个5个元素。又比如(o,6)记过肯定和 (o,5)是一样的,不会最后再补一个空字符,因为resource本身正常分割只能分割出5个元素。

  • 相关阅读:
    Google Protocol Buffers学习
    C学习笔记-一些知识
    前端相关
    Spark笔记-gz压缩存储到HDFS【转】
    maven笔记-将本地jar包打包进可执行jar中
    Spark运行时错误与解决
    机器学习笔记
    Spark笔记-DataSet,DataFrame
    云平台各层解释
    linux笔记-多服务器同时执行相同命令
  • 原文地址:https://www.cnblogs.com/wzhanke/p/4444291.html
Copyright © 2011-2022 走看看