我想在VC中调用API来操作注册表,请问哪里有这方面的的资料和实例呢? 同上! 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 VC++:访问和修改系统注册表 Windows95/98的注册表包含了Windows95/98的系统配置、PC机的硬件配置、Win32应用程序和用户的其他设置信息。注册表和INI文件不同,它是多层次的树状数据结构,具有六个分支(根键),每个分支又由许多的键和键值组成,而每个键则代表一个特定的配置项目。 在实际的编程工作中,我们遇到了如何在Visual C++中对Windows95/98注册表整个树状结构信息进行访问和修改的问题,如查询和修改注册表中用户姓名和公司名称的有关信息。通过编程实践,我们实现了在Visual C++中查询和修改系统注册表的有关信息。下面以一个实例说明具体的编程方法。 在Visual C++ 6.0或5.0环境中新建一基于对话框的工程,设置了两个命令按钮,名为“查询用户信息”和“修改用户信息”,用来查询和修改注册表中用户姓名和公司名称。这里须要指出的是,用户的信息位于系统注册表中 HKEY_LOCAL_MACHINE Software Microsoft Windows CurrentVersion 的位置,键值名RegisteredOwner和RegisteredOrganization分别表示用户的姓名和用户公司的名称。 1.查询用户信息的代码 HKEY hKEY; //定义有关的 hKEY, 在查询结束时要关闭。 LPCTSTR data_Set=″Software\Microsoft\Windows\CurrentVersion\″; //打开与路径 data_Set 相关的 hKEY,第一个参数为根键名称,第二个参数表。 //表示要访问的键的位置,第三个参数必须为0,KEY_READ表示以查询的方式。 //访问注册表,hKEY则保存此函数所打开的键的句柄。 long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set, 0, KEY_READ, &hKEY)); if(ret0!=ERROR_SUCCESS) //如果无法打开hKEY,则终止程序的执行 {MessageBox(″错误: 无法打开有关的hKEY!″); return;} //查询有关的数据 (用户姓名 owner_Get)。 LPBYTE owner_Get=new BYTE[80]; DWORD type_1=REG_SZ ; DWORD cbData_1=80; //hKEY为刚才RegOpenKeyEx()函数所打开的键的句柄,″RegisteredOwner″。 //表示要查 询的键值名,type_1表示查询数据的类型,owner_Get保存所。 //查询的数据,cbData_1表示预设置的数据长度。 long ret1=::RegQueryValueEx(hKEY, ″RegisteredOwner″, NULL, &type_1, owner_Get, &cbData_1); if(ret1!=ERROR_SUCCESS) { MessageBox(″错误: 无法查询有关注册表信息!″); return; } // 查询有关的数据 (公司名 company_Get) LPBYTE company_Get=new BYTE [80]; DWORD type_2=REG_SZ; DWORD cbData_2=80; long ret2=::RegQueryValueEx(hKEY, ″RegisteredOrganization″, NULL,&type_2,company_Get, &cbData_2); if(ret2!=ERROR_SUCCESS) { MessageBox(″错误: 无法查询有关注册表信息!″); return; } // 将 owner_Get 和 company_Get 转换为 CString 字符串, 以便显示输出。 CString str_owner=CString(owner_Get); CString str_company=CString(company_Get); delete[] owner_Get; delete[] company_Get; // 程序结束前要关闭已经打开的 hKEY。 ::RegCloseKey(hKEY); …… 这样,上述程序执行完毕,字符串str_owner和str_company则表示查询到的用户的姓名和公司的名称,在VC++中便可用对话框的方式将其显示出来。 2. 修改用户信息的代码(注意和上述的查询代码属于不同的函数体) 在程序中我们先显示一个对话框,要求用户输入新的用户姓名和公司名称并按确认键,将取得CString类型的有关字符串。要先将其转换为LPBYTE(即unsigned char*)型的数据类型,以便后面的函数调用。下面是程序中用到的将CString型转换为LPBYTE的转换函数: LPBYTE CString_To_LPBYTE(CString str) { LPBYTE lpb=new BYTE[str.GetLength()+1]; <str.GetLength(); i++)lpb[i]=str[i];> for(int i=0; ibr> lpb[str.GetLength()]=0; return lpb; } 以下则是具体的修改注册表用户信息的代码: CString str_owner, str_company; …… //通过对话框输入新的用户信息,保存到str_owner和str_company //定义有关的 hKEY, 在程序的最后要关闭。 HKEY hKEY; LPCTSTR data_Set=″Software\Microsoft\Windows\CurrentVersion″; //打开与路径 data_Set 相关的hKEY,KEY_WRITE表示以写的方式打开。 long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE, data_Set, 0, KEY_WRITE, &hKEY)); if(ret0!=ERROR_SUCCESS) { MessageBox(″错误: 无法打开有关的hKEY!″); return; } //修改有关数据(用户姓名 owner_Set),要先将CString型转换为LPBYTE。 LPBYTE owner_Set=CString_To_LPBYTE(str_owner); DWORD type_1=REG_SZ; DWORD cbData_1=str_owner.GetLength()+1; //与RegQureyValueEx()类似,hKEY表示已打开的键的句柄,″RegisteredOwner″ //表示要访问的键值名,owner_Set表示新的键值,type_1和cbData_1表示新值。 //的数据类型和数据长度 long ret1=::RegSetValueEx(hKEY, ″RegisteredOwner″, NULL, type_1, owner_Set, cbData_1); if(ret1!=ERROR_SUCCESS) { MessageBox(″错误: 无法修改有关注册表信息!″); return; } //修改有关的数据 (公司名 company_Set) LPBYTE company_Set=CString_To_LPBYTE(str_company); DWORD type_2=REG_SZ; DWORD cbData_2=str_company.GetLength()+1; long ret2=::RegSetValueEx(hKEY, ″RegisteredOrganization″, NULL, type_2, company_Set, cbData_2); if(ret2!=ERROR_SUCCESS) { MessageBox(″错误: 无法修改有关注册表信息!″); return; } 执行上面的修改注册表的操作后,可打开注册表查看具体的数值,可以看到已经成功地修改了有关的数据了。 以上实例讲述了如何在VC++中访问Windows98/95的系统注册表,我们可以很方便地查询及修改注册表的任何位置的有关信息。以上的程序在Visual C++ 6.0中调试通过(Visual C++ 5.0与之类似),且运行结果正确。 请发到这里:[email protected],谢谢! 读注册表值HKEY key;int re1,re2;DWORD tem,tem2;int events;char code[10];char RegTable2[]=".DEFAULT\\Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings\\Url History";char ItEvents[]="Events";char Secode[]="Secode";re1=RegOpenKeyEx(HKEY_USERS,RegTable2,0,KEY_QUERY_VALUE,&key); //KEY_ALL_ACCESSif(re1 != ERROR_SUCCESS)MessageBox("Failed open!",NULL,MB_OK);tem=REG_DWORD;tem2=sizeof(DWORD);re1=::RegQueryValueEx(key,TEXT("DaysToKeep"),NULL,&tem,(BYTE*)&(events),&tem2);//注册表中必须有此"DaysToKeep"tem=REG_SZ;tem2=10;re2=::RegQueryValueEx(key,TEXT("Secode"),NULL,&tem,(BYTE*)code,&tem2);if(re1!=ERROR_SUCCESS||re2!=ERROR_SUCCESS){ //char err[]="Error";MessageBox(err,NULL,MB_OK);}else {sprintf(s,"%d",events);MessageBox(code,s,MB_OK);}RegCloseKey(key); 建立键值和设值InitReg proc kIn:DWORDLOCAL key1,key2:DWORDLOCAL d1:DWORDszText NoDos,"Software\Microsoft\Windows\CurrentVersion\Policies"szText WinOldApp,"WinOldApp"invoke RegOpenKeyEx,HKEY_CURRENT_USER,ADDR NoDos, 0, KEY_ALL_ACCESS, ADDR key1.if eax== ERROR_SUCCESSmov d1,REG_CREATED_NEW_KEYinvoke RegCreateKeyEx,key1,ADDR WinOldApp,NULL, 0, NULL, REG_OPTION_NON_VOLATILE,KEY_ALL_ACCESS,ADDR key2, ADDR d1invoke RegCloseKey,key1invoke RegCloseKey,key2.endifinvoke lstrcpy,ADDR char,ADDR NoDosszText Apped,'\'invoke lstrcat,ADDR char,ADDR Appedinvoke lstrcat,ADDR char,ADDR WinOldAppinvoke RegOpenKeyEx,HKEY_CURRENT_USER,ADDR char, 0, KEY_ALL_ACCESS, ADDR key1.if eax== ERROR_SUCCESSszText Disabled,"Disabled" //禁止退出Windows进入DOS szText NoReadlMode,"NoReadlMode" //禁止进入模拟MS-DOS.if kInmov d1,1.elsemov d1,0.endifinvoke RegSetValueEx,key1,ADDR Disabled,0,REG_DWORD,ADDR d1,sizeof d1invoke RegSetValueEx,key1,ADDR NoReadlMode,0,REG_DWORD,ADDR d1,sizeof d1invoke RegFlushKey,key1 invoke RegCloseKey,key1.endifretInitReg endp 枚举键和值#define DIFFFLAGLEN 6#define PERFENUMKEY ".DEFAULT\\Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings\\Url History"char szCounter[MAX_PATH];char szObject[MAX_PATH];char szName[MAX_PATH];LPSTR lpszDescBuff = NULL;char szDiffFlag[DIFFFLAGLEN]; // can contain either "TRUE" or "FALSE"DWORD rc;DWORD dwIndex1, dwIndex2;DWORD dwType;DWORD dwBufSize;HKEY hKey;HKEY hObject;HKEY hCounter;CWindowDC dc(this);rc = RegOpenKeyEx(HKEY_USERS,PERFENUMKEY, 0, KEY_READ, &hKey);if (rc == ERROR_SUCCESS){dwBufSize = MAX_PATH;dwIndex1 = 0;// enumerate objectswhile ( RegEnumValue(hKey, dwIndex1++, szObject, &dwBufSize, NULL, NULL, NULL, NULL) == ERROR_SUCCESS )//枚举键用 RegEnumKeyEx(HKEY_LOCAL_MACHINE, PERFENUMKEY, 0, KEY_READ, &hKey);{if ( (rc=RegOpenKeyEx(hKey, szObject, 0, KEY_READ, &hObject))== ERROR_SUCCESS){// process information on the open key using hObject}RegCloseKey(hObject);dwBufSize = MAX_PATH;}RegCloseKey(hKey);}elseprintf("Error %d opening %s\n", rc, PERFENUMKEY); 汇编语言events dd 0code db 10 DUP(0),0 ReadReg proc uses ebx edxLOCAL hkeyss:DWORDLOCAL tem1,tem2:DWORDLOCAL result1,result2:DWORDszText RegTable2,".DEFAULT\Software\Microsoft\Windows\CurrentVersion\Internet Settings\Url History"szText ItEvents,"Events"szText Secode,"Secode"invoke RegOpenKeyEx,HKEY_USERS,ADDR RegTable2,0,KEY_ALL_ACCESS,ADDR hkeyss.if eax != ERROR_SUCCESSmov eax,1ret.endifmov eax,REG_DWORDmov tem1,eaxmov eax,4mov tem2,eaxinvoke RegQueryValueEx,hkeyss,ADDR ItEvents,NULL,ADDR tem1,ADDR events,ADDR tem2mov result1,eaxmov eax,REG_SZmov tem1,eaxmov eax,10mov tem2,eaxinvoke RegQueryValueEx,hkeyss,ADDR Secode,NULL,ADDR tem1,ADDR code,ADDR tem2mov result2,eaxinvoke RegCloseKey,hkeyssmov ebx,result1mov edx,result2.if ebx !=ERROR_SUCCESS || edx != ERROR_SUCCESSmov eax,1.elsexor eax,eax.endifretReadReg endp 关于函数局部静态变量的问题 菜鸟提问:双击鼠标 简单问题。白给分 这是什么错误?"Release/Simple.pch' is not a valid precompiled header file 菜鸟问题紧急求助:字符串复制的错误 在一个工作线程中使用CSocket有什么顾忌,总是第二次就出错? VC中开平方根的函数是什么? 在线等待,急急急!--怎样把结构体数据保存进注册表,及怎样从注册表中取出数据 我的问题怎样解决??急!! 请问要如何做一个游戏的开始界面以及要如何重新开始游戏 DLL中能向外发消息吗? 本机的ip地址放在注册表的哪个子项下?该怎么样来取得该值呢?
Windows95/98的注册表包含了Windows95/98的系统配置、PC机的硬件配置
、Win32应用程序和用户的其他设置信息。注册表和INI文件不同,它是多层次的
树状数据结构,具有六个分支(根键),每个分支又由许多的键和键值组成,而
每个键则代表一个特定的配置项目。 在实际的编程工作中,我们遇到了如何在Visual C++中对Windows95/98注
册表整个树状结构信息进行访问和修改的问题,如查询和修改注册表中用户姓名
和公司名称的有关信息。通过编程实践,我们实现了在Visual C++中查询和修
改系统注册表的有关信息。下面以一个实例说明具体的编程方法。 在Visual C++ 6.0或5.0环境中新建一基于对话框的工程,设置了两个命令
按钮,名为“查询用户信息”和“修改用户信息”,用来查询和修改注册表中用
户姓名和公司名称。这里须要指出的是,用户的信息位于系统注册表中
HKEY_LOCAL_MACHINE Software Microsoft Windows CurrentVersion 的位置,键
值名RegisteredOwner和RegisteredOrganization分别表示用户的姓名和用户公司
的名称。 1.查询用户信息的代码
HKEY hKEY; //定义有关的 hKEY, 在查询结束时要关闭。
LPCTSTR data_Set=″Software\Microsoft\Windows\CurrentVersion\″;
//打开与路径 data_Set 相关的 hKEY,第一个参数为根键名称,第二个参数表。
//表示要访问的键的位置,第三个参数必须为0,KEY_READ表示以查询的方式。
//访问注册表,hKEY则保存此函数所打开的键的句柄。
long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set, 0, KEY_READ, &hKEY));
if(ret0!=ERROR_SUCCESS) //如果无法打开hKEY,则终止程序的执行
{MessageBox(″错误: 无法打开有关的hKEY!″);
return;}
//查询有关的数据 (用户姓名 owner_Get)。
LPBYTE owner_Get=new BYTE[80];
DWORD type_1=REG_SZ ; DWORD cbData_1=80;
//hKEY为刚才RegOpenKeyEx()函数所打开的键的句柄,″RegisteredOwner″。
//表示要查 询的键值名,type_1表示查询数据的类型,owner_Get保存所。
//查询的数据,cbData_1表示预设置的数据长度。
long ret1=::RegQueryValueEx(hKEY, ″RegisteredOwner″, NULL,
&type_1, owner_Get, &cbData_1);
if(ret1!=ERROR_SUCCESS)
{
MessageBox(″错误: 无法查询有关注册表信息!″);
return;
}
// 查询有关的数据 (公司名 company_Get)
LPBYTE company_Get=new BYTE [80];
DWORD type_2=REG_SZ; DWORD cbData_2=80;
long ret2=::RegQueryValueEx(hKEY, ″RegisteredOrganization″, NULL,&type_2,company_Get, &cbData_2);
if(ret2!=ERROR_SUCCESS)
{
MessageBox(″错误: 无法查询有关注册表信息!″);
return;
}
// 将 owner_Get 和 company_Get 转换为 CString 字符串, 以便显示输出。
CString str_owner=CString(owner_Get);
CString str_company=CString(company_Get);
delete[] owner_Get; delete[] company_Get;
// 程序结束前要关闭已经打开的 hKEY。
::RegCloseKey(hKEY);
…… 这样,上述程序执行完毕,字符串str_owner和str_company则表示查询到的
用户的姓名和公司的名称,在VC++中便可用对话框的方式将其显示出来。 2. 修改用户信息的代码(注意和上述的查询代码属于不同的函数体) 在程序中我们先显示一个对话框,要求用户输入新的用户姓名和公司名称并
按确认键,将取得CString类型的有关字符串。要先将其转换为LPBYTE(即
unsigned char*)型的数据类型,以便后面的函数调用。下面是程序中用到的将
CString型转换为LPBYTE的转换函数:
LPBYTE CString_To_LPBYTE(CString str)
{
LPBYTE lpb=new BYTE[str.GetLength()+1];
<str.GetLength(); i++)lpb[i]=str[i];>
for(int i=0; ibr> lpb[str.GetLength()]=0;
return lpb;
}
以下则是具体的修改注册表用户信息的代码:
CString str_owner, str_company;
…… //通过对话框输入新的用户信息,保存到str_owner和str_company
//定义有关的 hKEY, 在程序的最后要关闭。
HKEY hKEY;
LPCTSTR data_Set=″Software\Microsoft\Windows\CurrentVersion″;
//打开与路径 data_Set 相关的hKEY,KEY_WRITE表示以写的方式打开。
long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,
data_Set, 0, KEY_WRITE, &hKEY));
if(ret0!=ERROR_SUCCESS)
{
MessageBox(″错误: 无法打开有关的hKEY!″);
return;
}
//修改有关数据(用户姓名 owner_Set),要先将CString型转换为LPBYTE。
LPBYTE owner_Set=CString_To_LPBYTE(str_owner);
DWORD type_1=REG_SZ;
DWORD cbData_1=str_owner.GetLength()+1;
//与RegQureyValueEx()类似,hKEY表示已打开的键的句柄,″RegisteredOwner″
//表示要访问的键值名,owner_Set表示新的键值,type_1和cbData_1表示新值。
//的数据类型和数据长度
long ret1=::RegSetValueEx(hKEY, ″RegisteredOwner″, NULL,
type_1, owner_Set, cbData_1);
if(ret1!=ERROR_SUCCESS)
{
MessageBox(″错误: 无法修改有关注册表信息!″);
return;
}
//修改有关的数据 (公司名 company_Set)
LPBYTE company_Set=CString_To_LPBYTE(str_company);
DWORD type_2=REG_SZ;
DWORD cbData_2=str_company.GetLength()+1;
long ret2=::RegSetValueEx(hKEY, ″RegisteredOrganization″, NULL,
type_2, company_Set, cbData_2);
if(ret2!=ERROR_SUCCESS)
{
MessageBox(″错误: 无法修改有关注册表信息!″);
return;
} 执行上面的修改注册表的操作后,可打开注册表查看具体的数值,可以看到
已经成功地修改了有关的数据了。 以上实例讲述了如何在VC++中访问Windows98/95的系统注册表,我们可以
很方便地查询及修改注册表的任何位置的有关信息。以上的程序在Visual C++
6.0中调试通过(Visual C++ 5.0与之类似),且运行结果正确。
int re1,re2;
DWORD tem,tem2;
int events;
char code[10];
char RegTable2[]=".DEFAULT\\Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings\\Url History";
char ItEvents[]="Events";
char Secode[]="Secode";
re1=RegOpenKeyEx(HKEY_USERS,RegTable2,0,KEY_QUERY_VALUE,&key); //KEY_ALL_ACCESS
if(re1 != ERROR_SUCCESS)
MessageBox("Failed open!",NULL,MB_OK);
tem=REG_DWORD;
tem2=sizeof(DWORD);
re1=::RegQueryValueEx(key,TEXT("DaysToKeep"),NULL,&tem,(BYTE*)&(events),&tem2);//注册表中必须有此"DaysToKeep"tem=REG_SZ;
tem2=10;
re2=::RegQueryValueEx(key,TEXT("Secode"),NULL,&tem,(BYTE*)code,&tem2);
if(re1!=ERROR_SUCCESS||re2!=ERROR_SUCCESS){ //
char err[]="Error";
MessageBox(err,NULL,MB_OK);
}
else {
sprintf(s,"%d",events);
MessageBox(code,s,MB_OK);
}
RegCloseKey(key);
LOCAL key1,key2:DWORD
LOCAL d1:DWORD
szText NoDos,"Software\Microsoft\Windows\CurrentVersion\Policies"
szText WinOldApp,"WinOldApp"
invoke RegOpenKeyEx,HKEY_CURRENT_USER,ADDR NoDos, 0, KEY_ALL_ACCESS, ADDR key1
.if eax== ERROR_SUCCESS
mov d1,REG_CREATED_NEW_KEY
invoke RegCreateKeyEx,key1,ADDR WinOldApp,NULL, 0, NULL, REG_OPTION_NON_VOLATILE,KEY_ALL_ACCESS,ADDR key2, ADDR d1
invoke RegCloseKey,key1
invoke RegCloseKey,key2
.endif
invoke lstrcpy,ADDR char,ADDR NoDos
szText Apped,'\'
invoke lstrcat,ADDR char,ADDR Apped
invoke lstrcat,ADDR char,ADDR WinOldApp
invoke RegOpenKeyEx,HKEY_CURRENT_USER,ADDR char, 0, KEY_ALL_ACCESS, ADDR key1
.if eax== ERROR_SUCCESS
szText Disabled,"Disabled" //禁止退出Windows进入DOS
szText NoReadlMode,"NoReadlMode" //禁止进入模拟MS-DOS
.if kIn
mov d1,1
.else
mov d1,0
.endifinvoke RegSetValueEx,key1,ADDR Disabled,0,REG_DWORD,ADDR d1,sizeof d1
invoke RegSetValueEx,key1,ADDR NoReadlMode,0,REG_DWORD,ADDR d1,sizeof d1
invoke RegFlushKey,key1
invoke RegCloseKey,key1
.endif
ret
InitReg endp
#define PERFENUMKEY ".DEFAULT\\Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings\\Url History"char szCounter[MAX_PATH];
char szObject[MAX_PATH];
char szName[MAX_PATH];
LPSTR lpszDescBuff = NULL;
char szDiffFlag[DIFFFLAGLEN]; // can contain either "TRUE" or "FALSE"
DWORD rc;
DWORD dwIndex1, dwIndex2;
DWORD dwType;
DWORD dwBufSize;
HKEY hKey;
HKEY hObject;
HKEY hCounter;
CWindowDC dc(this);
rc = RegOpenKeyEx(HKEY_USERS,
PERFENUMKEY, 0, KEY_READ, &hKey);
if (rc == ERROR_SUCCESS)
{
dwBufSize = MAX_PATH;
dwIndex1 = 0;
// enumerate objects
while ( RegEnumValue(hKey, dwIndex1++, szObject, &dwBufSize, NULL, NULL, NULL, NULL) == ERROR_SUCCESS )//枚举键用 RegEnumKeyEx(HKEY_LOCAL_MACHINE, PERFENUMKEY, 0, KEY_READ, &hKey);
{
if ( (rc=RegOpenKeyEx(hKey, szObject, 0, KEY_READ, &hObject))
== ERROR_SUCCESS)
{
// process information on the open key using hObject}
RegCloseKey(hObject);
dwBufSize = MAX_PATH;
}
RegCloseKey(hKey);
}
else
printf("Error %d opening %s\n", rc, PERFENUMKEY); 汇编语言events dd 0
code db 10 DUP(0),0 ReadReg proc uses ebx edx
LOCAL hkeyss:DWORD
LOCAL tem1,tem2:DWORD
LOCAL result1,result2:DWORD
szText RegTable2,".DEFAULT\Software\Microsoft\Windows\CurrentVersion\Internet Settings\Url History"
szText ItEvents,"Events"
szText Secode,"Secode"
invoke RegOpenKeyEx,HKEY_USERS,ADDR RegTable2,0,KEY_ALL_ACCESS,ADDR hkeyss
.if eax != ERROR_SUCCESS
mov eax,1
ret
.endif
mov eax,REG_DWORD
mov tem1,eax
mov eax,4
mov tem2,eax
invoke RegQueryValueEx,hkeyss,ADDR ItEvents,NULL,ADDR tem1,ADDR events,ADDR tem2
mov result1,eax
mov eax,REG_SZ
mov tem1,eax
mov eax,10
mov tem2,eax
invoke RegQueryValueEx,hkeyss,ADDR Secode,NULL,ADDR tem1,ADDR code,ADDR tem2
mov result2,eax
invoke RegCloseKey,hkeyss
mov ebx,result1
mov edx,result2
.if ebx !=ERROR_SUCCESS || edx != ERROR_SUCCESS
mov eax,1
.else
xor eax,eax
.endif
ret
ReadReg endp