Windows核心编程 注册表

news2025/4/9 1:30:45

目录

注册表概述

打开关闭注册表

创建删除子健

查询写入删除键值

子健和键值的枚举

常用注册表操作


注册表概述

注册表是Windows操作系统、硬件设备以及客户应用程序得以正常运行和保存设置的核心"数据库",也可以说是一个非常巨大的树状分层结构的数据库系统

注册表是一个存储计算机配置信息的数据库,用于存储计算机上的硬件、安装的软件、系统设置以及用户账户配置等重要信息。对注册表的编辑不当可能会影响计算机的正常运行。应用程序可以调用API函数来对注册表进行增、删等操作。

注册表记录了用户安装在计算机上的软件和每个程序的相互关联信息,它包括了计算机的硬件配置,包括自动配置的即插即用的设备和已有的各种设备说明、状态属性以及各种状态信息和数据。利用一个功能强大的注册表数据库来统一集中地管理系统硬件设施、软件配置等信息,从而方便了管理,增强了系统的稳定性

早期的注册表以ini为扩展名的文本文件的配置文件。

自Windows95操作系统开始,注册表真正成为Windows用户经常接触的内容,并在其后的操作系统中继续沿用:

  • 注册表数据库由多个文件组成
  • Windows提供了注册表编辑器

与INI文件不同的是:

  • 注册表采用了二进制形式登录数据;
  • 注册表支持子键,各级子关键字都有自己的“键值”;
  • 注册表中的键值项可以包含可执行代码,而不是简单的字串;
  • 在同一台计算机上,注册表可以存储多个用户的特性。

特点:

  • 注册表允许对硬件、系统参数、应用程序和设备驱动程序进行跟踪配置,这使得修改某些设置后不用重新启动成为可能。
  • 注册表中登录的硬件部分数据可以支持高版本Windows的即插即用特性。当Windows检测到机器上的新设备时,就把有关数据保存到注册表中,另外,还可以避免新设备与原有设备之间的资源冲突。
  • 管理人员和用户通过注册表可以在网络上检查系统的配置和设置,使得远程管理得以实现。

注册表查看:Win + R 运行 regedit 。可以改动的区域 - HKEY_CURRENT_USER - SOFTWARE

注册表以树状结构进行呈现。

注册表根键说明:

值:

  • 字符串值(REG_Sz):固定长度的文本字符串
  • 二进制值(REG_BINARY):原始二进制数据。多数硬件组件信息都以二进制数据存储
  • DWORD值(REG_DWORD):数据由4字节长的数表示。设备驱动程序和服务的很多参数都是这种类型
  • QWORD值(REG_QwORD):数据由8字节长的数表示
  • 多字符串值(REG_MULTl_SZ):多重字符串。包含列表或多值的值通常为该类型
  • 可扩充字符串值(REG_EXPAND_Z):长度可变的数据串。该数据类型包含在程序或服务使用该数据时解析的变量

打开关闭注册表

RegOpenKeyEx           打开注册表

RegOpenKeyExA是Windows API函数之一,用于打开一个指定的注册表项。

LSTATUS RegOpenKeyExA(
  HKEY   hKey,
  LPCSTR lpSubKey,
  DWORD  ulOptions,
  REGSAM samDesired,
  PHKEY  phkResult
);

下面是对该函数参数的解释:

  • hKey:表示要打开的注册表项的父项句柄。常见的父项句柄包括HKEY_LOCAL_MACHINEHKEY_CURRENT_USER等,可以使用这些常量来表示。

  • lpSubKey:表示相对于父项的子项路径。字符串类型,使用 ANSI 编码。

  • ulOptions:指定打开注册表项的选项。可以使用零或者REG_OPTION_NON_VOLATILE(非易失性注册表项)。

  • samDesired:指定打开注册表项时的访问权限。使用KEY_READKEY_WRITE等常量来表示。

  • phkResult:指向一个HKEY类型的指针,用于接收打开的注册表项的句柄。

