龙亿

------ 细细口味人生中的每一杯苦咖啡.

导航

字符串操作 (--转载,觉得蛮好,收藏下)

Posted on 2008-11-18 00:20  龙亿  阅读(330)  评论(0编辑  收藏  举报

一、StringBuilder 类的部分属性与方法:

StringBuilder 类

String类的不可改变性使它更像一个值类型而不是一个引用类型。其副作用是每次执行字符操作时,都会创建一个新的String对象。StringBuilder 类解决了对字符串进行重复修改的过程中创建大量对象的问题。

StringBuilder类并没有String 类的功能强大,只提供基本的替换和添加和删除字符串中的文本,但它的工作效率非常高,当定义StringBuilder对象时可以指定内存的内存容量,如果不指定系统就会根据对象初始化时的字符串长度来确定。它有两个主要参数Length和Capacity分别表示字符串的实际长度和字符串占据的内存空间长度。对字符串的修改就是在这个内存中进行的,大大提高了添加和替换的的效率

StringBuilder 类的部分属性与方法
Length 属性

注意:它并不是只读的
StringBuilder sb=new StringBuilder("I love c#");
Console.WriteLine(sb.ToString( )); 
sb.Length = 6;
Console.WriteLine(sb.ToString( )); //输出 "I love"

Capacity 属性
描述:当前为实例分配的字符数量。默认容量是16,如果将一个字符串作为参数提供给构造函数,容量以最接近 2 的幂的值。

MaxCapacity 属性
描述:这个实例中可以被分配的字符最大数量。

Append(  ) 方法
描述:追加给定值的字符串表示。
StringBuilder sb=new StringBuilder( );
Console.WriteLine( sb.Capacity+"\t"+sb.Length ); //输出16      0
sb.Append ( 'a' , 17 )
Console.WriteLine( sb.Capacity+"\t"+sb.Length );//输出32      17

AppendFormat()

描述:添加特定格式的字符串

EnsureCapacity( Int capacity )  方法
描述:如果当前容量小于指定容量,内存分配会增加内存空间以达到指定容量。

Insert()

描述:插入一个子字符串

Remove()

描述:从当前字符串删除字符

Replace( Char oldchar,Char newchar )  方法
描述:用newchar替换oldchar。

Replace( String oldstring,String newstring ) 方法
描述:用newstring替换oldstring。

Replace( Char oldchar,Char newchar,Int  startpos,Int count ) 方法
描述:从startpos到count-1之间用newchar替换oldchar。

Replace( String oldstring,String newstring,Int startpos,Int count ) 方法
描述:从startpos到count-1之间用newstring替换oldstring。

ToString( ) 方法
StringBuilder sb=new StringBuilder( "I live this game" );
String s1=sb.ToString( );         // "I live this game"
String s2=sb.ToString(3,4);     //Displays "live"
在这里第二个ToString( )方法调用了String类的Substring( )方法
public String ToString( int startIndex,int length )
{
  return m_StringValue.Substring( startIndex,length );
}

 

二、String 类的部分属性及方法

字符访问

String s ="ABCD";

Console.WriteLine(s[0]); //输出 "A"

Console.WriteLine(s.length); //输出 4

打散

String s ="ABCD";

Char[] arr =s.ToCharArray();//打散成字符数组

Console.WriteLine(Arr[0]);//输出"A"

截取

String s ="ABCD";

Console.WriteLine(s.substring(1));//从第二位一直截取到最后,输出"BCD"

Console.WriteLine(s.substring(2,2));//从第三位开始截取两位,输出"BC"

字符匹配

String s ="ABCD";

Console.WriteLine(s.IndexOf('A')); //从头开始搜索第一个A,输出"0"

大小写转换

String s ="AbCd";

Console.WriteLine(s.ToLower());//转化为小写,输出abcd

Console.WriteLine(s.ToUpper());//转化为大写,输出 ABCD

对齐

String s ="ABCD";

Console.WriteLine(s.Padleft(6,'_'));//使用'_'填充字符串左部,使它扩充到6为长度 输出''__ABCD"  

Console.WriteLine(s.PadRight(6,'_')) //使用'_'填充字符串右部,使它扩充到6为长度 输出'' ABCD__";

匹配移除

String s ="_A_B_C_D_"; s.Trim('_'));//去掉前后的'_' 输出为"A_B_C_D"  s.TrimStart('_'));//去掉前面的'_' 输出为" A_B_C_D_"

