当前位置: 首页 > article >正文

VBA 64位API声明语句第008讲

跟我学VBA,我这里专注VBA, 授人以渔。我98年开始,从源码接触VBA已经20余年了,随着年龄的增长,越来越觉得有必要把这项技能传递给需要这项技术的职场人员。希望职场和数据打交道的朋友,都来学习VBA,利用VBA,起码可以提高自己的工作效率,可以有时间多陪陪父母,多陪陪家人,何乐而不为呢?我的教程一共九套,从入门开始一直讲到程序的分发,是学习利用VBA的实用教程。这份API资料是随高级教程赠送的.

这讲我们继续学习VBA 64位API声明语句第008讲,这些内容是MS的权威资料,看似枯燥,但对于想学习API函数的朋友是非常有用的。

【分享成果,随喜正能量】 102 我们不是圣人,所以常走错路,路,没有错,错的只是选择。如果,在一条走错的路上,别人都步履蹒跚,愁眉不展,而我们却依旧笑颜如花,坦然前行,久而久之,就成了错误路上的一道风景,亮丽了别人的眼睛,也愉悦了自己的心。当我们的心不同了,脚下的路也就不同了,阳光会明媚,伤痛也会远离。。

当学员学习到高级阶段,如果引用API,这个资料可以直接查到64位写法。大多数情况下我们是将低版本的程序文件升级到高版本,这时您就不必为如下的错误提示所困扰了:

AceCount As Long

AclBytesInUse As Long

AclBytesFree As Long

End Type

' //

' //

' SECURITY_DESCRIPTOR //

' //

' //

'

' Define the Security Descriptor and related data types.

' This is an opaque data structure.

'

' begin_ntddk begin_ntifs

'

' Current security descriptor revision value

'

Const SECURITY_DESCRIPTOR_REVISION = (1)

Const SECURITY_DESCRIPTOR_REVISION1 = (1)

' end_ntddk

'

' Minimum length, in bytes, needed to build a security descriptor

' (NOTE: This must manually be kept consistent with the)

' (sizeof(SECURITY_DESCRIPTOR) )

'

Const SECURITY_DESCRIPTOR_MIN_LENGTH = (20)

Const SE_OWNER_DEFAULTED = &H1

Const SE_GROUP_DEFAULTED = &H2

Const SE_DACL_PRESENT = &H4

Const SE_DACL_DEFAULTED = &H8

Const SE_SACL_PRESENT = &H10

Const SE_SACL_DEFAULTED = &H20

Const SE_SELF_RELATIVE = &H8000

'

' Where:

'

' SE_OWNER_DEFAULTED - This boolean flag, when set, indicates that the

' SID pointed to by the Owner field was provided by a

' defaulting mechanism rather than explicitly provided by the

' original provider of the security descriptor. This may

' affect the treatment of the SID with respect to inheritence

' of an owner.

'

' SE_GROUP_DEFAULTED - This boolean flag, when set, indicates that the

' SID in the Group field was provided by a defaulting mechanism

' rather than explicitly provided by the original provider of

' the security descriptor. This may affect the treatment of

' the SID with respect to inheritence of a primary group.

'

' SE_DACL_PRESENT - This boolean flag, when set, indicates that the

' security descriptor contains a discretionary ACL. If this

' flag is set and the Dacl field of the SECURITY_DESCRIPTOR is

' null, then a null ACL is explicitly being specified.

'

' SE_DACL_DEFAULTED - This boolean flag, when set, indicates that the

' ACL pointed to by the Dacl field was provided by a defaulting

' mechanism rather than explicitly provided by the original

' provider of the security descriptor. This may affect the

' treatment of the ACL with respect to inheritence of an ACL.

' This flag is ignored if the DaclPresent flag is not set.

'

' SE_SACL_PRESENT - This boolean flag, when set, indicates that the

' security descriptor contains a system ACL pointed to by the

' Sacl field. If this flag is set and the Sacl field of the

' SECURITY_DESCRIPTOR is null, then an empty (but present)

' ACL is being specified.

'

' SE_SACL_DEFAULTED - This boolean flag, when set, indicates that the

' ACL pointed to by the Sacl field was provided by a defaulting

' mechanism rather than explicitly provided by the original

' provider of the security descriptor. This may affect the

' treatment of the ACL with respect to inheritence of an ACL.

' This flag is ignored if the SaclPresent flag is not set.

'

' SE_SELF_RELATIVE - This boolean flag, when set, indicates that the

' security descriptor is in self-relative form. In this form,

' all fields of the security descriptor are contiguous in memory

' and all pointer fields are expressed as offsets from the

