草庐IT

UNICODE_STRING

全部标签

c - 为 Windows 库添加 unicode 支持

我想为我正在维护的C库添加Unicode支持。目前它希望所有字符串都以utf8编码传递。根据反馈,Windows通常提供3个功能版本。fooA()ANSI编码字符串fooW()Unicode编码字符串foo()字符串编码取决于UNICODE定义有没有一种无需自己编写大量包装函数即可添加此支持的简单方法?一些函数可以从库中调用,也可以由用户调用,这使情况变得有点复杂。我想保留对utf8字符串的支持,因为该库可在多个操作系统上使用。 最佳答案 没有后缀的foo函数实际上是宏。fooA函数已过时,是fooW函数的简单包装器,它们是唯一实际

c# - string.Equals ("string") 和 "String".Equals(string) 有什么区别?

下面两行比较字符串值的代码有什么区别吗stringstr="abc";if(str.Equals("abc"))和if("abc".Equals(str))在第一行中,我在字符串变量上调用equals方法,将其与字符串文字进行比较。第二行反之。仅仅是编码风格的不同,还是编译器处理这两个语句的方式不同。 最佳答案 唯一的区别是,在第一种情况下,当您执行以下操作时:str.Equals("abc")如果str为null,您将在运行时得到一个异常。通过这样做:"abc".Equals(str)如果str为null,您将得到false。

c# - 将 Unicode 数据从 xml 字符串插入到 Datatable

我想使用以下代码将unicode数据从xml字符串保存到数据库中:XmlDocumentxmlDoc=newXmlDocument();xmlDoc.LoadXml(xmlText);using(XmlNodeReaderxmlReader=newXmlNodeReader(xmlDoc)){DataTabledt=newDataTable();dt.TableName="sms";dt.Columns.Add("rowID");dt.Columns.Add("origAddr");dt.Columns.Add("time");dt.Columns.Add("message");dt.

c# - INotifyDataErrorInfo.GetErrors 何时调用 null 与 String.empty?

在msdnpageforInotifyDataErrorInfo.GetErrors它说调用GetErrors方法的参数可以是:我们要为其检索错误信息的属性的名称无String.Empty文档没有说明何时使用null与String.Empty调用此方法。我在我的应用程序中看到了这两种情况,我需要了解何时可以预期其中一种情况。澄清:我不是在问我应该如何实现GetErrors方法(我只是测试null和empty)。问题更多的是理解为什么WPF框架尝试有时使用null有时使用空字符串调用此方法(我在我的应用程序中遇到了这两种情况)。如果目的是询问与特定属性无关的错误,为什么在调用时使用两个不

c# - 是否有带谓词的 String.IndexOf?

我需要能够说类似myString.IndexOf(c=>!Char.IsDigit(c))的东西,但我在.NET框架中找不到任何这样的方法。我错过了什么吗?以下是有效的,但我自己的滚动在这里似乎有点乏味:usingSystem;classProgram{staticvoidMain(){stringtext="555ttt555";intnonDigitIndex=text.IndexOf(c=>!Char.IsDigit(c));Console.WriteLine(nonDigitIndex);}}staticclassStringExtensions{publicstaticint

c# - `ReadAsAsync<string>` 和 `ReadAsStringAsync` 应该用来做什么?

应该做什么HttpContentExtensions.ReadAsAsync和HttpContent.ReadAsStringAsync用来做什么?他们似乎在做类似的事情,但工作方式却很奇怪。下面是几个测试及其输出。在某些情况下JsonReaderException被抛出,在某些情况下,输出JSON但带有额外的转义字符。我最终在我的代码库中同时使用了这两个函数,但如果我能理解它们应该如何工作,我希望能在其中一个上保持一致。//CreatedataandserialisetoJSONvardata=new{message="helloworld"};stringdataAsJson=Js

c# - 将 C# 中的 String^ 转换为 C++/CLI 中的 CString

我在用MFC编写我的应用程序时遇到了一个问题,需要帮助。我在我的应用程序中使用CLR即CommonLanguageRuntime来集成c#API。但现在我坚持将System::String^转换为CString。我做不到。我正在使用以下代码。String^csPass=gcnewString(strPassword.GetBuffer());array^Value=Encoding::UTF8->GetBytes(csPass);for(inti=0;iLength;i++){csPass+=String::Format("{0:X2}",Value[i]);}现在我想将csPass转

c# - 如何实现 StringBuilder 和/或调用 String.FastAllocateString?

我很想知道我是否可以创建一个优化版本的StringBuilder(尝试稍微加快它的速度,因为它目前是我的一个应用程序的瓶颈)。对我来说不幸的是,它似乎利用了我无法使用(或者看起来如此)的“神奇”系统调用。反编译System.Text.StringBuilder的源代码后,我注意到它使用了以下内部(因此无法调用)系统调用:[SecurityCritical][MethodImpl(MethodImplOptions.InternalCall)]internalstaticstringFastAllocateString(intlength);还有这个未记录的属性被大量使用:[ForceT

c# - 为什么用于 Unicode 属性测试的 C# System.Char 方法有两个重载?

在methodsofSystem.Char,我们看到两种检查字符是否为符号的方法:publicstaticboolIsSymbol(strings,intindex)publicstaticboolIsSymbol(charc)同样适用于其他属性测试:IsLower、IsLetter等为什么会出现这种重复?有什么理由比Char.IsSymbol(s[idx])更喜欢Char.IsSymbol(s,idx)吗? 最佳答案 从表面上看,这两个重载在功能上似乎是相同的,但是深入到对InternalGetUnicodeCategory的调用

c# - String.comparison 性能(带修剪)

我需要做很多高性能的不区分大小写的字符串比较,并意识到我这样做的方式.ToLower().Trim()真的很愚蠢,因为所有的新字符串都被分配了所以我仔细研究了一下,这种方式似乎更可取:String.Compare(txt1,txt2,StringComparison.OrdinalIgnoreCase)这里唯一的问题是我想忽略前导或尾随空格,即Trim()但如果我使用Trim,我会遇到与字符串分配相同的问题。我想我可以检查每个字符串,看看它是StartsWith("")还是EndsWith(""),然后才修剪。或者找出每个字符串的索引、长度并传递给string.Compareoverr