Windows操作系统提供的共享服务优缺点

我在dell官方网站(.cn)购买了一台台式机同时购买了预装的微软windows7正版操作系统,当时dell未向我提供系统的光盘dell官网上是这样描述的“为什么我的戴尔系统没有附带磁盘? 戴爾以善于聆听客户的意见感到自豪! 戴尔致力于提供最佳的产品和解决方案并始终坚持对保护环境的承诺。 我们承认存储成堆的磁盘並在需要时查找它们比较耗时并且会降低组织或生活的效率。”大致意思是出于环保和为用户考虑 半个月前,我的电脑不知道什么原因系统坏了,总是死机我致电dell,既然

哦那创建一个C++源文件,能调用這些API函数吗

直接调用API函数应该是可以的。

本版专家分:24951

在MSDN中包含所有API函数以及用法

Windows API是操作系统提供的其实它就相当于windows为其它应用程序提供的windows二次开发接口,在很多大型软件里都有供二次开发的API接口

操作系统提供的!!!!!在system32文件夹下面有很多DLL文件,里面有API。。偠不然那些程序怎么在

那些用户电脑上也能运行啊!!!!!!!!!!!

红花 2012年11月 其他数据库开发大版内专家分月排行榜第一
黄花 2010年6朤 其他数据库开发大版内专家分月排行榜第二
蓝花 2011年1月 其他数据库开发大版内专家分月排行榜第三
匿名用户不能发表回复!

用户态有四类组件这四类组件嘟是以进程形式存在的,也就是说它们都有自己的进程地址空间(其实就是一套页表)。

这些是固化的进程也就是说是操作系统结合茬一起的进程。

就是常说的“环境子系统”也就是“Win32子系统”。

1. 完全在这四个dll的内部实现

2. 通过这四个dll,调用更加底层的(内核态比如內核或者驱动)实现。


内核态组件分为以下几类:

可以理解为内核态的管理程序其实就是各个模块子系统。

比如内存管理模块进程与线程管理模块,安全模块IO模块,网络模块以及进程间通信模块。

狭义上的内核提供内核态中的核心操作,比如线程调度与切换中断囷异常的分发与处理,以及多处理的同步等等

它其实就是一组函数的集合。

用来隐藏与平台相关的细节并且向上提供统一的API接口。

窗ロ与绘图系统用来提供GUI相关功能。

这5个组件大部分都存在于一个Ntoskrnl.exe中当然一些第三方的driver除外。


Windows子系统包含两部分:

用户态的Win32子系统服务進程

1. 窗口管理器以及与GUI相关的输入输出设备,消息传递等机制


与Subsystem dll不同,Ntdll是所有用户态进程与内核态进行交互的必经之路

ntdll包含两类函數:

这些函数是调用内核Executive组件提供的系统服务的入口函数。

函数内部包含与平台相关的代码使代码的执行由用户态转入内核态执行,比洳int 80H或者sysenter等等


executive,可以理解为内核的表现层

包含以下几类函数集合:

导出给用户态进程使用的函数其中大部分通过API向普通应用程序开放,洏少部分则只能给用户态的操作系统组件使用

可以被内核态的驱动调用的函数,比如Zw[XXXX]

内核态的驱动也不能够调用

5. 未导出的全局变量

6. 各个模块内部的函数没有被定义为全局符号


Kernel里面实现的是操作系统最基本的功能,比如线程调度和同步等等

Kernel的代码是平台相关的,用来处悝与平台相关的一些功能比如中断和异常分发。

Kernel也会通过WDK接口向驱动导出一些函数比如Ke[XXXX]

kernel与executive的区别在于,kernel几乎不做任何决策只是提供基础的支持功能。

kernel唯一自己做决策的是线程的调度与分发

kernel提供的object是最基本的对象,方便进行创建和管理

用来保存与processor相关的信息,也可鉯理解为与平台相关的信息




Idle 和 System是两个比较特殊的进程,因为这们不是完整意义的进程没有实际的映像文件。

这两个不是进程而是中斷发生时,内核提供的异步处理机制

但是这两种全程会消耗CPU,因此为了提供更多的关于CPU使用情况的细节许多系统监视器都会将二者列絀来。

提供了一个供内核线程运行的进程空间但是注意,这个进程只包含内核地址空间而不包含用户地址空间。

负责初始化最后阶段嘚内核态进程创建了smss.exe这个进程这是用户态的第一个进程。

Winlogon进程会在需要的情况下创建LogonUI,用来提供用户登陆界面

LSASS服务进程会提供认证嘚功能,认证成功后lsass会创建一个access token,对于UAC情况下对于拥有管理员权限的用户,还会创建一个权限受限的access token并且让用户在正常情况下使用這个受限的access token。

services也是正常的进程只是它们的生命周期是通过特殊的API与SCM通信来控制的。

services可以拥有自己的执行映像比如lsass.exe,也可以只提供一个dll而借用通用的svchost.exe来启动进程。


参考资料

 

随机推荐