asp.net.ph

Skip Navigation LinksHome > Getting Started > ASP.NET Base Types > Basic String Operations > Comparing Strings

Comparing Strings

Getting Started   ASP.NET Base Types   Basic String Operations


The .NET Framework provides several methods to compare the values of strings. The following table lists and describes the value-comparison methods.

Method Name Use
String.Compare Compares the values of two strings. Returns an integer value.
String.CompareOrdinal Compares two strings without regard to local culture. Returns an integer value.
String.CompareTo Compares the current string object to another string. Returns an integer value.
String.StartsWith Determines if a string begins with the string passed. Returns a Boolean value.
String.EndsWith Determines if a string ends with the string passed. Returns a Boolean value.
String.Equals Determines if two strings are the same. Returns a Boolean value.
String.IndexOf Returns the index position of a character or string, starting from the beginning of the string you are examining. Returns an integer value.
String.LastIndexOf Returns the index position of a character or string, starting from the end of the string you are examining. Returns an integer value.

Compare

The String.Compare method provides a thorough way of comparing the current string object to another string or object. This method is culturally aware. You can use this function to compare two strings or substrings of two strings. Additionally, overloads are provided that regard or disregard case and cultural variance. The following table shows the three integer values that might be returned by this method.

Value Type Condition
A negative integer strA is less than strB.
0 strA equals strB.
A positive integer

-or-

1

This instance is greater than value.

-or-

value is a null reference ( Nothing in Visual Basic ).

The following code example uses the Compare method to determine the relative values of two strings.

 [ VB ]
Dim myString As String = "Hello World!"
Console.WriteLine ( [ String ].Compare ( myString, "Hello World?" ) )
 [ C# ]
string myString = "Hello World!";      
Console.WriteLine ( String.Compare ( myString, "Hello World?" ) );

This example displays -1 to the console.

CompareOrdinal

The String.CompareOrdinal method compares two string objects without considering the local culture. The return values of this method are identical to the values returned by the Compare method in the previous table.

The following code example uses the CompareOrdinal method to compare the values of two strings.

 [ VB ]
Dim myString As String = "Hello World!"
Console.WriteLine ( String.CompareOrdinal ( myString, "hello world!" ) )
 [ C# ]
string myString = "Hello World!";      
Console.WriteLine ( String.CompareOrdinal ( myString, "hello world!" ) );

This example displays -32 to the console.

CompareTo

The String.CompareTo method compares the string that the current string object encapsulates to another string or object. The return values of this method are identical to the values returned by the Compare method in the previous table.

The following code example uses the CompareTo method to compare the myString object to the OtherString object.

 [ VB ]
Dim myString As String = "Hello World!"
Dim OtherString As String = "Hello Cruel World!"
Dim myInt As Integer = myString.CompareTo ( OtherString )
Console.WriteLine ( myInt )
 [ C# ]
String myString = "Hello World!";
String OtherString = "Hello Cruel World!";
int myInt = myString.CompareTo ( OtherString );    
Console.WriteLine ( myInt );

This example displays 1 to the console.

Equals

The String.Equals method can easily determine if two strings are the same. This case-sensitive method returns a True or False Boolean value. It can be used from an existing class, as illustrated in the next example. The following code example uses the Equals method to determine if a string object contains the phrase "Hello World".

 [ VB ]
Dim myString As String = "Hello World"
Console.WriteLine ( myString.Equals ( "Hello World" ) )
 [ C# ]
string myString = "Hello World";
Console.WriteLine ( myString.Equals ( "Hello World" ) );

This example displays True to the console.

This method can also be used as a static method. The following code example compares two string objects using a static method.

 [ VB ]
Dim myString As String = "Hello World"
Dim YourString As String = "Hello World"
Console.WriteLine ( String.Equals ( myString, YourString ) )
 [ C# ]
string myString = "Hello World";
string YourString = "Hello World";
Console.WriteLine ( String.Equals ( myString, YourString ) );

This example displays True to the console.

StartsWith and EndsWith

You can use the String.StartsWith method to determine if a string object begins with the same characters that encompass another string. This case-sensitive method returns true if the current string object begins with the passed string and false if it does not. The following code example uses this method to determine if a string object begins with "Hello".

 [ VB ]
Dim myString As String = "Hello World"
Console.WriteLine ( myString.StartsWith ( "Hello" ) )
 [ C# ]
string myString = "Hello World";
Console.WriteLine ( myString.StartsWith ( "Hello" ) );

This example displays True to the console.

The String.EndsWith method compares a passed string to the characters that exist at the end of the current string object. It also returns a Boolean value. The following code example checks the end of a string using the EndsWith method.

 [ VB ]
Dim myString As String = "Hello World"
Console.WriteLine ( myString.EndsWith ( "Hello" ) )
 [ C# ]
string myString = "Hello World";    
Console.WriteLine ( myString.EndsWith ( "Hello" ) );

This example displays Falseto the console.

IndexOf and LastIndexOf

You can use the String.IndexOf method to determine the position of the first occurrence of a particular character within a string. This case-sensitive method starts counting from the beginning of a string and returns the position of a passed character using a zero-based index. If the character cannot be found, a value of –1 is returned.

The following code example uses the IndexOf method to search for the first occurrence of the ’l’ character in a string.

 [ VB ]
Dim myString As String = "Hello World"
Console.WriteLine ( myString.IndexOf ( "l"c ) )
 [ C# ]
string myString = "Hello World";
Console.WriteLine ( myString.IndexOf ( 'l' ) );

This example displays 2 to the console.

The String.LastIndexOf method is similar to the String.IndexOf method except that it returns the position of the last occurrence of a particular character within a string. It is case-sensitive and uses a zero-based index.

The following code example uses the LastIndexOf method to search for the last occurrence of the ’l’ character in a string.

 [ VB ]
Dim myString As String = "Hello World"
Console.WriteLine ( myString.LastIndexOf ( "l"c ) )
 [ C# ]
string myString = "Hello World";    
Console.WriteLine ( myString.LastIndexOf ( 'l' ) );

This example displays 9 to the console.

Both methods are useful when used in conjunction with the String.Remove method. You can use either the IndexOf or LastIndexOfmethods to retrieve the position of a character, and then supply that position to the Remove method in order to remove a character or a word that begins with that character.

See Also

Basic String Operations



© 2025 Reynald Nuñez and asp.net.ph. All rights reserved.

If you have any question, comment or suggestion
about this site, please send us a note