1 / 3
文档名称:

关于C字符串截取的研究.doc

格式:doc   大小:20KB   页数:3页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

关于C字符串截取的研究.doc

上传人:q1188830 2019/11/13 文件大小:20 KB

下载得到文件列表

关于C字符串截取的研究.doc

相关文档

文档介绍

文档介绍:关于C#字符串截取的研究对于网站程序员,一定会碰到字符串长度截取这个常用功能,一般如果用SubString即可解决。但是当遇到中英文混合,或者单字节双字节的混合时,此方法总感觉有点不如意。例如:abcdefghijkl字符串。当截取7个字符时。则为:abcdefg当存在abc啊哦哦defg字符串,再截取7个字符时。则为:abc啊哦哦d从以上我们显然可以看到。两个字符串的长度虽然都为7。但是第二个字符的长度明显要比第一长。这个是为什么呢?因为第一个截取的字符串,按字节数来算长度是7。而第二字符串的字节数其实是10。这样我们在网页设计时就会遇到页面变形。在设计网站时一般我们对于一个框架,其宽度一般都是固定。而当所截取的字符串超过指定长度时,就容易把原先的框架撑开,或者换行。这样的结果不是我们预先想要设计的。那么我们应该如何来操作呢,答案其实已经公布了。那就是按照字符串的字节数来截取我们所需要的长度。问题找到了,我们来进一步分析具体需要的操作。此处提供2个方法:方法一:每次截取一个字符,然后进行判断截取的总的字符串的长度是否满足需要截取的字节数。该方法的特点就是程序代码简单方便,但是效率不是很高。比如要执行一个10000字节截取的操作,最好的结果就是循环检测5000次。当然最坏的结果就得循环检查10000次,这样的操作或许在实际应用中不太常见,但此方法本人觉得应该有改进之处。于是产生第二个操作方法。方法二:当字符串全部为单字节字符时,则可以用SubString方法截取指定长度即可。当字符串全部为双字节字符时,则只需要用SubString方法截取指定长度的一半当字符串为单字节双字节混合时,则我们可以用折中这样的方法来处理。例如我们有一个长度为350字节的字符串。而我们需要截取100个字节,则我们进行如下操作:先用SubString方式取得100/2个字符。然后获取这50个字符的字节数。当50个字符=100个字节时,则直接返回结果。如果还不到100个字节,则继续用SubString方法截取(100-(50个字符的字节数))/2的字符。如此循环直到剩下的字节数为1或者0的时候,则停止。当剩余一个字节时,再进行判断下一个字符是否是单字节字符,如果是单字节,则把这个字符一起做为结果返回。如果双字节字符,则将下一个字符放弃,直接返回已经截取的字符串的长度。用此方法为指数形式截取,一般截取长字符串时只需进行几步操作即可。比如截取10000个字符,则进行最多12+1次操作即可附操作代码///<summary>///是否中文///</summary>///<paramname="chars"></param>///<paramname="RegType">true:包含中文;false:全部为中文</param>///<returns></returns>publicstaticboolIsChinese(stringchars,boolRegType){if(RegType){(chars,@"^([\u4e00-\u9fa5]|[\uff01-\uff60]|\u3000){1,}$");}(chars,@"([\u4e00-\u9fa5]|[\uff01-\uff60]|\u3000){1,}