关于注册表函数RegEnumValue()如何正确使用?(请确实使用过的高手解答,我问多次,却无人解答!!)

s6w6k 2004-07-10 01:12:10
注册表函数RegEnumValue()如何正确使用?
我是这样用的:
int num=0;
char str[20];
DWORD th=20;
DWORD type;
char strv[255];
DWORD vl=254;
DWORD suc;
::RegOpenkey(……);
suc=::RegEnumValue(hkey,(dword)num,str,NULL,&type,strv,&vl);
一运行,说变量有错,(我在vb6.0中使用可以,怎么在vc里却不下?)
请高手解答!!谢谢!


...全文
1834 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
yyfa6 2004-09-29
  • 打赏
  • 举报
回复
mark
pomelowu 2004-07-26
  • 打赏
  • 举报
回复
不好意思,才看到你的回帖
这四个语句,前两个,开辟内存空间,用于保存Key的名字和数据,
后两句用来把刚才开辟的空间全部清零。
s6w6k 2004-07-14
  • 打赏
  • 举报
回复
pomelowu(羽战士):今天编译成功!!
本人是初学者,有几点不明之处,请给予指点!
tcKeyName = new TCHAR[lLongestKeyNameLen];
 pbbinKeyData = new BYTE[lLongestDataLen];
memset(pbbinKeyData, 0, lLongestDataLen);
  memset(tcKeyName, 0, lLongestKeyNameLen);
尤其以上4句,是起什么作用???
s6w6k 2004-07-13
  • 打赏
  • 举报
回复
怎么没有人回答??帮解决燃眉之急!
s6w6k 2004-07-12
  • 打赏
  • 举报
回复
我的例子也有,我以前用vb6.0编写过注册表编辑器,现想改用vc编写,我感到vc有时比较繁琐,难.
我想搜索HKEY_CURRENT_USER\Control Panel\\desktop下的所有项名称,放在例表里,代码如下:
int index=0;
long lresult=0;
char valuename[254];
DWORD dwcvaluename=254;
CString data;
valuename[0]='\0';
DWORD dwtype;
DWORD dwcount =254;
::RegOpenKey(HKEY_CURRENT_USER,"Control Panel\\desktop",&hkey);
CListBox *pListBox=(CListBox*)GetDlgItem(IDC_LIST1);
do {

lresult=RegEnumValue(hkey,index,valuename,&dwcvaluename,NULL,&dwtype,NULL,&dwcount);

pListBox->AddString(valuename);
index++;
}
while (lresult == ERROR_SUCCESS);
RegCloseKey(hkey);
}

出现的现象是:查到index为5时,lresult就不能正确,index为4时,valuename的值,
即获取的项名少几个字母,
如果被搜索的项名称(valuename)是一个字母,或项的名称是文字"1"或"2"这样的,valuename就
是空的.

pomelowu 2004-07-11
  • 打赏
  • 举报
回复
呵呵~~我贴的那部分程序的时候把全角的空格和全角的符号替换掉就可以用了

主要是给你一个怎么用的例子。:)
s6w6k 2004-07-11
  • 打赏
  • 举报
回复
win98+vc6
chui168的可以运行!!
pomelowu(羽战士):编译时出错为:error C2018: unknown character '0xa1',有23个.
但vchui168运行时,查到index为5时,lresult就不能正确,index为4时,valuename的值,
即获取的项名少几个字母,
有那位好心的高手,帮帮忙,救我出水火,必有厚谢!!
chui168 2004-07-11
  • 打赏
  • 举报
回复
long index=0;
long lresult=0;
char valuename[254];
dword dwcvaluename=254;
dword dwtype;
dword dwcount=254;
cstring data;
lresult=RegEnumValue(hkey,index,valuename,&dwcvaluename,null,&dwtype,null,&dwcount);
这是我自己用过的代码,没错!!!
pomelowu 2004-07-10
  • 打赏
  • 举报
回复
给段例子给你吧:

