这个问题在对集合进行删除操作时经常出现,常见代码如下:
foreach(Object obj in Collections)
{
//删除元素;
}
可以用下面的语句代替解决此问题:
fro(int i = Collections.Count; i>0; i--)
{
Object obj = Collection[i-1] as Object;
//删除元素;
}
。。。
posted @
2008-06-29 17:38 cn罗克 阅读(101) |
评论 (0) |
编辑
.Net自带的String.PadRight 方法按照MSDN的说明是:
左对齐此字符串中的字符,在右边用空格或指定的 Unicode 字符填充以达到指定的总长度。
实际使用中却发现问题:对于我们中文用户来说,双字节的汉字和单字节的字符同时处理是不可避免的,这时候此方法是不能实现其所谓的对齐效果的;
为此有了以下这个函数,经过这个函数的处理,不管字符串里面是否是中英混排的,都能正确地得到同样占位长度的字符串。
private string padRightEx(string str,int totalByteCount)
{
Encoding coding = Encoding.GetEncoding("gb2312");
int dcount = 0;
foreach (char ch in str.ToCharArray())
{
if (coding.GetByteCount(ch.ToString()) == 2)
dcount++;
}
string w = str.PadRight(totalByteCount - dcount);
return w;
}
此函数采用默认的补空格形式。同样可实现补齐任意需要的字符:
private string padRightEx(string str,int totalByteCount,char ch)
{
...
string w = str.PadRight(totalByteCount - dcount,ch);
...
}
String.PadLeft也可照此扩展。
例如:
Console.Write(padRightEx("中.", 12,'*')+"\r\n");
Console.Write(padRightEx("中文E", 12,'*') + "\r\n");
输出:
"中.*********";
"中文E*******";
posted @
2008-06-04 12:52 cn罗克 阅读(112) |
评论 (0) |
编辑
.net连接Oracle数据库时候出现此错误。
ORA-12154: TNS:无法解析指定的连接标识符
ORA-12154: TNS:could not resolve the connect identifier specified
错误号:ORA-12154
症状:
可执行程序为c#2.0编译完成,连接Oracle(经测试的有9i和10.2两个版本,目前可确认这两个版本)会报此错误。
鉴于这个异常的原因比较莫名,记下来,以兹效尤。
起初一直莫名其妙,前面程序一直运行的好好的怎么今天一早突然就出现这个问题了。并且tnsping正常,sqlplus连接一切正常,测试“本地.Net服务名配置”也能连通,Toad登录正常。
实在不明白,网上找,好像原因挺多的,依照着一个一个试,最后竟然是那个最莫名的原因:我的可执行程序路径前面有个文件夹名称内有'('和')'这两个符号。把我的可执行程序拷出去,运行,一切OK了,一切正常了。呜呼,大凶竟是此。莫名啊莫名。。。
在此记录下来,希望能对以后有碰到的朋友提供一种解决方案。也希望有其他解决办法的朋友指教。。。
posted @
2008-01-17 00:24 cn罗克 阅读(958) |
评论 (5) |
编辑
由于hexun的帐号被封,故启用此帐户。同时鄙视一下hexun的网管,就是那么一篇在新浪爱问、google随便一搜就有N多的文章,就要封我帐号?。。。。。。。
也好这个帐户只写技术。。
posted @
2007-11-17 17:19 cn罗克 阅读(15) |
评论 (0) |
编辑