IndexOf method returns 0 when it should had return -1 in C# / Java

前端 未结 8 560
被撕碎了的回忆
被撕碎了的回忆 2021-01-12 10:47

A friend of mine came to me with this strange behavior which i can\'t explain, any insight view would be appreciated.

Im running VS 2005 (C# 2.0), the following code

相关标签:
8条回答
  • 2021-01-12 11:17

    Just for the fun of it. It also works like that in python

    >>> "test".startswith("")
    True
    >>> "test".index("")
    0
    

    Python throws a ValueError instead of the -1 that is nice.

    >>> "test".index('r')
    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
    ValueError: substring not found
    
    0 讨论(0)
  • 2021-01-12 11:18

    0 is correct. Start at position zero and you can (trivially) match a zero-length string. Likewise, "" contains "".

    0 讨论(0)
  • 2021-01-12 11:19

    0 is correct. The Javadocs point out that indexOf works as follows:

    The integer returned is the smallest value k such that:

     this.startsWith(str, k)
    

    Any string starting with "" is equal to the original string (and every string starts with ""), so the smallest k for str = "" is always 0.

    0 讨论(0)
  • 2021-01-12 11:24

    Think of it this way: IndexOf, when looking for a string, will start at position 0, try to match the string, if it doesn't fit, move on to position 1, 2, etc. When you call it with an empty string, it attempts to match the empty string with the string starting at position 0 with length 0. And hooray, nothing equals nothing.

    Side note: There's no real reason to use ToString when you're using Console.Write/WriteLine. The function automatically calls the ToString method of the object in question. (Unless overloading ToString)

    0 讨论(0)
  • 2021-01-12 11:28

    This is not an exception to the rule, but rather a natural consequence of how indexOf and startsWith are defined.

    You’re claiming that "test".indexOf("") should return -1. This is essentially equivalent to the claim that "test".startsWith("") should return false. Why is this? Although this case is specifically addressed in the documentation as returning true, this is not just an arbitrary decision.

    How would you decide "test".startsWith("te"), for example? The simplest way is to use recursion. Since both strings start with the character 't', you call "est".startsWith("e") and return the result. Similarly, you will call "st".startsWith("") and return the result. But you already know that the answer should be true, so that is why every string starts with "".

    0 讨论(0)
  • 2021-01-12 11:33

    It should return 0. You are looking for the first occurrence of an empty string, right? :)

    0 讨论(0)
提交回复
热议问题