• 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:

    1. 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.
    2. no access modifier allowed on namespace,but public is implicitly.
    3. internal is default to a class
    4. no access modifier allowed on a interface but public is implicitly.
    5. 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

    1. 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.
    2. struct can have constructor which have parameter(s), default constructor(paramterless) is not allowed.
    3. struct can have const,field,property,method,index,operator,event,but if you need these members,then a class may be better.
    4. struct can implement interfaces,but can not inherit from a class,so members of struct can not be protected.
    5. you can declare a struct object without "new" keyword: 
      MyStruct myStruct;
      myStruct.Pro1="value";
    6. 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

    1. 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.
    2. 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

    1. interface can extend another interface
    2. interface CAN have indexer! check it on MSDN
    3. interface CAN have event! check it on MSDN
    4. "Interfaces can contain events, indexers, methods, and properties." ——MSDN
    5. 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

    1. A managed thread is either foreground thread or background thread.Foreground thread(s) keep application running,while background don't.
    2. Process can not be stopped until all foreground threads are stopped.
    3. Process won't be stopped by stopping Background thread.
    4. 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()

  • 相关阅读:
    SharedPreferences.Editor 的apply()与commit()方法的区别
    Android 解决方法数 65536 (65k) 限制
    Android RatingBar 自定义样式
    自定义 checkbox 新玩法 ?
    Android 透明度百分比对应的 十六进制
    Linux文件权限rwx简单了解
    Linux学习之Vim使用
    Linux学习之用户管理
    Linux学习之sudo命令
    一元稀疏多项式加法运算
  • 原文地址:https://www.cnblogs.com/lwhkdash/p/6713746.html
Copyright © 2020-2023  润新知