void CRegExplorerView::EnumerateValues(HKEY hKey, LPCTSTR cstrKey)
{
 static HKEY hLastKey = hKey;
 LONG lResult;
 DWORD dwIndex = 0;
 HKEY hCurKey = hKey;
 DWORD dwKeyType;
 DWORD dwKeyDataLength, dwKeyNameLen;
 LPBYTE pbbinKeyData = NULL;
 TCHAR *tcKeyName = NULL;
 TCHAR tcDataType[1024] = _T("");
 lResult = RegOpenKeyEx(hCurKey, cstrKey, 0, KEY_QUERY_VALUE , &hKey);
 if(lResult != ERROR_SUCCESS)
  return;
 DWORD lNoOfValues = 0;
 DWORD lLongestKeyNameLen = 1;
 DWORD lLongestDataLen = 1;

 lResult = RegQueryInfoKey(hKey, NULL, NULL, NULL, NULL, NULL, NULL, &lNoOfValues, &lLongestKeyNameLen, &lLongestDataLen,NULL, NULL);

 if(lResult != ERROR_SUCCESS)
  return;
 hLastKey = hKey;
 lLongestKeyNameLen++;
 lLongestDataLen++;
 tcKeyName = new TCHAR[lLongestKeyNameLen];
 pbbinKeyData = new BYTE[lLongestDataLen];
 CString cstrFinalData, cstrTemp;
 while(TRUE)
 {
  memset(pbbinKeyData, 0, lLongestDataLen);
  memset(tcKeyName, 0, lLongestKeyNameLen);
  dwKeyType = dwKeyDataLength = dwKeyNameLen = 0;
  dwKeyNameLen = lLongestKeyNameLen;
  dwKeyDataLength = lLongestDataLen;
  lResult = RegEnumValue(hKey, dwIndex, tcKeyName, &dwKeyNameLen, NULL, &dwKeyType, pbbinKeyData, &dwKeyDataLength);
  if(lResult == ERROR_NO_MORE_ITEMS)
   break;
  AddRegistryItem(tcKeyName, dwKeyType, pbbinKeyData, dwKeyDataLength, dwIndex);//显示数据于ListView
  dwIndex++;
 }
 RegCloseKey(hKey);
 delete tcKeyName;
 delete pbbinKeyData;
}
Cocoky 2004-07-10
  • 打赏
  • 举报
