创建根对象

ObInit会被调用两次,ObpInitializationPhase分别为TRUE和FALSE的时候。

在ObpInitializationPhase==TURE时,创建根目录\和\ObjectTypes
在ObpInitializationPhase==FALSE时,调用ObCreateObjectType,创建\ObjectTypes中下的的Type、Directory、SymbolicLink等。
根目录\和\ObjectTypes

ObInit()
{

// 创建根目录\

/* Create the directory */
Status = NtCreateDirectoryObject(&Handle,
                                 DIRECTORY_ALL_ACCESS,
                                 &ObjectAttributes);


//将句柄转换成对象
Status = ObReferenceObjectByHandle(Handle,
                                   0,
                                   ObDirectoryType,
                                   KernelMode,
                                   (PVOID*)&ObpRootDirectoryObject,
                                   NULL);


// 创建根目录\ObjectTypes
Status = NtCreateDirectoryObject(&Handle,
                                 DIRECTORY_ALL_ACCESS,
                                 &ObjectAttributes);


/* Get a handle to it */
Status = ObReferenceObjectByHandle(Handle,
                                   0,
                                   ObDirectoryType,
                                   KernelMode,
                                   (PVOID*)&ObpTypeDirectoryObject,
                                   NULL);


}

转载于:https://www.cnblogs.com/fanzi2009/archive/2010/02/10/1667194.html

### Vue.js 创建对象的方法 在 Vue.js 中,“创建对象”的概念通常指的是通过 `createApp` 方法初始化一个 Vue 应用实例,或者定义和管理组件内的数据对象。以下是关于如何在 Vue.js 中创建对象的具体方法及其示例。 #### 使用 `createApp` 初始化应用并绑定根级数据对象 当调用 `Vue.createApp()` 时,实际上是在创建一个新的 Vue 实例,并将其挂载到指定的 DOM 元素上。在这个过程中,可以传递一个包含初始状态的对象作为参数[^1]。 ```javascript const { createApp } = Vue; // 定义一个简单的对象作为初始状态 const appState = { message: 'Hello from Vue!' }; // 调用 createApp 并传入该对象 const app = createApp({ data() { return appState; } }); // 将应用挂载到页面上的某个元素 app.mount('#app'); ``` 上述代码展示了如何利用 `createApp` 来设置全局可用的数据对象 `message`,并通过模板语法访问它。 #### 组件内部声明响应式对象 除了在整个应用层面共享的状态之外,在单个组件范围内也可以轻松地定义复杂的嵌套结构来表示业务逻辑所需的各种实体模型[^3]。 ```javascript export default { name: 'ExampleComponent', data() { return { user: { firstName: 'John', lastName: 'Doe' }, settings: { theme: 'dark', notificationsEnabled: true } }; } }; ``` 这里展示了一个典型的 Vue 组件配置方式,其中包含了两个独立但相互关联的部分——用户的个人信息以及偏好设定选项列表。 #### 动态更新已存在的对象属性值 得益于 Vue 的双向绑定机制,任何对这些响应型变量所做的更改都会自动反映到视图层面上去而无需手动触发渲染过程[^2]。 ```html <div id="example"> {{ fullName }} </div> <script> new Vue({ el: '#example', computed: { fullName() { return `${this.user.firstName} ${this.user.lastName}`; } }, data() { return { user: {firstName:'Jane',lastName:'Roe'} } } }); </script> ``` 此片段说明了即使原始 JSON 数据被修改后也能即时呈现最新版本的信息给最终用户看到的效果。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值