昨天写代码,不经意就把引用类型和值类型比较的不同忘记了,有必要记下来提醒自己,以免以后犯一样的错误. 先贴上自己写的错误代码 Object entryId ="entryid"; var result =sourceDynamicObject.where (o=>o.GetDynamicObjectItemValue<Object>("ParentEntryId")==entryId); 这个错误很明显,引用类型的比较使用==,明显reslut获不到值。
C#有以下一些引用类型: 数组(派生于System.Array) 用户用定义的以下类型: 类:class(派生于System.Object); 接口:interface(接口不是一个“东西”,所以不存在派生于何处的问题。Anders在《C# Programming Language》中说,接口只是表示一种约定[contract]); 委托:delegate(派生于System.Delegate)。 object(System.Object的别名); 字符串:string(System.String的别名)。 可以看出: 引用类型与值类型相同的是,结构体也可以实现接口; 引用类型可以派生出新的类型,而值类型不能; 引用类型可以包含null值,值类型不能(可空类型功能允许将 null 赋给值类型); 引用类型变量的赋值只复制对对象的引用,而不复制对象本身。而将一个值类型变量赋给另一个值类型变量时,将复制包含的值。 对于最后一条,经常混淆的是string。我曾经在一本书的一个早期版本上看到String变量比string变量效率高;我还经常听说String是引用类型,string是值类型,等等。例如: string s1 = "Hello, "; string s2 = "world!"; string s3 = s1 + s2;//s3 is "Hello, world!" 这确实看起来像一个值类型的赋值。再如: string s1 = "a"; string s2 = s1; s1 = "b";//s2 is still "a" 改变s1的值对s2没有影响。这更使string看起来像值类型。实际上,这是运算符重载的结果,当s1被改变时,.NET在托管堆上为s1重新分配了内存。这样的目的,是为了将做为引用类型的string实现为通常语义下的字符串。
通过上面的介绍,下面的结果就很明显
string s1= "abc";
string s2="abc";
String s3 = new String("abc");
String s4 =new String("abc");
s1==s2 true
s3==s4 false
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。