句柄(HANDLE)的简单理解

什么是句柄

句柄是一个整数,单独的看它只是数字。

但这个整数是进程句柄表数组的下标,有了这个下标,操作系统就可以找到其索引的数据结构,并能找到数据结构里面的指针,然后根据这个指针获取内核里的某个对象。

在这里插入图片描述

句柄的本质理解

操作系统内核中有一个全局句柄表(如上图)。每个进程有自己的一个句柄表,是一个数据结构组成的数组,每个数据结构包含一个指向内核对象的指针、访问掩码、继承标识等。

  1. 句柄是进程句柄表数组的下标。
  2. 在32位系统中,句柄是一个32位值。64位系统中则是64位值。
  3. 应用程序调用创建内核对象的API函数后,该API函数会返回一个句柄以标识操作系统内核所创建的内核对象。这个句柄可以由进程的任何线程使用。
  4. 句柄只读
  5. 指针可以当句柄,句柄不一定都是指针。

为什么需要句柄

  1. 指针权力太大了,如果是内核对象,用指针风险很大。
  2. HANDLE是固定不变的,但是对象的地址会变(由于虚拟存储机制),HANDLE可以用来记录对象的最新地址。(我每天都想去上数学课,但是数学课教室总变,但是我可以每天都问数学老师,因为数学老师不会变,这个数学老师就是句柄)
  • 31
    点赞
  • 75
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你好,我可以回答你的问题。 要使用C语言编写一个数据库代码,你需要使用C语言的数据库API(应用程序接口)。常用的数据库API包括ODBC(开放式数据库连接)、JDBC(Java数据库连接)和ADO.NET(.NET数据库连接)等。 以下是使用ODBC API编写数据库代码的一些基本步骤: 1. 在代码中包含ODBC API头文件 2. 连接到数据库 3. 执行SQL查询或命令 4. 处理结果集或更新数据库 5. 断开与数据库的连接 这里有一个简单的示例代码,可以帮助你更好地理解如何使用C语言编写数据库代码: ``` #include <stdio.h> #include <stdlib.h> #include <sql.h> #include <sqlext.h> int main() { SQLHENV env; // 环境句柄 SQLHDBC dbc; // 数据库连接句柄 SQLHSTMT stmt; // 语句句柄 SQLRETURN ret; // 返回值 // 分配环境句柄 ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &env); // 设置环境句柄属性 ret = SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, 0); // 分配连接句柄 ret = SQLAllocHandle(SQL_HANDLE_DBC, env, &dbc); // 连接到数据库 ret = SQLConnect(dbc, "dsn_name", SQL_NTS, "username", SQL_NTS, "password", SQL_NTS); // 分配语句句柄 ret = SQLAllocHandle(SQL_HANDLE_STMT, dbc, &stmt); // 执行查询语句 ret = SQLExecDirect(stmt, "SELECT * FROM table_name", SQL_NTS); // 处理结果集 SQLCHAR name[50]; while (SQLFetch(stmt) == SQL_SUCCESS) { SQLGetData(stmt, 1, SQL_C_CHAR, name, sizeof(name), NULL); printf("%s\n", name); } // 释放语句句柄 ret = SQLFreeHandle(SQL_HANDLE_STMT, stmt); // 断开连接 ret = SQLDisconnect(dbc); // 释放连接句柄 ret = SQLFreeHandle(SQL_HANDLE_DBC, dbc); // 释放环境句柄 ret = SQLFreeHandle(SQL_HANDLE_ENV, env); return 0; } ``` 需要注意的是,这只是一个简单的示例代码,实际的数据库代码可能更加复杂。同时,不同的数据库API也有不同的用法和语法,需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值