回复
type = REG_DWORD;
suc=::RegEnumValue(hkey, (dword)num, str, NULL, &type, strv, &vl);
windows自带的注册表编辑器并没有把所有的项都显示出来,出于好奇,自己写了个简易的注册表编辑器,以查看隐藏的东西~~ 界面跟自带的很像,里面的小图标都是从自带里导出来的。 具有的功能: 1.浏览键(key)、值(value); 2.插入、修改REG_SZ、REG_EXPAND_SZ、REG_MULTI_SZ、REG_DWORD、REG_DWORD_BIG_ENDIAN、REG_QWORD六种值类型(value)的名称跟数据; 3.删除所有类型的键值(value); 4.插入键(key),删除不含子键的键(key); 5.左侧树形窗口右键点击时是收缩节点,方便浏览; 6.自带的每个键它都会显示默认(就是名称为空的)键值(value),而我则是严格按照RegEnumValue的结果来显示; 通过使用并跟自带的比较后发现: XP系统下,自带的隐藏了HKEY_PERFORMANCE_DATA、HKEY_PERFORMANCE_TEXT、HKEY_PERFORMANCE_NLSTEXT的显示,不过这三个键都不含子键,只含值,不知为何,这三个键的默认键值打不开,提示参数不正确。需要注意的是,打开这三个键时,会有点卡。 WIN7下,自带的还隐藏了HKEY_PT的显示,里面似乎REG_QWORD类型的键值很多。 由于我的小程序查错步骤很多,一有错误就会显示出来(要么是弹出消息框,要么是在标题栏显示),因此发现了很多有趣的地方,比如:HKEY_LOCAL_MACHINE\SECURITY和HKEY_LOCAL_MACHINE\SAM\SAM的权限很高,连KEY_READ都打不开,因此自带的没显示这两个键的内容,不知道的还以为确实没内容,其实是注册表API函数打不开的缘故; 另外需要注意的是,打开HKEY_CLASSES_ROOT节点时,由于其子项很多,所以会卡住一会儿,耐心等待。 里面有一个封装了操作注册表的类CRegKey。 里面还有一个截图软件,其两个附加功能或许对你日常生活有帮助,一个是VC的error lookup程序的功能,一个是表达式计算器的功能,你可以在其托盘隐藏时使用热键Ctrl+F8和Ctrl+F9打开、关闭,非常便捷; 里面还可以参考一下CTreeCtrl的Expand函数只能触发一次TVN_ITEMEXPANDING or TVN_ITEMEXPANDED消息题的解决方法。 有题联系:hastings1986@163.com
API之网络函数1. API之网络函数 WNetAddConnection 创建同一个网络资源的永久性连接 WNetAddConnection2 创建同一个网络资源的连接 WNetAddConnection3 创建同一个网络资源的连接 WNetCancelConnection 结束一个网络连接 WNetCancelConnection2 结束一个网络连接 WNetCloseEnum 结束一次枚举操作 WNetConnectionDialog 启动一个标准对话框,以便建立同网络资源的连接 WNetDisconnectDialog 启动一个标准对话框,以便断开同网络资源的连接 WNetEnumResource 枚举网络资源 WNetGetConnection 获取本地或已连接的一个资源的网络名称 WNetGetLastError 获取网络错误的扩展错误信息 WNetGetUniversalName 获取网络中一个文件的远程名称以及/或者UNC(统一命名规范)名称 WNetGetUser 获取一个网络资源用以连接的名字 WNetOpenEnum 启动对网络资源进行枚举的过程 2. API之消息函数 BroadcastSystemMessage 将一条系统消息广播给系统中所有的顶级窗口 GetMessagePos 取得消息队列中上一条消息处理完毕时的鼠标指针屏幕位置 GetMessageTime 取得消息队列中上一条消息处理完毕时的时间 PostMessage 将一条消息投递到指定窗口的消息队列 PostThreadMessage 将一条消息投递给应用程序 RegisterWindowMessage 获取分配给一个字串标识符的消息编号 ReplyMessage 答复一个消息 SendMessage 调用一个窗口的窗口函数,将一条消息发给那个窗口 SendMessageCallback 将一条消息发给窗口 SendMessageTimeout 向窗口发送一条消息 SendNotifyMessage 向窗口发送一条消息 3. API之文件处理函数 CloseHandle 关闭一个内核对象。其中包括文件、文件映射、进程、线程、安全和同步对象等 CompareFileTime 对比两个文件的时间 CopyFile 复制文件 CreateDirectory 创建一个新目录 CreateFile 打开和创建文件、管道、邮槽、通信服务、设备以及控制台 CreateFileMapping 创建一个新的文件映射对象 DeleteFile 删除指定文件 DeviceIoControl 对设备执行指定的操作 DosDateTimeToFileTime 将DOS日期和时间值转换成一个 win32 FILETIME 值 FileTimeToDosDateTime 将一个 win32 FILETIME 值转换成DOS日期和时间值 FileTimeToLocalFileTime 将一个FILETIME结构转换成本地时间 FileTimeToSystemTime 根据一个FILETIME结构的内容,装载一个SYSTEMTIME结构 FindClose 关闭由FindFirstFile函数创建的一个搜索句柄 FindFirstFile 根据文件名查找文件 FindNextFile 根据调用FindFirstFile函数时指定的一个文件名查找下一个文件 FlushFileBuffers 针对指定的文件句柄,刷新内部文件缓冲区 FlushViewOfFile 将写入文件映射缓冲区的所有数据都刷新到磁盘 GetBinaryType 判断文件是否可以执行 GetCompressedFileSize 判断一个压缩文件在磁盘上实际占据的字节数 GetCurrentDirectory 在一个缓冲区中装载当前目录 GetDiskFreeSpace 获取与一个磁盘的组织有关的信息,以及了解剩余空间的容量 GetDiskFreeSpaceEx 获取与一个磁盘的组织以及剩余空间容量有关的信息 GetDriveType 判断一个磁盘驱动器的类型 GetExpandedName 取得一个压缩文件的全名 GetFileAttributes 判断指定文件的属性 GetFileInformationByHandle 这个函数提供了获取文件信息的一种机制 GetFileSize 判断文件长度 GetFileTime 取得指定文件的时间信息 GetFileType 在给出文件句柄的前提下,判断文件类型 GetFileVersionInfo 从支持版本标记的一个模块里获取文件版本信息

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