函数返回值:返回一个LSTATUS类型的值,代表函数执行的结果状态码。如果函数成功执行,返回值将是ERROR_SUCCESS

RegCloseKey   关闭已打开的注册表句柄

LSTATUS RegCloseKey(
  HKEY hKey
);

hKey:要关闭的键句柄,即RegOpenKeyExphkResult

测试代码

#include <Windows.h>
#include <iostream>

int main()
{
    // 打开HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion注册表项
    HKEY hKey;
    LPCSTR lpSubKey = "Software\\Microsoft\\Windows\\CurrentVersion";

    LSTATUS result = RegOpenKeyExA(HKEY_CURRENT_USER, lpSubKey, 0, KEY_READ, &hKey);
    if (result == ERROR_SUCCESS)
    {
        std::cout << "成功打开注册表项!" << std::endl;

        // 在这里可以使用其他注册表API函数来读取或修改注册表项的键值对

        // 关闭注册表项句柄
        RegCloseKey(hKey);
    }
    else
    {
        std::cout << "无法打开注册表项,错误代码:" << result << std::endl;
    }

    return 0;
}

创建删除子健

RegCreateKeyEx         创建一个子键

RegCreateKeyExA是Windows API函数之一,用于创建或打开一个指定的注册表项。

LSTATUS RegCreateKeyExA(
  HKEY                        hKey,
  LPCSTR                      lpSubKey,
  DWORD                       Reserved,
  LPSTR                       lpClass,
  DWORD                       dwOptions,
  REGSAM                      samDesired,
  const LPSECURITY_ATTRIBUTES lpSecurityAttributes,
  PHKEY                       phkResult,
  LPDWORD                     lpdwDisposition
);

下面是对该函数参数的解释:

  • hKey:表示要创建或打开的注册表项的父项句柄。常见的父项句柄包括HKEY_LOCAL_MACHINEHKEY_CURRENT_USER等,可以使用这些常量来表示。

  • lpSubKey:表示相对于父项的子项路径。字符串类型,使用 ANSI 编码。

  • Reserved:保留参数,必须为零。

  • lpClass:为新创建的注册表项指定一个类别。该参数可以为NULL。

  • dwOptions:指定创建或打开注册表项时的选项。

  • samDesired:指定创建或打开注册表项时的访问权限。

  • lpSecurityAttributes:指定注册表项的安全性设置。可以为NULL。

  • phkResult:指向一个HKEY类型的指针,用于接收创建或打开的注册表项的句柄。

  • lpdwDisposition:指定一个DWORD类型的指针,用于接收返回的操作结果信息。

函数返回值:返回一个LSTATUS类型的值,代表函数执行的结果状态码。如果函数成功执行,返回值将是ERROR_SUCCESS

使用RegCreateKeyExA函数可以创建或打开一个注册表项后,可以使用其他注册表API函数来读取或修改注册表项的键值对。

RegDeleteKey    删除子键

LSTATUS RegDeleteKeyA(
  HKEY   hKey,
  LPCSTR lpSubKey
);

测试代码

#include <Windows.h>
#include <iostream>

int main()
{
    // 创建或打开HKEY_CURRENT_USER\Software\MyApp注册表项
    HKEY hKey;
    LPCSTR lpSubKey = "Software\\MyApp";

    LSTATUS result = RegCreateKeyExA(HKEY_CURRENT_USER, lpSubKey, 0, NULL, 0, KEY_ALL_ACCESS, NULL, &hKey, NULL);
    if (result == ERROR_SUCCESS)
    {
        std::cout << "成功创建或打开注册表项!" << std::endl;

        // 在这里可以使用其他注册表API函数来读取或修改注册表项的键值对

        // 关闭注册表项句柄
        RegCloseKey(hKey);
    }
    else
    {
        std::cout << "无法创建或打开注册表项,错误代码:" << result << std::endl;
    }

    return 0;
}

查询写入删除键值

RegQueryValueEx   读取键名称中的数据或查询键名称的属性

LSTATUS RegQueryValueExA(
  HKEY    hKey,
  LPCSTR  lpValueName,
  LPDWORD lpReserved,
  LPDWORD lpType,
  LPBYTE  lpData,
  LPDWORD lpcbData
);

