Easy mistakes in c#
ACCESS MODIFIERS
c# has some access modifiers as below:
public:class or member can be accessed by no restrictions
private:members can only be accessed within the class itself
internal:class or member can only be accessed within the assembly,not others.
protected:members can only be accessed by derived class(or within the class of course), not others non-derived class.
protected internal: members can only be accessed by derived class, OR, in the same assembly.
NOTE:
- not all access modifiers can be used on class,that's why there's underline on "class or member" and "members". it's nonsense to use private,protected,protected internal on a class. This may make mistake easily.
- no access modifier allowed on namespace,but public is implicitly.
- internal is default to a class
- no access modifier allowed on a interface but public is implicitly.
- private is default to members.
Modifiers and Static
Can not use override,virtual or abstract on a static member, cause these are for instance of inheriting
Size of basic types
type | size(bits) | Range |
char | 16(2 bytes of unicode) | |
byte(unsigned-byte) | 8 | 0 ~ 255 |
sbyte(signed-byte) | 8 | -128 ~ 127 |
short | 16 | –32,768 ~ 32,767 |
ushort | 16 | 0 ~ 65,535 |
int | 32 | –2,147,483,648 ~ 2,147,483,647 |
uint | 32 | 0 ~ 4294967295 |
long | 64 | –9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807 |
ulong | 64 | 0 ~ 18,446,744,073,709,551,615 |
decimal | 128 |
dynamic
for most time, dynamic is just the same as object,(xx is dynamic) equals to (xx is object) so:
int a=1;
(a is dynamic) is true
but (null is object) is false, so:
string a=null;
(a is dynamic) is false,of course
dynamic i=1;
(i is object) is true
params
No additional prameters are permitted after "params" prameters, and only one params keyword is allowed in a method argument declaration.
A "params" parameter has to be an array.
bitwise
&: computes the logical bitwise AND
|: computes the logical bitwise OR
^:if and only if one operand is true then true,or maybe i can say, if the operands is not the same then true otherwise false.
7^2=>111^010=>101=>5
class and struct
- class is a reference type that stored in heap,and struct is value type that stored in stack. Struct often used to present light weight object which only contains data.
- struct can have constructor which have parameter(s), default constructor(paramterless) is not allowed.
- struct can have const,field,property,method,index,operator,event,but if you need these members,then a class may be better.
- struct can implement interfaces,but can not inherit from a class,so members of struct can not be protected.
- you can declare a struct object without "new" keyword:
MyStruct myStruct;
myStruct.Pro1="value"; - only class can have deconstructor
boxing & unboxing
boxing means value type data in stack "be boxed" to manage heap
unboxing mean reference type data in manage heap "be unboxed" to stack.
but why we call that "boxing" and "unboxing"? i think just because managed heap is a place where will be cleaned(by GC),so we will package up garbages,or "box" garbages up and put them onto the heap.But sometime we don't want it to be collected by GC,so unbox it from heap and put them onto stack. Just kidding^^
Equals and ==
When we're talking about equal, actually we're talking about two kind of equal: logical equal(having the same value) or reference equal(having the same reference)
For reference objects, Equals method and the "==" operator have the same behavior, that is, comparing two objects to see if they have the same reference.But sometime we want a little bit change so we override the Equals method to let it compare the value rather than reference,String type is a classic example, when we use Equals method to compare two string,actually we are checking if they are the same sequence of chars.
Things is a little bit complicate for value type.The Equals method of value type is used to check the value equality, but value type don't have the "==" operator, unless you overload it.
Dictionary and Hashtable
- Dictionary and Hashtable are based on hash,Dictionary is actually a hashtable. Dictionary supports generic type while Hashtable don't, so Dictionary is type-safe,and has a better performance, because we don't need to convert the value which is object type to what it actually is,so no risk of boxing/unboxing.
- Both use the GetHashCode method to check the uniqueness of keys,but if there is already a key which have the same hashcode,then the Equals method will be called to check if they are ference equals.
Interface
- interface can extend another interface
- interface CAN have indexer! check it on MSDN
- interface CAN have event! check it on MSDN
- "Interfaces can contain events, indexers, methods, and properties." ——MSDN
- You can implement multi interfaces which have method(s) with same name!! In this situation,you should implement them explicitly:
public interface ITest { void Test(); } public interface ITest2 { void Test(); } public class Dual : ITest, ITest2 { void ITest.Test() { Console.WriteLine("ITest.Test"); } void ITest2.Test() { Console.WriteLine("ITest2.Test"); } }
And the methods can not be public.In order to access the method, you have to first convert the class to the interface type:
var dual = new Dual(); // Call the ITest.Test() function by first assigning to an explicitly typed variable ITest test = dual; test.Test(); // Call the ITest2.Test() function by using a type cast. ((ITest2)dual).Test();
What is serialization?
Serialization is a converting from data structure or object state in memory to byte stream so that it can be store,transfer,or turn into other format like xml,json under helping of formaters.
Foreground thread and background thread
- A managed thread is either foreground thread or background thread.Foreground thread(s) keep application running,while background don't.
- Process can not be stopped until all foreground threads are stopped.
- Process won't be stopped by stopping Background thread.
- Thread is foreground by default,you can set the IsBackground property to be ture if needed.
Mutable object and Immutable object
Mutable means "changeable" and Immutable means "unchangeable"
Immutable object means that once you create the object, you can never change its state.For example, string is immutable, when you declare a variable of string : string a="foo", then an object of string "foo" is created, when you do this:a="bar", you are actually creating a new instance of string ,the origin instance "foo" still exists and never ever be changed.
1. "obj is dynamic" is always true, nomatter what type is obj,unless obj is null。
2."params" parameter must be the last one,even to "out" parameter
3.Why can not a struct have default constructor??
Calling GetType on a Nullable type causes a boxing operation to be performed when the type is implicitly converted to Object. Therefore GetType always returns a Type object that represents the underlying type, not the Nullable type.
so basically your code is equal to:
DateTime? dt = DateTime.Now;
object box = (object)dt;
Console.Write(box.GetType().ToString());
also, looking at "Boxing Nullable Types" on MSDN we read:
If the object is non-null -- if HasValue is true -- then boxing occurs, but only the underlying type that the nullable object is based on is boxed. Boxing a non-null nullable value type boxes the value type itself, not the System.Nullable(Of T) that wraps the value type.
this clearly explain the "strange" behavior of Nullable<T>.GetType()