' beginning of the security descriptor. This form is useful

' for treating security descriptors as opaque data structures

' for transmission in communication protocol or for storage on

' secondary media.

'

'

'

' In general, this data structure should be treated opaquely to ensure future

' compatibility.

'

'

Type SECURITY_DESCRIPTOR

Revision As Byte

Sbz1 As Byte

Control As Integer

Owner As LongPtr

Group As LongPtr

Sacl As ACL

Dacl As ACL

End Type

' Where:

'

' Revision - Contains the revision level of the security

' descriptor. This allows this structure to be passed between

' systems or stored on disk even though it is expected to

' change in the future.

'

' Control - A set of flags which qualify the meaning of the

' security descriptor or individual fields of the security

' descriptor.

'

' Owner - is a pointer to an SID representing an object's owner.

' If this field is null, then no owner SID is present in the

' security descriptor. If the security descriptor is in

' self-relative form, then this field contains an offset to

' the SID, rather than a pointer.

'

' Group - is a pointer to an SID representing an object's primary

' group. If this field is null, then no primary group SID is

' present in the security descriptor. If the security descriptor

' is in self-relative form, then this field contains an offset to

' the SID, rather than a pointer.

'

' Sacl - is a pointer to a system ACL. This field value is only

' valid if the DaclPresent control flag is set. If the

' SaclPresent flag is set and this field is null, then a null

' ACL is specified. If the security descriptor is in

' self-relative form, then this field contains an offset to

' the ACL, rather than a pointer.

'

' Dacl - is a pointer to a discretionary ACL. This field value is

' only valid if the DaclPresent control flag is set. If the

' DaclPresent flag is set and this field is null, then a null

' ACL (unconditionally granting access) is specified. If the

' security descriptor is in self-relative form, then this field

' contains an offset to the ACL, rather than a pointer.

'

' //

' //

' Privilege Related Data Structures //

' //

' //

' Privilege attributes

'

Const SE_PRIVILEGE_ENABLED_BY_DEFAULT = &H1

Const SE_PRIVILEGE_ENABLED = &H2

Const SE_PRIVILEGE_USED_FOR_ACCESS = &H80000000

'

' Privilege Set Control flags

'

Const PRIVILEGE_SET_ALL_NECESSARY = (1)

'

我20多年的VBA实践经验,全部浓缩在下面的各个教程中:



相关文章:

VBA 64位API声明语句第008讲

跟我学VBA,我这里专注VBA, 授人以渔。我98年开始,从源码接触VBA已经20余年了,随着年龄的增长,越来越觉得有必要把这项技能传递给需要这项技术的职场人员。希望职场和数据打交道的朋友,都来学习VBA,利用VBA,起码可以提高…...

Linux信号——信号的保存(2)

关于core和term两种终止方式 core是什么? 将进程在内存中的核心数据(与调试有关)转存到磁盘中形成core,core.pid的文件。 core dump:核心转储。 core与term的区别: term只是普通的终止,而core终止方式还要…...

PyQt6实例_A股日数据维护工具_权息数据增量更新线程

目录 前置: 代码: 1 工作类 2 数据库交互 3 主界面启用子线程 视频: 前置: 1 本系列将以 “PyQt6实例_A股日数据维护工具” 开头放置在“PyQt6实例”专栏 专栏地址 https://blog.csdn.net/m0_37967652/category_12929760.h…...

【蓝桥杯嵌入式——学习笔记一】2016年第七届省赛真题重难点解析记录,闭坑指南(文末附完整代码)

在读题过程中发现本次使用的是串口2,需要配置串口2。 但在查看产品手册时发现PA14同时也是SWCLK。 所以在使用串口2时需要拔下跳线帽去连接CH340。 可能是用到串口2的缘故,在烧录时发现报了一个错误。这时我们要想烧录得按着复位键去点击烧录&#xff0c…...

基础常问 (概念、代码)

读源码 代码题 Void方法 ,也可以提前rerun;结束 RandomAccessFile类(随机访问文件) 在 Java 中,可以使用RandomAccessFile类来实现文件指针操作。RandomAccessFile提供了对文件内容的随机访问功能,它的文件指针可以通…...

大学生机器人比赛实战(一)综述篇

大学生机器人比赛实战 参加机器人比赛是大学生提升工程实践能力的绝佳机会。本指南将全面介绍如何从零开始准备华北五省机器人大赛、ROBOCAN、RoboMaster等主流机器人赛事,涵盖硬件设计、软件开发、算法实现和团队协作等关键知识。 一、比赛选择与准备策略 1.1 主…...

什么是宽带拨号?