下面是对该函数参数的解释:

  • hKey:表示要查询的注册表项的句柄。

  • lpValueName:表示要查询的注册表项中的值的名称。字符串类型,使用 ANSI 编码。

  • lpReserved:保留参数,必须为NULL。

  • lpType:指向一个DWORD类型的指针,用于接收查询的值的数据类型。

  • lpData:指向一个缓冲区,用于接收查询到的值的数据。

  • lpcbData:指向一个DWORD类型的指针,用于指定缓冲区的大小,并返回实际写入缓冲区的字节数。

函数返回值:返回一个LSTATUS类型的值,代表函数执行的结果状态码。如果函数成功执行,返回值将是ERROR_SUCCESS

RegSetValueEx         写入键值项

LSTATUS RegSetValueExA(
  HKEY       hKey,
  LPCSTR     lpValueName,
  DWORD      Reserved,
  DWORD      dwType,
  const BYTE *lpData,
  DWORD      cbData
);

下面是对该函数参数的解释:

  • hKey:表示要设置的注册表项的句柄。

  • lpValueName:表示要设置的注册表项中的值的名称。字符串类型,使用 ANSI 编码。

  • Reserved:保留参数,必须为0。

  • dwType:表示要设置的值的数据类型。可以使用预定义的常量,如REG_SZ表示字符串类型。

  • lpData:指向要设置的数据的缓冲区的指针。

  • cbData:表示要设置的数据的大小,以字节为单位。

函数返回值:返回一个LSTATUS类型的值,代表函数执行的结果状态码。如果函数成功执行,返回值将是ERROR_SUCCESS

使用RegSetValueExA函数可以设置注册表项中指定值的数据。通过指定dwType参数来确定数据的类型,并将要设置的数据存储在lpData缓冲区中

RegDeleteValue      删除键值项

LSTATUS RegDeleteValueA(
  HKEY   hKey,
  LPCSTR lpValueName
);

下面是对该函数参数的解释:

  • hKey:表示要删除值的注册表项的句柄。

  • lpValueName:表示要删除的注册表项中的值的名称。字符串类型,使用 ANSI 编码。

函数返回值:返回一个LSTATUS类型的值,代表函数执行的结果状态码。如果函数成功执行,返回值将是ERROR_SUCCESS

使用RegDeleteValueA函数可以删除注册表项中指定的值。通过指定hKey参数来确定要删除值的注册表项的位置,通过指定lpValueName参数来指定要删除的值的名称。

测试代码

#include <Windows.h>
#include <iostream>

int main() {
    // 打开注册表项
    HKEY hKey;
    if (RegOpenKeyExA(HKEY_CURRENT_USER, "Software\\MyApp", 0, KEY_ALL_ACCESS, &hKey) != ERROR_SUCCESS) {
        std::cout << "Failed to open registry key." << std::endl;
        return 1;
    }

    // 查询注册表项中的值
    DWORD dwType;
    DWORD dwValue;
    DWORD dwSize = sizeof(DWORD);
    if (RegQueryValueExA(hKey, "MyValue", nullptr, &dwType, reinterpret_cast<LPBYTE>(&dwValue), &dwSize) == ERROR_SUCCESS) {
        std::cout << "Value found: " << dwValue << std::endl;
    } else {
        std::cout << "Value not found." << std::endl;
    }

    // 设置注册表项中的值
    DWORD dwNewValue = 123;
    if (RegSetValueExA(hKey, "MyValue", 0, REG_DWORD, reinterpret_cast<const BYTE*>(&dwNewValue), sizeof(DWORD)) == ERROR_SUCCESS) {
        std::cout << "Value set successfully." << std::endl;
    } else {
        std::cout << "Failed to set value." << std::endl;
    }

    // 删除注册表项中的值
    if (RegDeleteValueA(hKey, "MyValue") == ERROR_SUCCESS) {
        std::cout << "Value deleted successfully." << std::endl;
    } else {
        std::cout << "Failed to delete value." << std::endl;
    }

    // 关闭注册表项
    RegCloseKey(hKey);

    return 0;
}

