Archive for 12月, 2009

进程、线程与应用程序域(AppDomain) 浅析

12月 23rd, 2009

进程
进程是操作系统用于隔离众多正在运行的应用程序的机制。在.Net之前,每一个应用程序被加载到单独的进程中,并为该进程指定私有的虚拟内存。进程不能直接访问物理内存,操作系统通过其它的处理把这些虚拟内存映射到物理内存或IO设备的某个区域,而这些物理内存之间不会有重叠,这就决定了一个进程不可能访问分配给另一个进程的内存。相应地,运行在该进程中的应用程序也不可能写入另一个应用程序的内存,这确保了任何执行出错的代码不会损害其地址空间以外的应用程序。在这种机制下,进程作为应用程序之间一个独立而安全的边界在很大程度上提高了运行安全。

Read more »

反射,动态加载,晚期绑定间的关系。

12月 22nd, 2009

1 动态加载程序集

2 反射获取Type信息(类的信息,方法的信息)

3晚期绑定(1 创造对象实例  2 调用方法(有参,无参))

.net程序集格式

12月 20th, 2009

win32文件首部

CLR文件首部

CIL代码

类型元数据

程序集清单

可选的嵌入资源

求二进制数中1的个数

12月 19th, 2009

对于一个字节(8bit)的变量,求其二进制表示中“1”的个数,要求算法的执行效率尽可能地高。 Read more »

一摞烙饼引发的“血案”

12月 6th, 2009

看移山之道这个网站,看到了不错的问题,好多牛人在讨论,以后得常去,最近忙着考试,写到要少的多了。

有一次我烙了三个饼,一个两面都焦了,一个两面都是金黄色,一个一面是焦的,一面是金黄色,我把它们摞一起,只能看到最上一面,发现是焦的,问最上面这个饼的另一面是焦的概率是多少?

解法1:

1. 最上一面是焦的, 排除最上一张是两面金黄色

2. 剩下两张饼四个面, 三面是焦的, 一面金黄色, 现知道其中一面是焦的,

所以判断另一面是焦的概率就是求 二面焦 + 一面金黄 中焦的概率, = 2/2+1 = 2/3

解法2:

A=最上面的饼双面焦

B=最上面的饼双面金黄

C=最上面的饼一面金黄一面焦

J=最上面的一面焦

则P(J|A)=1,P(J|B)=0,P(J|C)=0.5

P(A|J)=P(AJ)/P(J)=(1/3)/(1/2)=2/3