-
C#优化字符串操作经验之谈
1.Convert.ToInt32与Int32.Parse的恩恩怨怨
2.Split的3种用法
3.@"abc"和"abc"区别在那里
4.保留2位有效小数及四舍五入
5.url传递中文的解决方案
6.把123456789转换为12-345-6789的3种方法
7.交换两个指定位置字符的4种方法
8.“%10”的妙用
9.输出21个AAAAAAAAAAAAAAAAAAAAA的巧妙做法
1.Convert.ToInt32与Int32.Parse的恩恩怨怨
这2个方法都可以把把string解析为int,那么我们一定会有疑问:到底他们有什么区别?什么时候该用什么?性能如何等等。
其实在2.0里还有Int32.TryParse也实现了同样的效果。
C# CODE
using System;using System.Collections.Generic;
using System.Text;
namespace ConsoleApplication1
...
{
class Program
...
{
static void Main(string[] args)
...
{
string myString = "1234";
int myint = 0;
myint = Convert.ToInt32(myString);
Console.Write(myint+"rn ");
myint = Int32.Parse(myString);
Console.Write(myint+"rn ");
Int32.TryParse(myString, out myint);
Console.Write(myint+"rn");
}
}}
(运行效果将是毫无差别,图略)
那么我们把代码改一下:
C# CODE
//string myString = "1234";
string myString = null;
int myint = 0;
myint = Convert.ToInt32(myString);
Console.Write(myint+"rn");
myint = Int32.Parse(myString);
Console.Write(myint+"rn");
Int32.TryParse(myString, out myint);
Console.Write(myint+"rn");
这次字符串是null,那么运行结果会怎样呢?
(程序将会异常!)
这是因为如果解析错误:
Convert.ToInt32()在null时不抛异常而是返回0;
Int32.Parse()要抛异常;
Int32.TryParse()不抛异常,会返回true或false来说明解析是否成功,如果解析错误,调用方将会得到0值。
由于Convert.ToInt32()在null时我们看不到Int32.TryParse()的运行结果所以再分调试和不调试来看结果的差异:
调试:
(将会看到 TryParse 返回 false。图略)
其实一般出bug毕竟属于少数,而且大家都会测试保证不出bug,那么我们最关心的或许就是性能。
再把代码修改一下:
C# CODE
string myString1 = "1234";
//string myString = null;
int myint = 0;
Console.Write(System.DateTime.Now.ToString()+" "+System.DateTime.Now.Millisecond.ToString() + " ");
for (int i = 0; i < 1000000;i++ )
...
{
myint = Convert.ToInt32(myString1);
}
Console.Write(myint + " rn");
Console.Write(System.DateTime.Now.ToString() + " " + System.DateTime.Now.Millisecond.ToString() + "rn ");
string myString2 = "1234"; for (int i = 0; i < 1000000; i++)
...
{
myint = Int32.Parse(myString2);
}
Console.Write(myint + "rn ");
Console.Write(System.DateTime.Now.ToString() + " " + System.DateTime.Now.Millisecond.ToString() + " ");
string myString3 = "1234";
for (int i = 0; i < 1000000; i++)
...
{
Int32.TryParse(myString3, out myint);
} Console.Write(myint + "rn ");
Console.Write(System.DateTime.Now.ToString() + " " + System.DateTime.Now.Millisecond.ToString() + "rn ");
(执行效果图略,所耗时间基本相差不远)
其实我们可以得出结论:
3个方法几乎没有差异!
如果真要追求完美那么性能的差异是:Int32.TryParse()优于Int32.Parse()优于Convert.ToInt32()。
所以个人建议:.NET1.1下用Int32.Parse();.NET2.0用Int32.TryParse()。
那么为什么会这样呢?
其实这些数据不是偶然的,因为:
Convert.ToInt32 会把最终的解析工作代理给 Int32.Parse;
Int32.Parse 会把最终的解析工作代理给Number.ParseInt32;
Int32.TryParse 会把最终的解析工作代理给Number.TryParseInt32。
至于其他进制的转换请参考MSDN。重载参数即可!
2.Split的3种用法
我们可以把12 33 456 12342 拼起来就是一个字符,因为很多时候我们觉得处理只有几个组的时候用数组很麻烦所以我们用“|”或者“,”等等把他们拼起来在需要的时候用Split打散即可。
下面列举一些用法,不做性能分析了。
方法一:
C# CODE
static void Main(string[] args)
...{
string aa = "1234,234523,4324,324";
string[] cc = aa.Split(new char[] ...{ ',' });
foreach (string bb in cc)
...
{
Console.Write(bb + "rn ");
} }
方法二:C# CODE
string aa = "1234,234523,4324,324";
string[] str = aa.Split(',');
foreach (string bb in str)
...{
Console.Write(bb + " rn");
}
方法三:C# CODE
static void Main(string[] args)
...
{
string a = "1,2,3,4,5,6,7,8,9";
string b = ",";
string[] c = Split(a, b);
foreach (string bb in c)
...
{
Console.Write(bb + " rn");
}
}
public static string[] Split(string input, string pattern)
...
{
string[] arr = System.Text.RegularExpressions.Regex.Split(input, pattern);
return arr;
}
实现把文章按空格打散:
C# CODE
public static void Main () ...{
string a="While laughter is is very aerobic activity engages every single organ system";
string b=" "; string []c=TestDoWhile.Split(a,b);
foreach(string bb in c) ...{
Console.Write(bb+" rn"); }
}
public static string[] Split(string input,string pattern)
...
{
string[] arr = System.Text.RegularExpressions.Regex.Split(input,pattern);
return arr;
}
(运行效果图略,将是一个单词一行行输出)
3.@"abc"和"abc"区别在那里
@"abc"和"abc"没有什么区别
不过@是忽略转义字符的!
比如 "abcn" 输出 abc 并加个换行
但是 @"abcn" 输出 abcn 无换行!
取消转义
比如你想将 C:windowssystem 这个字符串赋值给 str
一般情况下要:
string str = "C:windowssystem";
因为在C#中, 才会被转义成一个
又例如n就是换行符
而加入@,就可以这样:
string str = @"C:windowssystem";
4.保留2位有效小数及四舍五入
这又是一个经常遇到的问题。
保留2位有效小数(和保留N位一样的参数不同而已):
C# CODE
static void Main()
{
Double a = 12.345678;
Console.Write(Math.Round(a,2));
}
//(将输出 12.35)四舍五入:static void Main()
这次字符串是null,那么运行结果会怎样呢?
(程序将会异常!)
这是因为如果解析错误:
Convert.ToInt32()在null时不抛异常而是返回0;
Int32.Parse()要抛异常;
Int32.TryParse()不抛异常,会返回true或false来说明解析是否成功,如果解析错误,调用方将会得到0值。
由于Convert.ToInt32()在null时我们看不到Int32.TryParse()的运行结果所以再分调试和不调试来看结果的差异:
调试:
(将会看到 TryParse 返回 false。图略)
其实一般出bug毕竟属于少数,而且大家都会测试保证不出bug,那么我们最关心的或许就是性能。
再把代码修改一下:
C# CODE
string myString1 = "1234";
//string myString = null;
int myint = 0;
Console.Write(System.DateTime.Now.ToString()+" "+System.DateTime.Now.Millisecond.ToString() + " ");
for (int i = 0; i < 1000000;i++ )
...
{
myint = Convert.ToInt32(myString1);
}
Console.Write(myint + " rn");
Console.Write(System.DateTime.Now.ToString() + " " + System.DateTime.Now.Millisecond.ToString() + "rn ");
string myString2 = "1234"; for (int i = 0; i < 1000000; i++)
...
{
myint = Int32.Parse(myString2);
}
Console.Write(myint + "rn ");
Console.Write(System.DateTime.Now.ToString() + " " + System.DateTime.Now.Millisecond.ToString() + " ");
string myString3 = "1234";
for (int i = 0; i < 1000000; i++)
...
{
Int32.TryParse(myString3, out myint);
} Console.Write(myint + "rn ");
Console.Write(System.DateTime.Now.ToString() + " " + System.DateTime.Now.Millisecond.ToString() + "rn ");