委托 delegate, 继承
c# 的委托就是说把函数当参数来传递。
这个在js完全就用不着搞什么委托东西,直接转就是了嘛。对不对!怎么录嘛!
一个函数,如果它的参数是函数,那么是这样子写的
public void method(Action<string, Int32> voidMethod, Func<string, Int32> returnMethod)
Action<string, Int32> voidMethod
的意思是说这个将被传进来的函数是一个没有return的函数,就是public void啦, 它需要一个str参数
(这里提一下,js中每个函数都是return的即使你没有写,它也会return undefiend)
Func<string, Int32> returnMethod
的意思是说这个函数是一个有return的函数,最后一个参数Int32代表了它的return是一个Int32 , 就是 public Int32啦, 那么除了最后一个参数其余的都是这个函数所需要的参数了
具体代码 :
public void test(Func<string,int,string> returnMethod, Action<string> voidMethod)
{
voidMethod("para1");
string returnValue = returnMethod("para1", );
}
protected void Page_Load(object sender, EventArgs e)
{
//第一种写法
test(delegate(string para1, int para2)
{
return "";
}, delegate(string para1)
{
string x = "do somthing";
}); //第2中写法,有点表达式的味道了。 js的话要ECMA6才支持箭头写法
test((para1, para2) => "", (para1) => { string x = "do somthing"; });
test((para1, para2) =>
{
string a = "" + para1;
return a + "";
}, (para1) =>
{
string x = "do somthing" + para1;
});
}
这里使用的是匿名函数delegate(){},这个比较习惯,因为js大多数会用匿名函数的。
当然,如果你硬硬要old school风 , 可以写比较传统的
public void method(tuoguan voidMethod, tuoguan2 returnMethod) //这里不可以在写 Action or Func了
{
Int32 i = returnMethod("b");
voidMethod("b");
}
public delegate void tuoguan(string name);
public delegate Int32 tuoguan2(string name);
public Int32 returnMethod(string name)
{
return ;
} tuoguan xx = delegate(string name)
{
//do somthing
};
tuoguan2 yy = returnMethod; //这里可以指向某个方法,不是一定要写 delegate
method(xx, yy);
委托是很好用的,比如我对进去的匿名函数也可以引用到作用域上的变量,这个和js是一样的!
把它当js来写,我觉得这样非常好!
继承
//简单介绍
public class basic_class_logic
{
public abstract class chouxiang //抽象类只是一个虚拟的类,是不可以实例化的(其它特性和普通类一样),目的是给派生类(子类)使用
{
//与接口不同
//里面可以写属性方法
} //public:它具有最高的访问级别,对访问公共成员没有限制。
//private:它的访问级别最低,仅限于它的包含类。
//protected:能在它的包含类或包含类的派生类中访问。
//internal:只能在同一程序集的文件中。
//protected internal:仅限于从包含类派生的当前程序集或类型。
//public abstract:可以在任何地方访问,但不能实例化,只能继承。
//public sealed:可以在任何地方访问,只能实例化,不能派生。
public static void move() { } //static void 是静态方法 (无需实例化类也可以调用)
public const int months = ; //const 是常量 ,一旦赋值就不能改变,通常用于一些死的变量
// public const DateTime months = new DateTime(2013, 10, 07, 00, 05, 00, 00); 这里会报错 ! const 不能使用 new ,所以用readonly就不会
public readonly int MAX_VALUE = ; // readonly 也是常量 。动态常量 , 有人建议用这个不要用 const //公有name "引用" 私有name (和js 一样逻辑)
//调用:
//Car first = new Car();
//first.name = "keatkeat";
//first.changeName("xinyao");
//string a = first.name; //result : xinyao
//*
public class Person
{
private string _name; //私有name public Person()
{
this.name = "ttc";
}
public string name //公有name
{
get { return _name; } //返回私有name
set { _name = value; } // set 私有name
}
public void changeName(string name)//公有方法
{
_name = name; //替换私有name
}
}
//无需私有name 的方式 效果和上面一个差不多
public class Car
{
public string name { get; set; } //公有name
public void changeName(string name)
{
this.name = name; //change obj.name
}
}
} //继承
public class xuncheng
{
public class Person //基类,父类
{
public Person(string name, int age = ) //实例化是调用的函数
{
this.name = name;
this.age = age;
}
public string name { get; set; }
public int age { get; set; }
public string getName() //普通方法
{
return this.name;
}
public abstract string getAbstractName(); //abstract 抽象方法(只有在抽象类才能有抽象方法) ,在本类是无法调用的,也无内容,只是一个声明,子类通过覆盖方法来调用(一定要有覆盖的方法,不然会error)
public virtual void sayVirtualName() //virtual 虚方法,本类可以调用,子类可以覆盖,如果没有覆盖将调用此方法 (和普通方法几乎一样)
{
string a = "bb";
}
}
//讲解:
//子类可以调用所有父类的属性和方法(除了私有的不可以)
public class Student : Person
{
//base.属性 ,base.方法 通过base关键字,调用父类的函数 (孩子的孩子,通过base方法就会一直向上调用,不管几代都能一直往上)
public string school_name { get; set; }
public Student(string school_name) //调用基类的构造函数(实例化时的函数) 可以写default也可以是传入参数
: base(school_name, )
{
this.school_name = school_name;
} public new string getName() //可以用 new 来隐藏父类的普通方法,在父类依然是调用父类,在子类就会调用new 的方法子类。
{
string a = this.name; //如果子类没有name 属性会调用父类的,有的话会调用子类的
string b = base.name; //100%调用父类的name
return "覆盖name";
}
public override string getAbstractName()//通过 override 来覆盖抽象方法或虚方法,一但覆盖了即便是在父类也将调用覆盖了的新方法了!
{
return "抽象方法必须实现-用override";
}
public override void sayVirtualName()//通过 override 来覆盖虚方法 (如果子类没有覆盖将调用回复类方法)
{
string start = "xx"; //这样就可以达到扩展方法的效果了
base.sayVirtualName();//调用回原本的方法
string end = "xx";
}
}
} //泛型
//调用时才把类型传进去,有点动态的感觉
//调用 : Parent<string> xx = new Parent<string>(); 这个时候才指定是string
public class Parent<T> //T 是一个类型 比如 string,int
{
public T name { get; set; }
public T getName()
{
return this.name;
}
}
//struct 是 值类型
//好处调用的是如果参数是值类型可以不用著名 test(100) 而不需要 test<int>(100);
public void test<T>(T number) where T : struct
{
int z = Convert.ToInt32(number);
//调用 test(100);
}
//不知道好处在哪
public void test2<T>(T lei) where T : class
{ }
//我知道哪个class还需要用泛型吗?! 不解
public void test3<T>() where T : stooges
{ }
//进来实例化就走?也是不知道哪里用得上!实例了又不能调用它的方法啦!靠
public T test4<T>() where T : new()
{
T abc = new T();
return abc;
}
public class stooges
{ } protected void Page_Load(object sender, EventArgs e)
{ }
更新 2016-07-12
async 一个方法
Func<Task<string>> xx = async () =>
{
await Task.Delay();
return "";
};
string www = await xx();
委托 delegate, 继承的更多相关文章
- [C#] C# 知识回顾 - 委托 delegate
C# 知识回顾 - 委托 delegate [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/6031892.html 目录 What's 委托 委托的属性 ...
- C# 委托Delegate(一) 基础介绍&用法
本文是根据书本&网络 前人总结的. 1. 前言 定义&介绍: 委托Delegate是一个类,定义了方法的类型, 使得可以将方法当做另一个方法的参数来进行传递,这种将方法动态地赋给参数的 ...
- 为什么不能把委托(delegate)放在一个接口(interface)当中?
stackoverflow上有人问,为什么不能把委托放在一个接口当中? 投票最多的第一个答案第一句话说,“A Delegate is just another type, so you don't g ...
- [.NET] C# 知识回顾 - 委托 delegate (续)
C# 知识回顾 - 委托 delegate (续) [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/6046171.html 序 上篇<C# 知识回 ...
- C# 代理/委托 Delegate
本文转载自努力,努力,努力 1. 委托的定义:委托是函数的封装,它代表一"类"函数.他们都符合一定的签名:拥有相同的参数列表,返回值类型.同时,委托也可以看成是对函数的抽象,是函数 ...
- c# 委托 delegate
委托是一种存储函数引用的类型,在事件和事件的处理时有重要的用途 通俗的说,委托是一个可以引用方法的类型,当创建一个委托,也就创建一个引用方法的变量,进而就可以调用那个方法,即委托可以调用它所指的方法. ...
- 理解委托(delegate)及为什么要使用委托
理解委托(delegate)及为什么要使用委托 委托:是一种定义方法签名的类型. 当实例化委托时,您可以将其实例与任何具有兼容签名的方法相关联. 您可以通过委托实例调用方法. 上述为官方说法,理解起来 ...
- 深入理解委托(Delegate)
前言 委托其实一直以来都感觉自己应该挺熟悉的,直到最近又去翻了翻 CLR via C#,感觉我之前的理解可能还有失偏颇.在这记录一下. 之前文章的链接: 接口和委托的泛型可变性 C#高级编程笔记 De ...
- C# -- 使用委托 delegate 执行异步操作
C# -- 使用委托 delegate 执行异步操作 委托是一种安全地封装方法的类型,它与 C 和 C++ 中的函数指针类似. 与 C 中的函数指针不同,委托是面向对象的.类型安全的和保险的. 委托的 ...
随机推荐
- otl获得sql出错位置(oracle)
项目的一个需要,要获得sql出错的位置,从而给出类似sqlplus的错误提示(如下) sql出错原因易获得,记录在otl_exception::msg,但出错位置就不是那么容易了. 默认情况下otl异 ...
- powershell利用winform批量执行tsql语句
#加载.net的winform模块 [Reflection.Assembly]::LoadWithPartialName("System.Windows.Forms") $app= ...
- 百度地图API 重新生成点聚合的功能
百度点聚合用来解决加载大量点要素到地图上产生覆盖现象的问题,并提高性能. http://api.map.baidu.com/library/MarkerClusterer/1.2/docs/symbo ...
- awk使用入门
1.基本用法 awk '{pattern + action}' {filenames} pattern 表示 AWK 在数据中查找的内容 action 是在找到匹配内容时所执行的一系列命令. patt ...
- Android Studio常用插件
ButterKnife 这个开源库可以让我们从大量的findViewById()和setonclicktListener()解放出来,其对性能的影响微乎其微(查看过Butter Knife的源码,其自 ...
- [Angular 2] ngrx/store
@ngrx/store builds on the concepts made popular by Redux and supercharges it with the backing of RxJ ...
- 【JavaScript】深入分析JavaScript的关系运算和if语句
JavaScript的关系运算,没有我原想的那么简单.等终于理清它的运算逻辑之后,我的头大了至少一圈.而if语句的真假判定逻辑本身不难,但要把它和关系运算联系起来,相信你会和我一样,到达崩溃边缘.不信 ...
- iscc2016 pwn部分writeup
一.pwn1 简单的32位栈溢出,定位溢出点后即可写exp gdb-peda$ r Starting program: /usr/iscc/pwn1 C'mon pwn me : AAA%AAsAAB ...
- Python元组、列表--笔记
<Python3 程序开发指南> 序列包括元组和列表,首先,我们介绍元组. 元组--tuple 元组为有序的序列,元组和字符串一样也是固定的,不能替换或删除其中的任意数据项.如果需要修改应 ...
- css空格和去浮动的应用
今天做了项目用到css,请教前端解决,第一个是记得css空格之间的关系是隶属关系,但是在元素中却是并列关系,如<div class="right_side_item_moban gra ...