子健和键值的枚举

RegEnumKeyEx         子键枚举函数

LSTATUS RegEnumKeyExA(
  HKEY      hKey,
  DWORD     dwIndex,
  LPSTR     lpName,
  LPDWORD   lpcchName,
  LPDWORD   lpReserved,
  LPSTR     lpClass,
  LPDWORD   lpcchClass,
  PFILETIME lpftLastWriteTime
);

下面是对该函数参数的解释:

  • hKey:表示要枚举子项的注册表项的句柄。

  • dwIndex:表示要枚举的子项的索引。使用0开始的索引。

  • lpName:指向一个缓冲区,用于存储返回的子项名称。

  • lpcchName:指向一个变量,用于指定lpName缓冲区的大小。在调用函数之前,应将其设置为缓冲区大小(以字节为单位),并在函数调用后,它将被设置为实际写入到lpName缓冲区中的字节数(不包括终止null字符)。

  • lpReserved:保留参数,必须为NULL。

  • lpClass:指向一个缓冲区,用于存储返回的子项的类名(可选)。可以将该参数设置为NULL,如果不需要子项的类名。

  • lpcchClass:指向一个变量,用于指定lpClass缓冲区的大小。在函数调用之前,应将其设置为缓冲区大小(以字节为单位),并在函数调用后,它将被设置为实际写入到lpClass缓冲区中的字节数(不包括终止null字符)。

  • lpftLastWriteTime:指向一个FILETIME结构体的指针,用于存储子项的最后修改时间。

函数返回值:返回一个LSTATUS类型的值,代表函数执行的结果状态码。如果函数成功执行,返回值将是ERROR_SUCCESS

使用RegEnumKeyExA函数可以枚举注册表项中的子项。通过指定hKey参数来确定要枚举子项的注册表项的位置,通过指定dwIndex参数来指定要枚举的子项的索引,然后将子项名称存储在lpName缓冲区中。

RegEnumValue     枚举键值

LSTATUS RegEnumValueA(
  HKEY    hKey,
  DWORD   dwIndex,
  LPSTR   lpValueName,
  LPDWORD lpcchValueName,
  LPDWORD lpReserved,
  LPDWORD lpType,
  LPBYTE  lpData,
  LPDWORD lpcbData
);

下面是对该函数参数的解释:

  • hKey:表示要枚举值的注册表项的句柄。

  • dwIndex:表示要枚举的值的索引。使用0开始的索引。

  • lpValueName:指向一个缓冲区,用于存储返回的值的名称。

  • lpcchValueName:指向一个变量,用于指定lpValueName缓冲区的大小。在调用函数之前,应将其设置为缓冲区大小(以字节为单位),并在函数调用后,它将被设置为实际写入到lpValueName缓冲区中的字节数(不包括终止null字符)。

  • lpReserved:保留参数,必须为NULL。

  • lpType:指向一个变量,用于接收值的类型。可以将该参数设置为NULL,如果不需要值的类型。

  • lpData:指向一个缓冲区,用于存储值的数据。

  • lpcbData:指向一个变量,用于指定lpData缓冲区的大小。在函数调用之前,应将其设置为缓冲区大小(以字节为单位),并在函数调用后,它将被设置为实际写入到lpData缓冲区中的字节数。

函数返回值:返回一个LSTATUS类型的值,代表函数执行的结果状态码。如果函数成功执行,返回值将是ERROR_SUCCESS

使用RegEnumValueA函数可以枚举注册表项中的值。通过指定hKey参数来确定要枚举值的注册表项的位置,通过指定dwIndex参数来指定要枚举的值的索引,然后将值的名称存储在lpValueName缓冲区中,并将值的数据存储在lpData缓冲区中。

测试代码


#include <iostream>
#include <windows.h>

using namespace std

