姓名: 日期:
1. 填空: (1)面向对象的语言具有________性、_________性、________性。
(2)能用foreach遍历访问的对象需要实现 ________________接口或声明________________方法的类型。
(3)列举ADO.net中的五个主要对象_______________、_____________、_______________、_______________、_________________。
2. 不定项选择:
(1) 以下叙述正确的是:
A. 接口中可以有虚方法。 B. 一个类可以实现多个接口。
C. 接口不能被实例化。 D. 接口中可以包含已实现的方法。
(2) 从数据库读取记录,你可能用到的方法有:
A. ExecuteNonQuery B. ExecuteScalar
C. Fill D. ExecuteReader
3. 简述 private、 protected、 public、 internal 修饰符的访问权限。
4. 写出一条Sql语句: 取出表A中第31到第40记录(SQLServer, 以自动增长的ID作为主键, 注意:ID可能不是连续的。)
5 .列举ASP.NET 页面之间传递值的几种方式。
6. 写出程序的输出结果

Code
1
class Class1
2

{
3
private string str = "Class1.str";
4
private int i = 0;
5
static void StringConvert(string str)
6
{
7
str = "string being converted.";
8
}
9
static void StringConvert(Class1 c)
10
{
11
c.str = "string being converted.";
12
}
13
static void Add(int i)
14
{
15
i++;
16
}
17
static void AddWithRef(ref int i)
18
{
19
i++;
20
}
21
static void Main()
22
{
23
int i1 = 10;
24
int i2 = 20;
25
string str = "str";
26
Class1 c = new Class1();
27
Add(i1);
28
AddWithRef(ref i2);
29
Add(c.i);
30
StringConvert(str);
31
StringConvert(c);
32
Console.WriteLine(i1);
33
Console.WriteLine(i2);
34
Console.WriteLine(c.i);
35
Console.WriteLine(str);
36
Console.WriteLine(c.str);
37
}
38
}
7.写出程序的输出结果

Code
1
public abstract class A
2

{
3
public A()
4
{
5
Console.WriteLine('A');
6
}
7
public virtual void Fun()
8
{
9
Console.WriteLine("A.Fun()");
10
}
11
}
12
13
public class B: A
14

{
15
public B()
16
{
17
Console.WriteLine('B');
18
}
19
20
public new void Fun()
21
{
22
Console.WriteLine("B.Fun()");
23
}
24
25
public static void Main()
26
{
27
A a = new B();
28
a.Fun();
29
}
30
}
31
32
8. 写出程序的输出结果:

Code
1
public class A
2

{
3
public virtual void Fun1(int i)
4
{
5
Console.WriteLine(i);
6
}
7
8
public void Fun2(A a)
9
{
10
a.Fun1(1);
11
Fun1(5);
12
}
13
}
14
15
16
public class B : A
17

