怎么识别是一中文汉字还是两个字符呢?

gggjjj 2006-11-01 08:42:17
一个中文汉字在C中占两个字节,一个西文字符占一个字节,那么怎么识别16位的一个串是代表一个中文字符呢还是两个西文字符呢?
...全文
234 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
sanniko 2006-11-01
  • 打赏
  • 举报
回复
[DllImport("kernel32")]
private static extern int lstrlenA(string lpString);
zzPandazz 2006-11-01
  • 打赏
  • 举报
回复
现在英文也是两个了
jxhwei 2006-11-01
  • 打赏
  • 举报
回复
Unicode的特点是:
不管哪一国的字符码均以两个Byte表示,例如"A"在Unicode则是16进制41和00的组合,即4100,高位41(转换为Ascii码即是65=A)

如果用的是Ascii码,自然不存在这个问题,如果是Unicode码,那么,如果后2位是00的,就是英文字符
gggjjj 2006-11-01
  • 打赏
  • 举报
回复
最后一句有些看不懂啊。
Knight94 2006-11-01
  • 打赏
  • 举报
回复
通过Encoding来判断,例如:
private int GetChsCharLength( string strValue )
{
if( strValue == null || strValue == "" ) return 0;

Encoding encGB = Encoding.GetEncoding( "gb2312" );
Encoding encUnicode = Encoding.Unicode;

return strValue.Length - ( encUnicode.GetByteCount( strValue ) - encGB.GetByteCount( strValue ) );
}

private int GetAniCharLength( string strValue )
{
if( strValue == null || strValue == "" ) return 0;

Encoding encGB = Encoding.GetEncoding( "gb2312" );
Encoding encUnicode = Encoding.Unicode;

return encUnicode.GetByteCount( strValue ) - encGB.GetByteCount( strValue );
}
内容概要:本文围绕基于改进秃鹰搜索算法(Improved Bald Eagle Search Algorithm, IBES)的微电网群经济优化调度模型展开研究,旨在通过智能优化算法提升多微电网系统在复杂运行环境下的经济性与调度效率。研究综合考虑分布式电源、储能系统及负荷的动态特性,构建以最小化综合运行成本为目标的优化模型,并引入IBES算法进行高效求解。该算法通过增强全局搜索能力与收敛精度,有效应对高维度、非线性及多约束的调度难题,实现了对各单元出力、储能充放电策略及外部电网交互功率的协同优化。结合Matlab仿真实验,验证了该方法在降低系统运行成本、提高可再生能源消纳率方面的优越性能,具有较强的工程应用价值。; 适合人群:具备电力系统基础理论与优化算法知识,从事新能源、微电网、智能调度及相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于多微电网系统或区域综合能源系统的经济调度优化;②为智能优化算法在电力系统中的实际部署提供可复现的技术范例;③辅助科研人员快速实现顶刊级算法模型,提升科研效率与创新水平。; 阅读建议:建议结合提供的Matlab代码深入理解算法实现细节,重点关注目标函数建模、约束条件处理及参数敏感性分析,同时可与其他主流智能算法(如PSO、GA、GWO)进行性能对比,进一步开展算法改进或拓展至不确定性优化、多目标调度等研究方向。

111,131

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Creator Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