void EnumValue()
{
	// 遍历HKEY_CURRENT_USER\SOFTWARE\360se6

	// 打开键
	HKEY hKey360se6  = NULL;
	LONG lRet  = RegCreateKey(HKEY_CURRENT_USER, "SOFTWARE\\360se6", &hKey36
		0se6);
	if (lRet  != ERROR_SUCCESS)
	{
		MessageBox(NULL, "打开结点失败", "提示", MB_OK);
		return;
	}

	// 获取值的个数
	DWORD dwValCnt  = 0;
	lRet  = RegQueryInfoKey(hKey360se6, NULL, NULL, NULL, NULL, NULL, NULL,
		&dwValCnt, NULL, NULL, NULL, NULL);

	// 遍历值
	for (DWORD dwIdx  = 0; dwIdx  < dwValCnt; dwIdx++)
	{
		char szBuff[MAXWORD] = {};
		DWORD dwNameLen  = sizeof(szBuff);
		RegEnumValue(hKey360se6, dwIdx, szBuff, &dwNameLen, NULL, NULL, NULL, NULL);
		cout  << szBuff  << endl;
	}

	RegCloseKey(hKey360se6);
}

int main()
{
	// 枚举值
	EnumValue();

	// 创建结点(项)
	HKEY hKey720  = NULL;
	LONG lRet  = RegCreateKey(HKEY_CURRENT_USER, "SOFTWARE\\360\\720", &hKey
		720);
	if (lRet  != ERROR_SUCCESS)
	{
		MessageBox(NULL, "创建结点失败", "提示", MB_OK);
		return 0;
	}

	// 删除key‐value对
		lRet  = RegDeleteValue(hKey720, "测试");
	if (lRet  != ERROR_SUCCESS)
	{
		MessageBox(NULL, "删除key‐value对失败", "提示", MB_OK);
		return 0;
	}

	 // 删除指定键
		lRet  = RegDeleteKey(HKEY_CURRENT_USER, "SOFTWARE\\360\\720");
	if (lRet  != ERROR_SUCCESS)
	{
		MessageBox(NULL, "删除子键720失败", "提示", MB_OK);
		return 0;
	}

	// 添加新的key‐value对
	char szBuff[] = { "hello register" };
	lRet  = RegSetValueEx(hKey720, "测试", 0, REG_SZ, (PBYTE)szBuff, sizeof(szBuff));
	if (lRet  != ERROR_SUCCESS)
	{
		MessageBox(NULL, "添加新的key‐value对失败", "提示", MB_OK);
		return 0;
	}

	DWORD dwVal  = 0x12345678;
	lRet  = RegSetValueEx(hKey720, "数值", 0, REG_DWORD, (PBYTE)&dwVal, sizeo
		f(dwVal));
	if (lRet  != ERROR_SUCCESS)
	{
		MessageBox(NULL, "添加新的key‐value对失败", "提示", MB_OK);
		return 0;
	}

	RegCloseKey(hKey720);

	std::cout  << "Hello World!\n";

	return 0;
}

常用注册表操作

禁用快捷菜单的”发送到“菜单项

打开计算机\HKEY_CLASSES_ROOT\AllFilesystemObjects\shellex\ContextMenuHandlers\SendTo 删除默认值。如果要恢复,将默认值设置为 {7BA4C740-9E81-11CF-99D3-00AA004AE837}

删除快捷方式箭头

打开计算机\HKEY_CLASSES_ROOT\lnkfile,删除IsShortcut键值

隐藏桌面图标

打开计算机\HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\Explorer,新建名称为NoSetFolders键值,并设置数据为1

禁止访问任务管理器

打开计算机\HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\System,修改DisableTaskmgr键值的数据为1。如果没有DisableTaskmgr键值,就创建一个。

在桌面显示Windows版本

打开计算机\HKEY_CURRENT_USER\Control Panel\Desktop,修改PaintDesktopVersion键值的数据为1

隐藏”重新启用“、”睡眠”和“休眠”命令

打开计算机\HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\Explorer,新建一个NoClose键值,并设置数据为1

禁用计算机中的USB端口

打开计算机\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\USBSTOR,修改Start键值数据为4