宽带拨号(PPPoE拨号)是一种通过账号密码认证接入互联网的方式,常见于家庭宽带、企业专线等场景。用户需要通过路由器或电脑进行拨号连接,运营商验证身份后分配IP地址,才能正常上网。 1. 宽带拨号的工作原理 PPPoE协议&…...

J1 ResNet-50算法实战与解析

🍨 本文為🔗365天深度學習訓練營 中的學習紀錄博客🍖 原作者:K同学啊 | 接輔導、項目定制 一、理论知识储备 1. 残差网络的由来 ResNet主要解决了CNN在深度加深时的退化问题(梯度消失与梯度爆炸)。 虽然B…...

[MySQL初阶]MySQL(8)索引机制:下

标题:[MySQL初阶]MySQL(8)索引机制:下 水墨不写bug 文章目录 四、从问题到底层,从现象到本质1.为什么插入的数据默认排好序2.MySQL的Page(1)为什么选择用Page?(2&#x…...

Muduo网络库实现 [九] - EventLoopThread模块

目录 设计思路 类的设计 模块的实现 私有接口 公有接口 设计思路 我们说过一个EventLoop要绑定一个线程,未来该EventLoop所管理的所有的连接的操作都需要在这个EventLoop绑定的线程中进行,所以我们该如何实现将EventLoop和线程绑定呢?…...

Vim操作指令全解析

Vim是我们在Linux日常工作中不可或缺的文本编辑器。它强大的功能和高效的编辑方式可以极大提升工作效率。本文将全面解析Vim的各种操作指令,从基础操作到高级技巧。 一、Vim模式解析 Vim是一个模式化编辑器,理解不同模式是掌握Vim的关键: …...

《K230 从熟悉到...》识别机器码(AprilTag)

《K230 从熟悉到...》识别机器码(aprirltag) tag id 《庐山派 K230 从熟悉到...》 识别机器码(AprilTag) AprilTag是一种基于二维码的视觉标记系统,最早是由麻省理工学院(MIT)在2008年开发的。A…...

VMware ESXi:企业级虚拟化平台详解

VMware ESXi:企业级虚拟化平台详解 目录 什么是VMware ESXi? ESXi的发展历史 ESXi的核心特性 3.1 裸机架构(Type-1 Hypervisor) 3.2 轻量化与高性能 3.3 集中管理(vCenter集成) ESXi的架构与工作原理…...

使用 PyTorch 的 `optim.lr_scheduler.CosineAnnealingLR` 学习率调度器

使用 PyTorch 的 optim.lr_scheduler.CosineAnnealingLR 学习率调度器 在深度学习中,学习率(Learning Rate, LR)是影响模型训练效果的一个关键超参数。一个合适的学习率调度策略可以帮助模型更快地收敛,同时避免陷入局部最优或振荡。PyTorch 提供了多种学习率调度器,其中…...

栈和队列的概念

1.栈的概念 只允许在固定的一端进行插入和删除,进行数据的插入和数据的删除操作的一端数栈顶,另一端称为栈底。 栈中数据元素遵循后进先出LIFO (Last In First Out) 压栈:栈的插入。 出栈:栈的删除。出入数据在栈顶。 那么下面…...

常用的元素操作API

click 触发当前元素的点击事件 clear() 清空内容 sendKeys(...) 往文本框一类元素中写入内容 getTagName() 获取元素的的标签名 getAttribute(属性名) 根据属性名获取元素属性值 getText() 获取当前元素的文本值 isDisplayed() 查看元素是否显示 get(String url) 访…...

红日靶场一实操笔记

一,网络拓扑图 二,信息搜集 1.kali机地址:192.168.50.129 2.探测靶机 注:需要win7开启c盘里面的phpstudy的服务。 nmap -sV -Pn 192.168.50.128 或者扫 nmap -PO 192.168.50.0/24 可以看出来win7(ip为192.168.50.128)的靶机开…...

SpringBoot集成Redis 灵活使用 TypedTuple 和 DefaultTypedTuple 实现 Redis ZSet 的复杂操作

以下是 Spring Boot 集成 Redis 中 TypedTuple 和 DefaultTypedTuple 的详细使用说明&#xff0c;包含代码示例和场景说明&#xff1a; 1. 什么是 TypedTuple 和 DefaultTypedTuple&#xff1f; TypedTuple<T> 接口&#xff1a; 定义了 Redis 中有序集合&#xff08;ZSet…...

7-4 BCD解密

BCD数是用一个字节来表达两位十进制的数&#xff0c;每四个比特表示一位。所以如果一个BCD数的十六进制是0x12&#xff0c;它表达的就是十进制的12。但是小明没学过BCD&#xff0c;把所有的BCD数都当作二进制数转换成十进制输出了。于是BCD的0x12被输出成了十进制的18了&#x…...

Golang改进后的任务调度系统分析

以下是整合了所有改进点的完整代码实现: package mainimport ("bytes""context""fmt""io""log""net/http""sync""time""github.com/go-redis/redis/v8""github.com/robfig/…...

【目标检测】【深度学习】【Pytorch版本】YOLOV2模型算法详解

【目标检测】【深度学习】【Pytorch版本】YOLOV2模型算法详解 文章目录 【目标检测】【深度学习】【Pytorch版本】YOLOV2模型算法详解前言YOLOV2的模型结构YOLOV2模型的基本执行流程YOLOV2模型的网络参数YOLOV2模型的训练方式 YOLOV2的核心思想前向传播阶段反向传播阶段 总结 前…...

NineData云原生智能数据管理平台新功能发布|2025年3月版

本月发布 15 项更新&#xff0c;其中重点发布 3 项、功能优化 11 项、性能优化 1 项。 重点发布 基础服务 - MFA 多因子认证 新增 MFA 多因子认证&#xff0c;提升账号安全性。系统管理员开启后&#xff0c;所有组织成员需绑定认证器&#xff0c;登录时需输入动态验证码。 数…...

破局与赋能:信息系统战略规划方法论

信息系统战略规划是将组织的战略目标和发展规划转化为信息系统的战略目标和发展规划的过程&#xff0c;常见的方法有以下几种&#xff1a; 一、企业系统规划法&#xff08;BSP&#xff09; 1.基本概念&#xff1a;通过全面调查&#xff0c;分析企业信息需求&#xff0c;确定信…...

GLSL(OpenGL 着色器语言)基础语法

GLSL&#xff08;OpenGL 着色器语言&#xff09;基础语法 GLSL&#xff08;OpenGL Shading Language&#xff09;是 OpenGL 计算着色器的语言&#xff0c;语法类似于 C 语言&#xff0c;但提供了针对 GPU 的特殊功能&#xff0c;如向量运算和矩阵运算。 着色器的开头总是要声明…...

Redis基础知识-3

RedisTemplate对多种数据结构的操作 1. String类型 示例代码&#xff1a; // 保存数据 redisTemplate.opsForValue().set("user:1001", "John Doe"); // 设置键值对&#xff0c;无过期时间 redisTemplate.opsForValue().set("user:1002", &qu…...

Git Rebase 操作中丢失提交的恢复方法

背景介绍 在团队协作中,使用 Git 进行版本控制是常见实践。然而,有时在执行 git rebase 或者其他操作后,我们可能会发现自己的提交记录"消失"了,这往往让开发者感到恐慌。本文将介绍几种在 rebase 后恢复丢失提交的方法。 问题描述 当我们执行以下操作时,可能…...

【diffusers 进阶(十五)】dataset 工具,Parquet和Arrow 数据文件格式,load dataset 方法

系列文章目录 【diffusers 极速入门&#xff08;一&#xff09;】pipeline 实际调用的是什么&#xff1f; call 方法!【diffusers 极速入门&#xff08;二&#xff09;】如何得到扩散去噪的中间结果&#xff1f;Pipeline callbacks 管道回调函数【diffusers极速入门&#xff0…...

unity各个面板说明

游戏开发&#xff0c;unity各个面板说明 提示&#xff1a;帮帮志会陆续更新非常多的IT技术知识&#xff0c;希望分享的内容对您有用。本章分享的是Python基础语法。前后每一小节的内容是存在的有&#xff1a;学习and理解的关联性&#xff0c;希望对您有用~ unity简介-unity基础…...

游戏引擎学习第199天

回顾并发现我们可能破坏了某些东西 目前&#xff0c;我们的调试 UI 运行得相对顺利&#xff0c;可以创建可修改的调试变量&#xff0c;也可以插入分析器&#xff08;profiler&#xff09;等特殊视图组件&#xff0c;并进行一些交互操作。然而&#xff0c;在上一次结束时&#…...

Linux红帽:RHCSA认证知识讲解(十)使用 tar创建归档和压缩文件

Linux红帽&#xff1a;RHCSA认证知识讲解&#xff08;十&#xff09;使用 tar创建归档和压缩文件 前言一、归档与压缩的基本概念1.1 归档与压缩的区别 二、使用tar创建归档文件2.1 tar命令格式2.2 示例操作 三、使用tar进行压缩3.2 命令格式3.3 示例操作 前言 在红帽 Linux 系…...