1:委托和事件
//事件类
public class EventClass
{
public void display(object sender, System.EventArgs e)
{
Console.WriteLine("This is the Event Class");
Console.ReadLine();
}
}
//调用类
class InvokeClass
{
//声明代理对象,注意参数
public delegate void delegateobj(object sender, System.EventArgs e);
//声明事件对象
private event delegateobj obj;
//声明要调用的事件类对象
private EventClass ec;
public InvokeClass()
{
ec = new EventClass();
//添加事件对象到事件队列中,参数为要调用的事件
this.obj += new delegateobj(ec.display);
}
//调用delegate对象触发事件
protected void OnObj(System.EventArgs e)
{
if (this.obj != null)
{
obj(this, e);
}
}
public void RaiseEvent()
{
EventArgs e = new EventArgs();
OnObj(e);
}
static void Main(string[] args)
{
InvokeClass ic = new InvokeClass();
Console.WriteLine("Please input a string");
string input = Console.ReadLine();
if (input.Equals(""))
{
Console.WriteLine("Sorry,you don't input anything");
}
else
{
//触发事件
ic.RaiseEvent();
}
}
}
2:遍历页面中所有的TextBox,交将值设置成"a"
{
foreach (object o in Page.Controls[j].Controls)
{
if (o is TextBox)
{
TextBox txt = (System.Web.UI.WebControls.TextBox)o;
txt.Text = "A";
}
}
}
3:常用排序算法
/// /冒泡排序
/// </summary>
private void BubbleSort()
{
//冒泡排序
int[] list = new int[5] { 111, 12, 223, 854, -5655 };//初始化数组
int i, j, temp;
for (j = 1; j < list.Length; j++)
{
for (i = 0; i < list.Length - j; i++)
{
if (list[i] > list[i + 1])
{
temp = list[i];
list[i] = list[i + 1];
list[i + 1] = temp;
}
}
}
}
/// <summary>
/// 选择排序
/// </summary>
private void SelectSort()
{
//选择排序
int[] a = new int[5] { 111, 12, 223, 854, -5655 };//初始化数组
int min, min_k;//定义最小数,和最小数的下标
for (int i = 0; i < 5; i++)
{
min = a[i];//将当前循环的数设置成最小数
min_k = i;
for (int j = i + 1; j < 5; j++)
{
if (a[j] < min)
{
min = a[j];
min_k = j;
int tem = a[min_k];
a[min_k] = a[i];
a[i] = tem;
}
}
}
}
4:结构体(Struct) 和 类(Class)
<1> 结构的特点和性能优势
结构是值类型,继承自System.ValueType。结构相对于类来说有两个性能上的优势,结构通常分配在栈(Stack)上面,类的实际内容通常分配在堆(Heap)上面,访问栈的速度会比访问堆的速度更快。但是这并不是一个明显的优势。最主要的是栈上面的内容释放是非常快的,通常在函数调用结束以后,栈就自动释放了;但是对于堆来说,必须等待垃圾收集器(Garbage Collector)来收集,往往垃圾收集器的工作都有滞后特性,所以我们不一定当时就能注意到性能的变化,但是这种影响终究会体现出来。
<2> 结构的弱点
(1)作为参数传递的时候效率低
(2)装箱(Boxing)和解箱(Unboxing)效率低
在下面的情况下使用类
1 内容很多的时候,因为结构总是暗地里拷贝了一个临时变量。
2 需要非常多内存的时候,因为栈的容量有限,而堆通常是足够使用的。
3 需要在声明字段的时候进行初始化。
4 需要从基类继承。
5 需要多态性。接口也可以用来实现多态性,但是因为结构是值类型,尽管它可以从接口继承,但是在多态过程中会进行装箱和解箱的操作。
1 希望能够象原始类型(比如int,double之类的)一样使用它。比如我们可以声明一个复数结构,然后像double类型一样地使用它。
2 需要的内存较少,栈可以完全地容纳它。
3 想避开垃圾收集器的处理,自己掌握资源的释放。
4 只需要缺省的值,而不需要在声明字段的时候赋值。
5 不需要从基类继承,当然,不包括ValueType。
6 不需要多态行为。
5:给XML文件中已知的结点添加属性:
XML文件结构如下:
<MovieBlacklist>
<Blacklist id="17050" part="32" name="江湖俏佳人" age="20" />
<Blacklist id="17310" part="1" name="阴谋" />
<Blacklist id="17316" part="1" name="WWE摔角080314" />
<Blacklist id="17190" part="1" name="2012世界末日" />
</MovieBlacklist>
给第一个Blacklist添加属性age
/// 给已知结点增加一个属性
/// </summary>
/// <param name="XmlPathNode"></param>
/// <param name="Content"></param>
public void XMLAddAttributes(string XmlPathNode,string sName, string sContent)
{
// 创建节点
XmlNode attrCount = objXmlDoc.CreateNode(XmlNodeType.Attribute, sName , null);
attrCount.Value = sContent ;
// 添加节点属性
objXmlDoc.SelectSingleNode(XmlPathNode).Attributes.SetNamedItem(attrCount);
}
6.求以下表达式的值,写出您想到的一种或几种实现方法: 1-2+3-4+……+m
答:
bool flag=true;
for(int i=1;i<=m;i++)
{
if(flag)
sum+=i;
else
sum-=i;
flag=!flag;
}
return sum;