配置开机启动项

计算机\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1268123.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

浅学指针(3)

系列文章目录 文章目录 系列文章目录前言系列文章目录前言1. 字符指针变量2. 数组指针变量那数组指针变量应该是&#xff1a;存放的应该是数组的地址&#xff0c;能够指向数组的指针变量。2.2 数组指针变量怎么初始化总结&#xff1a;函数名就是地址&#xff0c;&函数名和直…

YOLOv8改进 | 2023 | DWRSeg扩张式残差助力小目标检测 (附修改后的C2f+Bottleneck)

论文地址&#xff1a;官方论文地址 代码地址&#xff1a;该代码目前还未开源&#xff0c;我根据论文内容进行了复现内容在文章末尾。 一、本文介绍 本文内容给大家带来的DWRSeg中的DWR模块来改进YOLOv8中的C2f和Bottleneck模块&#xff0c;主要针对的是小目标检测&#xff0c…

深圳市东星制冷机电受邀莅临2024国际生物发酵展,济南与您相约

深圳市东星制冷机电有限公司受邀莅临2024国际生物发酵展&#xff0c;济南3月5-7日与您相约&#xff01; 展位号&#xff1a;1号馆A53 深圳市东星制冷机电有限公司&#xff0c;&#xff08;东星集团&#xff09;是一家专业生产制冷设备的外商独资大型集团企业,拥有30多年的生产…

虚拟机安装centos7系统后网络配置

一.桥接网络和nat网络的区别1&#xff0c;桥接模式&#xff08;如果外部访问虚拟机&#xff0c;最好选这个&#xff09; 通过使用物理机网卡 具有单独ip,但是需要手动配置。 在bridged模式下&#xff0c;VMWare虚拟出来的操作系统就像是局域网中的一台独立的主机&#xff0c;它…

react-route-dom 实现简单的嵌套路由