{
18
public override void Fun1(int i)
19
{
20
base.Fun1 (i + 1);
21
}
22
23
public static void Main()
24
{
25
B b = new B();
26
A a = new A();
27
a.Fun2(b);
28
b.Fun2(a);
29
}
30
}
31
32
9. 一列数的规则如下: 1、1、2、3、5、8、13、21、34......
求第30位数是多少, 用递归算法实现。(C#语言)
10. 程序设计: 猫大叫一声,所有的老鼠都开始逃跑,主人被惊醒。(C#语言)
要求: 1.要有联动性,老鼠和主人的行为是被动的。
2.考虑可扩展性,猫的叫声可能引起其他联动效应。
参考答案:
1. (1) 继承性、封装性、多态性。(考基本概念)
(2) IEnumerable 、 GetEnumerator (对foreach机制的理解,本来不想出这题的,凑分)
(3) ... (送分题, 对ADO.net的了解)
评分标准:一空1分,满分10分。
2. (1) B、C (考对接口的理解) (2) B、C、D (考查对ADO.net的熟练程度)
评分标准: 一题5分,不选或者错选均不得分。漏选得2分。满分10分。
3. . private : 私有成员, 在类的内部才可以访问。
protected : 保护成员,该类内部和继承类中可以访问。
public : 公共成员,完全公开,没有访问限制。
internal: 在同一命名空间内可以访问。
评分标准:答对1题2分,2题5分,3题7分。全对10分。 (送分题)
4. 解1: select top 10 * from A where id not in (select top 30 id from A)
解2: select top 10 * from A where id > (select max(id) from (select top 30 id from A )as A)
评分标准: 写对即10分。(答案不唯一,datagrid 分页可能需要用到)
5. 1.使用QueryString, 如....?id=1; response. Redirect()....
2.使用Session变量
3.使用Server.Transfer
....
评分标准: 答对1点得3分, 两点7分, 3点10分。
6. (考查值引用和对象引用)
10
21
0
str
string being converted.
评分标准:答对一点得2分,满分10分。
7. A
B
A.Fun()
评分标准: 写出A.B 得5分,写出A.Fun()得5分,满分10分。
(考查在继承类中构造函数, 以及new 方法, )
8. 2
5
1
6
评分标准: 答对一点得2分,两点得5分,3点得7分。全对得10分。
(一些人做这题,头都晕了.... ^_^ )
9.

Code
1
public class MainClass
2

{
3
public static void Main()
4
{
5
Console.WriteLine(Foo(30));
6
}
7
public static int Foo(int i)
8
{
9
if (i <= 0)
10
return 0;
11
else if(i > 0 && i <= 2)
12
return 1;
13
else return Foo(i -1) + Foo(i - 2);
14
}
15
}
16
评分标准: 写出return Foo(i -1) + Foo(i - 2); 得5分。
写出if(i > 0 && i <= 2) return 1; 得5分。
方法参数过多需要扣分(扣除分数 = 参数个数 - 1)
不用递归算法扣5分
(递归算法在树结构建立等方面比较常用)
10
要点:1. 联动效果,运行代码只要执行Cat.Cryed()方法。2. 对老鼠和主人进行抽象
评分标准: <1>.构造出Cat、Mouse、Master三个类,并能使程序运行(2分)
<2>从Mouse和Master中提取抽象(5分)
<3>联动效应,只要执行Cat.Cryed()就可以使老鼠逃跑,主人惊醒。(3分)

Code
1
public interface Observer
2
{
3
void Response(); //观察者的响应,如是老鼠见到猫的反映
4
}
5
public interface Subject
6
{
7
void AimAt(Observer obs); //针对哪些观察者,这里指猫的要扑捉的对象---老鼠
8
}
9
public class Mouse : Observer
10
{
11
private string name;
12
public Mouse(string name, Subject subj)
13
{
14
this.name = name;
15
subj.AimAt(this);
16
}
17
18
public void Response()
19
{
20
Console.WriteLine(name + " attempt to escape!");
21
}
22
}
23
public class Master : Observer
24
{
25
public Master(Subject subj)
26
{
27
subj.AimAt(this);
28
}
29
30
public void Response()
31
{
32
Console.WriteLine("Host waken!");
33
}
34
}
35
36
public class Cat : Subject
37
{
38
private ArrayList observers;
39
public Cat()
40
{
41
this.observers = new ArrayList();
42
}
43
public void AimAt(Observer obs)
44
{
45
this.observers.Add(obs);
46
}
47
public void Cry()
48
{
49
Console.WriteLine("Cat cryed!");
50
foreach (Observer obs in this.observers)
51
{
52
obs.Response();
53
}
54
}
55
}
56
class MainClass
57
{
58
static void Main(string[] args)
59
{
60
Cat cat = new Cat();
61
Mouse mouse1 = new Mouse("mouse1", cat);
62
Mouse mouse2 = new Mouse("mouse2", cat);
63
Master master = new Master(cat);
64
cat.Cry();
65
}
66
}
67
//---------------------------------------------------------------------------------------------
设计方法二: 使用event -- delegate设计..

Code
1
public delegate void SubEventHandler();
2
public abstract class Subject
3
{
4
public event SubEventHandler SubEvent;
5
protected void FireAway()
6
{
7
if (this.SubEvent != null)
8
this.SubEvent();
9
}
10
}
11
public class Cat : Subject
12
{
13
public void Cry()
14
{
15
Console.WriteLine("cat cryed.");
16
this.FireAway();
17
}
18
}
19
public abstract class Observer
20
{
21
public Observer(Subject sub)
22
{
23
sub.SubEvent += new SubEventHandler(Response);
24
}
25
public abstract void Response();
26
}
27
public class Mouse : Observer
28
{
29
private string name;
30
public Mouse(string name, Subject sub) : base(sub)
31
{
32
this.name = name;
33
}
34
public override void Response()
35
{
36
Console.WriteLine(name + " attempt to escape!");
37
}
38
}
39
public class Master : Observer
40
{
41
public Master(Subject sub) : base(sub)
{}
42
public override void Response()
43
{
44
Console.WriteLine("host waken");
45
}
46
}
47
class Class1
48
{
49
static void Main(string[] args)
50
{
51
Cat cat = new Cat();
52
Mouse mouse1 = new Mouse("mouse1", cat);
53
Mouse mouse2 = new Mouse("mouse2", cat);
54
Master master = new Master(cat);
55
cat.Cry();
56
}
57
58
}
59