Console.WriteLine(

Console.WriteLine(

Console.WriteLine(s.TrimEnd('_')); //去掉后面的'_' 输出为" _ A_B_C_D"

插入和删除

String s ="ADEF";

Console.WriteLine(s.Insert(1,"BC"));//从第二位插入字符串BC 输出 "ABCDEF"

Console.WriteLine(s.Remove(1));//将第2位后面的删除 输出"A"

Console.WriteLine(s.Remove(0,2));//将前两位删除 输出"EF"

替换

String s="A_B_C_D";

Console.WriteLine(s.Replace('_',','));//将字符串中的"_"替换为"," 输出 "A,B,C,D"

分割

String s=" A,B,C,D";

String[] arr=s.Split(',');

 

三、经验总结

 

1.Convert.ToInt32Int32.Parse的恩恩怨怨

2个方法都可以把把string解析为int,那么我们一定会有疑问:到底他们有什么区别?什么时候该用什么?性能如何等等。

其实在2.0里还有Int32.TryParse也实现了同样的效果。

Code

 

表面上看,可见3个方法都实现了同样的效果!

那么我们把代码改一下:

Code

 

这次字符串是null,那么运行结果会怎样呢?

这是因为如果解析错误:

Convert.ToInt32()null时不抛异常而是返回0

Int32.Parse()要抛异常;

Int32.TryParse()不抛异常,会返回truefalse来说明解析是否成功,如果解析错误,调用方将会得到0值。

由于Convert.ToInt32()null时我们看不到Int32.TryParse()的运行结果所以再分调试和不调试来看结果的差异:

调试:

不调试:

 

其实一般出bug毕竟属于少数,而且大家都会测试保证不出bug,那么我们最关心的或许就是性能。

再把代码修改一下

2

 

 

Code

 

我们让3个方法执行100万次转换看毫秒的差异:

为了准确多做几次测试:

第二次

 

第三次

 

  

第一次

第二次

第三次

Convert.ToInt32() 

532-204=328 

1163-750=413 

782-469=313 

Int32.Parse() 

844-532=312 

360-63=297 

1094-782=312 

Int32.TryParse() 

1141-844=297 

657-360=297 

375-94=281 

其实我们可以得出结论:

3个方法几乎没有差异!

如果真要追求完美那么性能的差异是:Int32.TryParse()优于Int32.Parse()优于Convert.ToInt32()

所以个人建议:.NET1.1下用Int32.Parse().NET2.0Int32.TryParse()

那么为什么会这样呢?

其实这些数据不是偶然的,因为:

Convert.ToInt32 会把最终的解析工作代理给 Int32.Parse

Int32.Parse 会把最终的解析工作代理给Number.ParseInt32

Int32.TryParse 会把最终的解析工作代理给Number.TryParseInt32

至于其他进制的转换请参考MSDN。重载参数即可!

2.Split3种用法

我们可以把12     33   456    12342  拼起来就是一个字符,因为很多时候我们觉得处理只有几个组的时候用数组很麻烦所以我们用"|"或者""等等把他们拼起来在需要的时候用Split打散即可。

下面列举一些用法,不做性能分析了

方法一:

Code

方法二:

Code

方法三:

 实现把文章按空格打散:

Code

 

 

 

Code

 

 

3.@"abc""abc"区别在那里

@"abc""abc"没有什么区别

不过@是忽略转义字符的!

比如 "abc\n" 输出 abc 并加个换行

但是 @"abc\n" 输出 abc\n 无换行!

取消转义

比如你想将 C:\windows\system 这个字符串赋值给 str

一般情况下要:

string str = "C:\\windows\\system";

因为在C#中,\\ 才会被转义成一个 \

又例如\n就是换行符

而加入@,就可以这样:

string str = @"C:\windows\system";

4.保留2位有效小数及
这又是一个经常遇到的问题。

保留2位有效小数(和保留N位一样的参数不同而已):

static void Main()

{

Double a = 12.345678;

Console.Write(Math.Round(a,2));

}

四舍五入:

static void Main()

{

 

Double a = 12.345678;//是要四舍五入的数

Console.Write((a*10000+0.5)/10000);

}

 

5.url传递中文的解决方案
1.
设置
web.config文件。

<system.web>

......

<globalization requestEncoding="gb2312" responseEncoding="gb2312" culture="zh-CN" fileEncoding="gb2312" />

......

</system.web>

2.传递中文之前,将要传递的中文参数进行编码,在接收时再进行解码。

>> 进行传递

string Name = "中文参数";

Response.Redirect("B.aspx?Name="+Server.UrlEncode(Name));

>> 进行接收

string Name = Request.QueryString["Name"]; Response.Write(Server.UrlDecode(Name));

3.如果是从 .HTML 文件向 .Aspx 文件进行传递中文参数的话(即不从后台用 Redirect()方法进行 Url 转换)。一样要将传递的中文参数进行编码,在接收时再进行解码。

>> 进行传递

<script language="JavaScript">

function GoUrl()

{

var Name = "中文参数";

location.href = "B.aspx?Name="+escape(Name);

}

</script>

<body onclick="GoUrl()">

>> 进行接收
string Name = Request.QueryString["Name"]; Response.Write(Server.UrlDecode(Name));

一般来说。设置web.config文件就可以了。但是如果你用 JavaScript 调用 webservice 方法的话(往webservice里面传递中文参数)。设置 web.config 文件好象无效。 //清清月儿http://blog.csdn.net/21aspnet/

6.123456789转换为12-345-67893种方法

方法一: 

string a = "123456789";

a = int.Parse(a).ToString("##-###-####");

Console.Write(a);

方法二:

string a = "123456789";

a = a.Insert(5, "-").Insert(2, "-");

Console.Write(a);

方法三:

 

Code

7.交换两个指定位置字符的4种方法

方法一:

Code

 

方法二:

 

Code

 

 

方法三:

 

Code

  

方法四:

 的妙用

 

Code

 

8. 输出21AAAAAAAAAAAAAAAAAAAAA的巧妙做法

Code

 

9.new构造器的理解

如果要你创建一个由21"A"字符构成的字符串,你会怎么做?

string str = "AAAAAAAAAAAAAAAAAAAAA";//老实型

string str = new string('A', 21);//简单聪明