最终效果 点击 to test1 点击to test2 > to test21 点击to test2 > to test22 代码如下 path: "page",element: <父组件 />,children: [{ path: "test1", element: <Test1 /> },{path: "test2",element: <Test2 />…

软件测试测试文档的编写和阅读

在软件测试中的流程中&#xff0c;测试文档也是一个重要的流程&#xff0c;所以测试人员也需要学习测试文档的编写和阅读。 一、定义&#xff1a; 测试文档&#xff08;Testing Documentation&#xff09;记录和描述了整个测试流程&#xff0c;它是整个测试活动中非常重要的文…

BIO、NIO、selector、Netty代码Demo示例

文章目录 &#xff08;一&#xff09;BIO&#xff08;Blocking I/O 阻塞I/O&#xff09;&#xff08;二&#xff09;NIO&#xff08;Non-Blocking I/O 非阻塞I/O&#xff09;&#xff08;三&#xff09;IO多路复用--Selector&#xff08;四&#xff09;Netty &#xff08;一&am…

翻译求职简历,如何做效果好?

随着国内经济的蓬勃发展&#xff0c;众多求职者都渴望能在外企寻得一席之地。而一份精彩绝伦的外文简历&#xff0c;往往能瞬间提高求职者的成功率。但如何才能做好这份简历翻译呢&#xff1f; 其实&#xff0c;简历翻译绝非简单的中英文对照。不同国家有着各自独特的语言表达方…

【海思SS528 | VDEC】MPP媒体处理软件V5.0 | VDEC的使用总结

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

操作系统 day14(进程同步、进程互斥、互斥的代码实现、互斥的硬件实现、互斥锁)

进程同步 概念 进程的异步性体现在&#xff0c;例如&#xff1a;当有I/O操作时&#xff0c;进程需要等待I/O操作&#xff0c;而每个I/O操作又是不同的&#xff0c;所以进程没有一个固定的顺序&#xff0c;固定的时间来执行&#xff0c;而这体现了进程的异步性。 进程互斥 …

【Java】泛型的简单使用

文章目录 一、包装类1.基本数据类型和对应的包装类2.自动装箱和自动拆箱3.手动装箱和手动拆箱 二、什么是泛型三、泛型的使用四、裸类型&#xff08;Raw Type&#xff09;五、泛型是如何编译的六、泛型的上界七、泛型方法总结 一、包装类 在了解泛型之前我们先了解什么是包装类…

【Java学习笔记】75 - 算法优化入门 - 马踏棋盘问题

一、意义 1.算法是程序的灵魂&#xff0c;为什么有些程序可以在海量数据计算时&#xff0c;依然保持高速计算? 2.拿老韩实际工作经历来说&#xff0c;在Unix下开发服务器程序&#xff0c;功能是要支持上千万人同时在线&#xff0c;在上线前&#xff0c; 做内测&#xff0c;一…

FPGA设计时序约束十、others类约束之Set_Disable_Timing

目录 一、序言 二、Set Disable Timing 2.1 基本概念 2.2 设置界面 2.3 命令语法 2.4 命令示例 三、工程示例 四、参考资料 一、序言 在Vivado的时序约束窗口中&#xff0c;存在一类特殊的约束&#xff0c;划分在others目录下&#xff0c;可用于设置忽略或修改默认的时…

一文学会Aiohttp

一、什么是aiohttp库 aiohttp库官网&#xff1a;https://docs.aiohttp.org/en/stable/ aiohttp是一个Python的HTTP客户端/服务器框架&#xff0c;它基于asyncio库实现异步编程模型&#xff0c;可以支持高性能和高并发的HTTP通信。aiohttp用于编写异步的Web服务器、Web应用程序…

【hacker送书第5期】SQL Server从入门到精通(第5版)

第5期图书推荐 内容简介作者简介图书目录参与方式 内容简介 SQL Server从入门到精通&#xff08;第5版&#xff09;》从初学者角度出发&#xff0c;通过通俗易懂的语言、丰富多彩的实例&#xff0c;详细介绍了SQL Server开发所必需的各方面技术。全书分为4篇共19章&#xff0c;…

Linux下文件操作函数

一.常见IO函数 fopen fclose fread fwrite fseek fflush fopen 运行过程 &#xff1a;打开文件 写入数据 数据写到缓冲区 关闭文件后 将数据刷新入磁盘 1.fopen 返回文件类型的结构体的指针 包括三部分 1).文件描述符&#xff08;整形值 索引到磁盘文件&#xff09;…

【重磅合作】九章云极DataCanvas公司与生态伙伴强强联手,构建人工智能强生态!

11月21日&#xff0c;在「筑基赋能 智向未来」九章云极DataCanvas大模型系列成果发布会上&#xff0c;九章云极DataCanvas公司与人工智能产业链上下游合作伙伴广东民营投资股份有限公司&#xff08;以下简称“粤民投”&#xff09;、西藏赛富合银投资有限公司&#xff08;以下简…

网络入门---网络编程预备知识

目录标题 ifconfigip地址和mac地址的区别端口号pid和端口号UDP和TCP的初步了解网络字节序socket套接字 ifconfig 通过指令ifconfig便可以查看到两个网络接口&#xff1a; 我们当前使用的是一个linux服务器并是一个终端设备&#xff0c;所以他只需要一个接口用来入网即可&…

重排链表,剑指offerII 26,力扣 120

目录 力扣题目地址&#xff1a; 题目&#xff1a; 那我们直接看题解吧&#xff1a; 解题方法&#xff1a; 难度分析&#xff1a; 审题目事例提示&#xff1a; 解题分析&#xff1a; 解题思路&#xff1a; 解题补充&#xff1a; 力扣题目地址&#xff1a; 143. 重排链表 - 力扣&…

树与二叉树堆:堆的意义

目录 堆的意义&#xff1a; 第一是堆的排序&#xff0c;第二是堆的top k 排行问题 堆的 top k 排行问题&#xff1a; 面对大量数据的top k 问题&#xff1a; 堆排序的实现&#xff1a;——以升序为例 方法一 交换首尾&#xff1a; 建立大堆&#xff1a; 根结点尾结点的…