草庐IT

stream-operators

全部标签

c# - System.Net.ProtocolViolationException : You must write ContentLength bytes to the request stream before calling [Begin]GetResponse

我得到了"System.Net.ProtocolViolationException:YoumustwriteContentLengthbytestotherequeststreambeforecalling[Begin]GetResponse"errorwhencallingtothe"BeginGetResponse"methodofthewebrequest.这是我的代码:try{StreamdataStream=null;WebRequestWebrequest;Webrequest=WebRequest.Create(this.EndPointAddress);Webrequ

c# - 需要重载 operator< 和 null 检查

我在C#中重载了lessthan运算符,我想知道这是否需要检查null。您可以在下面找到一个示例:publicstaticbooloperator或者这是正确的:publicstaticbooloperator我没有找到任何关于此的说明。但也许我错过了什么。 最佳答案 答案取决于您的预期使用模式。如果您计划混合使用空值,并且您希望null值小于非空值,那么您的实现是正确的;如果您想将null值视为大于非null对象,则注释掉的返回值(false和true)应该被使用。如果您不打算在混合中允许空值,则抛出ArgumentNullExc

c# - 如何使用 Stream 获取图像大小(宽 x 高)

我有这段代码用来读取上传的文件,但我需要获取图像的大小,但不确定我可以使用什么代码HttpFileCollectioncollection=_context.Request.Files;for(inti=0;i先生,我可以得到正确的文件,但是如何检查它的图像(宽度和大小)? 最佳答案 首先你必须写图像:System.Drawing.Imageimage=System.Drawing.Image.FromStream(newSystem.IO.MemoryStream(byteArrayHere));然后你有:image.Height

c# - .NET 4.5 中的代码契约 + 异步 : "The method or operation is not implemented"

在Windows7x64上的VS2012中使用CodeContracts1.4.51019.0时,我从ccrewrite收到以下编译错误:“方法或操作未实现."这似乎是由属性访问器的组合和使用缺少内部await的async方法引起的。复制步骤:创建一个启用“完整”运行时契约检查的新类库:namespaceCodeContractsAsyncBug{usingSystem.Threading.Tasks;publicclassService{//Offendingmethod!publicasyncTaskProcessAsync(Entityentity){varflag=entity

c# - is-operator 的最佳用法是什么

is运算符的好的用法是什么?下面的转换构造不是推荐的方法,几乎​​所有文档都更喜欢带有null检查的as-operator。if(objisSomeClass){SomeClasssome=(SomeClass)obj;....}当然这是一个(非常小的)性能提升,有些甚至提到了胎面安全性。是的,这是真的......那么,为什么我们要有is运算符?“带有空检查的运算符(operator)”在哪里不起作用或不是可行的方法?使用is运算符限制声明的范围是否有优势? 最佳答案 as不适用于不可为null的struct:objecto=123

c# - 字符串比较 : operator==() vs. Equals()

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:C#:Arestring.Equals()and==operatorreallysame?对于字符串比较,哪种方法更好(且安全):strings1="Sarfaraz";strings2="Nawaz";boolresult1=(s1==s2);//approach1boolresult2=s1.Equals(s2);//approach2或者两者在底层是一样的?

c# - F# 屈服! operator - 实现和可能的 C# 等价物

我目前正在学习F#,我非常喜欢yield!(yield-bang)运算符。不仅因为它的名字,当然也因为它的作用。yield!运算符基本上允许您从序列表达式中产生序列的所有元素。这对于组合枚举器很有用。因为我经常遇到大而复杂的枚举器,所以我对我们可以用来将它们分解并由更简单的枚举器组合起来的策略很感兴趣。不幸的是,yield!运算符在C#中不可用。据我所知,它的作用类似于foreach(varxinsource)yieldx;但我正在阅读的书(Petricek'sRealWorldF#-Manning)表明它具有更好的性能......那么F#编译器在这里究竟做了什么?(是的,我也可以使用

c# - 调用 Stream.Write 和使用 StreamWriter 有什么区别?

实例化一个Stream对象,比如MemoryStream和调用memoryStream.Write()方法来写入有什么区别流,并使用流实例化一个StreamWriter对象并调用streamWriter.Write()?考虑以下场景:你有一个方法接受一个Stream,写入一个值,然后返回它。稍后会读取流,因此必须重置位置。有两种可能的方法(似乎都有效)。//InstantiateaMemoryStreamsomewhere//-PassedtothefollowingtwomethodsMemoryStreammemoryStream=newMemoryStream();//Notus

c# - EF 4.1 和 "Collection was modified; enumeration operation may not execute."异常

在过去的2天里,这让我抓狂。我有3个非常基本的类(好吧,为了便于阅读而减少了)publicclassEmployee{publicstringName{set;get;}virtualpublicEmployerEmployer{set;get;}publicEmployee(stringname){this.Name=name;}},//thisbasicallytiesEmployeeandhisroleinacompany.publicclassEmployeeRole{publicintId{set;get;}virtualpublicEmployeeEmployee{set;

c# - 从 wcf 绑定(bind) transferMode 从 "Buffered"更改为 "Streamed"是否被视为客户端的重大更改?

我有一个WCF服务端点,它通过流提供二进制文档。端点看起来像这样:publicStreamGetFile(intfileId){...}此服务端点的basicHttpBinding被错误地配置为使用TransferMode="Buffered"。服务端点当前由我无法控制的集成方使用。由于缓冲传输模式的内存消耗问题,我想将其更改为TransferMode="Streamed"。我能否安全地对服务绑定(bind)配置进行此更改,并期望这不会对任何集成方造成任何影响? 最佳答案 据我所知,WCF流模式传输是在客户端选择加入的,这意味着即使