草庐IT

char_set

全部标签

c# - 如何在不复制的情况下从 char 数组创建字符串?

我有一个非常大的字符数组,我需要将其转换为字符串以便在其上使用正则表达式。但它太大了,当我将它传递给字符串构造函数时,我得到了OutOfMemoryException。我知道字符串是不可变的,因此不应该可以指定它的底层字符集合,但我需要一种无需复制就可以使用正则表达式的方法整个事情。我如何获得该数组?我使用StreamReader从文件中获取它。我知道要读取的内容的起始位置和长度,Read和ReadBlock方法需要我提供一个char[]缓冲区。所以这里是我想知道的事情:有没有办法指定字符串的底层集合?(它甚至将其字符保存在数组中吗?)...或直接在字符数组上使用正则表达式?...或者

c# - 如何将 char 转换为其完整的 Unicode 名称?

这个问题在这里已经有了答案:FindingoutUnicodecharacternamein.Net(6个答案)关闭9年前。我需要在字符(例如'α')和它的完整Unicode名称(例如"GREEKSMALLLETTERALPHA")之间进行双向转换的函数。我想出的解决方案是在在线提供的官方Unicode标准中执行查找:http://www.unicode.org/Public/6.2.0/ucd/UnicodeData.txt,或者更确切地说,在其缓存的本地副本中,可能事先转换为合适的集合以提高查找性能)。是否有更简单的方法来进行这些转换?我更喜欢C#中的解决方案,但也欢迎可以适应C#

c# - SOAP 错误 : "Server was unable to process request" "Object reference not set to an instance of an object"

当我向本地IIS中的服务发送SOAP请求时,一切正常。当我向在另一台主机上的IIS上运行的同一服务发送SOAP请求时,一切正常。但是当另一个程序员向我的服务发送SOAP请求时,他通常会得到正确的响应,除了返回服务中的一个方法:soap:ServerServerwasunabletoprocessrequest.--->Objectreferencenotsettoaninstanceofanobject.我需要了解他收到此错误的原因。他的SOAP请求与SOAP请求完全相同,但我的有效,而他的无效。 最佳答案 如果您不确切知道错

c# - 为什么在这种情况下我会打印出 System.char[]?

我想弄清楚我在这里做错了什么,但我似乎做不到。我有这种方法,它接受一个字符串并将其反转。但是,当我从调用方方法中打印出反转的字符串时,我只得到“System.Char[]”而不是实际的反转字符串。staticstringreverseString(stringtoReverse){char[]reversedString=toReverse.ToCharArray();Array.Reverse(reversedString);returnreversedString.ToString();} 最佳答案 在.NET中对T数组调用To

c# - 在 EventHandler 中尝试 Set() 时,如何检查 ManualResetEvent 是否已被处置?

我有以下设计模式:varmyObjectWithEvents=newObjectWithEvents();using(varmre=newManualResetEvent(false)){varonEvent=newEventHandler((sender,e)=>{mre.Set();});try{myObjectWithEvents.OnEvent+=onEvent;vartask=Task.Factory.StartNew(()=>{myObjectWithEvents.DoSomethingThatShouldRaiseAnEvent();});vartimedOut=!mre

c# - 为什么我需要使用 get 和 set?

我有一段代码:publicclassMyClass{privatestring_myProperty;publicstringMyProperty{get{return_myProperty;}set{_myProperty=value;}}}这里有什么意义?我可以将_myProperty字符串声明为公共(public)字符串,我的任何类对象都可以直接访问它们并获取或设置值。相反,我们将_myProperty设为私有(private),并使用类对象使用get和set来访问它们。在任何一种情况下,类对象都能够访问它们并且结果总是相同的。那么为什么要使用这种方法呢?这仅仅是因为我可以在se

c# - EF 查询 Oracle 抛出 "ORA-12704: character set mismatch"

我试图在Oracle的EF中组合几列,然后像这样对这些列执行.Contains():publicIEnumerableSearchUsers(stringsearch){search=search.ToLower();return_securityUow.Users.Where(u=>(u.FirstName.ToLower()+""+u.LastName.ToLower()+"("+u.NetId.ToLower()+")").Contains(search)).OrderBy(u=>u.LastName).ThenBy(u=>u.FirstName).AsEnumerable();

c# - 将 sbyte[] 转换为 bool[] 并将 char[] 转换为 short[]

有没有显式转换/强制转换sbyte[]或byte[]到bool[]char[]到short[]/ushort[]在CIL中,您经常会看到诸如stelemTypesbyte(ldlocpArray)ldc_i41ldc_i40正在执行pArray[1]=true,其中pArray是bool[]类型的一维数组。我想通过做在c#中复制它(sbyte[])pArray[1]=1;不幸的是,C#编译器不允许这样做。 最佳答案 未记录的技巧,风险自负:(例如here以及许多其他地方)[StructLayout(LayoutKind.Explic

c# - Char.IsDigit() vs Char.IsNumber(),有什么区别?

Char.IsDigit()和Char.IsNumber()有什么区别 最佳答案 //1/2symbolChar.IsNumber('½');//trueChar.IsDigit('½');//false//UnicodecharacterforRomannumeral5(V)Char.IsNumber('\x2165');//trueChar.IsDigit('\x2165');//false 关于c#-Char.IsDigit()vsChar.IsNumber(),有什么区别?,我们

c# - "Cannot insert explicit value for identity column in table when IDENTITY_INSERT is set to OFF"带复合键

我们最近向我们的数据库添加了一个新的“级别”——在整个数据库中的表中现有ID身份字段的上方/之前添加了一个键“Company_ID”。例如,如果一个表有ID然后是字段,它现在有Company_ID,然后是ID,然后是字段。这个想法是,这允许ID为提供给功能的每个不同的Company_ID值自动递增(Company_ID1可以有ID1、2、3等;Company_ID2可以有ID1、2、3等)。自增字段保持为ID。一个示例表是:[dbo].[Project]([Company_ID][int]NOTNULL,[ID][int]IDENTITY(1,1)NOTNULL,[DescShort]