zoukankan      html  css  js  c++  java
  • strstr(),strchr()

      strstr($a, $b)和strchr()一样,起的别名,表示查找$a中第一次出现$b,并返回字符串的剩余部分:

    。strrchr()从后往前查第一个出现的

    直接写两行代码:

    <?php
    
    $str = 'abc0';
    
    echo strstr($str, '0');// 0
    
    echo '<hr/>';
    
    echo strstr($str, '0') == '0';// 1
    
    echo '<hr/>';
    
    // 注意两个等号和三个等号的区别,字符串0和false 强制转换后是一样的。    所以应用时 要使用  ===
    echo strstr($str, '0') == false;
    
    echo '<hr/>';
    
    echo strstr($str, '0') === false;// false
    echo '<hr/>';
    
    
    
    $str = 'abcabcdefg';
    
    // 很常见的一个substr()和strchr()联合用法,取这个字符的后边出现的
    echo substr(strchr($str, 'd'), 1);// efg
    
    echo '<hr/>';
    
    // 也可以这样 当然要知道'd’有没有,可以判断下!==false
    echo substr($str, stripos($str, 'd')+1);// efg
    
    echo '<hr/>';
    
    // 从后往前查第一个f出现
    echo strrchr($str, 'f');// fg
     

     练练算法,用php部分实现strstr()函数,检查一个串是不是另一个串的子串,简单测了一下可以

    <?php
    
    
    /**
     * @param $a
     * @param $b
     * b是子串
     * a是全量
     */
    
    function str($a, $b){
        $alen = strlen($a);
        $blen = strlen($b);
        for($i=0; $i<= ($alen - $blen); $i++){
            if($a[$i] == $b[0]){
                $x = $i;
                for($j=0; $j< $blen; $j++){
                    if($b[$j] != $a[$i++]){
                        $i = $x;
                        break;
                    }
                }
                if(intval($j) == $blen){
                    return true;
                }
            }
            
        }
        return false;
    }
  • 相关阅读:
    ASP.Net请求处理机制初步探索之旅
    ASP.Net请求处理机制初步探索之旅
    ASP.Net请求处理机制初步探索之旅
    NET平台处理HTTP请求
    HTTP.SYS
    ASP.NET页面与IIS底层交互和工作原理
    MUI的一些笔记
    SpringMCV跨域
    servlet跨域
    Git
  • 原文地址:https://www.cnblogs.com/firstForEver/p/4885577.html
Copyright © 2011-2022 走看看