• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 8  文章 - 26  trackbacks - 0
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            留言簿(5)

            隨筆檔案

            文章分類

            文章檔案

            相冊

            C++語言

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            今天在教室看書實(shí)在無聊,趕上這兩天在學(xué)習(xí)注冊表操作函數(shù),就寫了這堆代碼,寫完在機(jī)子上運(yùn)行了下感覺還不錯(cuò),也就把注冊表的一些信息寫進(jìn)了單項(xiàng)鏈表中,便于實(shí)現(xiàn)查找操作。
            代碼如下:
            /*存放子鍵與鍵值的數(shù)據(jù)結(jié)構(gòu)*/
            typedef struct RegValueInfo
            {
            DWORD sValueCnt;
            //鍵值數(shù)量,用于頭節(jié)點(diǎn)中
            TCHAR sValueName[256];//鍵值名
            TCHAR sValueData[256];//鍵值數(shù)據(jù)
            DWORD sType;//鍵值類型
            struct RegValueInfo *next;//指向下一節(jié)點(diǎn)的指針
            }
            RegValueInfo,*PRegValueInfo;
             
            typedef struct RegKeyInfo
            {
            DWORD dSunkeyCnt;
            //用于頭節(jié)點(diǎn)中記錄子鍵數(shù)量
            TCHAR lpName[256];//子鍵名稱
            struct RegKeyInfo *next;//指向下一節(jié)點(diǎn)的指針
            }
            RegKeyInfo,*PRegKeyInfo;
             
            /**************************************************************/
            /*枚舉鍵值名、數(shù)據(jù)、類型,并存放于鏈表中,RKI 為鏈表的頭指針*/
            /**************************************************************/
            BOOL MyRegEnumValue(
                                           HKEY hKey,
            //打開注冊表鍵的句柄
                               LPCTSTR lpSubKey,//要打開的注冊表子鍵名稱
                               REGSAM samDesired,//打開時(shí)所要的權(quán)限
                               RegValueInfo ** RKI//用于接收鏈表首地址的指針
                                         )
            {
            int Ret=0;
            HKEY hkey
            =NULL;
            Ret
            =RegOpenKeyEx(hKey,lpSubKey,0,samDesired,&hKey);
            if(ERROR_SUCCESS!=Ret)
            {
             
            cout
            <<"RegOpenKeyEx error ."<<endl;
            RegCloseKey(hkey);
            return FALSE;
            }
                                       
            DWORD dwIndex
            =0;//鍵值索引號
            DWORD dwValueCnt;//鍵值數(shù)量
            DWORD dwValueNameMaxLen;//鍵值名稱最大長度
            DWORD dwValueDataMaxLen;//鍵值數(shù)據(jù)最大長度
            TCHAR *szValueName;//鍵值名稱
            BYTE *szValueData;//鍵值數(shù)據(jù)
            DWORD dwValueType;//鍵值類型
             
             
            Ret
            =RegQueryInfoKey(hKey,NULL,NULL,NULL,NULL,NULL,NULL,&dwValueCnt,&dwValueNameMaxLen,&dwValueDataMaxLen,NULL,NULL);
            if(ERROR_SUCCESS!=Ret)
            {
             
            cout
            <<"RegQueryInfoKey error ."<<endl;
            RegCloseKey(hKey);
            return FALSE;
            }
                        
                                         
             
            RegValueInfo 
            * Tail;//尾指針
            *RKI=new RegValueInfo;////構(gòu)造單鏈表的頭節(jié)點(diǎn)
            (*RKI)->sValueCnt=dwValueCnt;                        
            (
            *RKI)->next=NULL;
            Tail
            =*RKI;
            //開始枚舉所有子鍵
            for(;dwIndex<dwValueCnt;dwIndex++)
            {
            DWORD dwValueNameSize
            =dwValueNameMaxLen+1;
            DWORD dwValueDataSize
            =dwValueDataMaxLen+1;
            szValueName
            =new TCHAR[dwValueNameSize]; 
            szValueData
            =new BYTE[dwValueDataSize];
             
            RegEnumValue(hKey,dwIndex,szValueName,
            &dwValueNameSize,0,&dwValueType,(unsigned char *)szValueData,&dwValueDataSize);
            RegValueInfo 
            *NewNode=new RegValueInfo;
            strcpy(NewNode
            ->sValueName,szValueName);
            strcpy(NewNode
            ->sValueData,(const char *)szValueData);
            NewNode
            ->sType=dwValueType;
            Tail
            ->next=NewNode;
            Tail
            =NewNode;
            }
            //for                            
                                         
            Tail
            ->next=NULL;                        
            return TRUE;                                                          
             }
            //end_fun
             
            /*枚舉子鍵名,并存放于鏈表中,RKI 為鏈表頭*/
             
            BOOL MyRegEnumKey(
                                           HKEY hKey,
            //打開注冊表鍵的句柄
                               LPCTSTR lpSubKey,//要打開的注冊表子鍵名稱
                               REGSAM samDesired,//打開時(shí)所要的權(quán)限
                               RegKeyInfo ** RKI//用于接收鏈表首地址的指針
                                         )
            {
            int Ret=0;
            HKEY hkey
            =NULL;
            Ret
            =RegOpenKeyEx(hKey,lpSubKey,0,samDesired,&hKey);
            if(ERROR_SUCCESS!=Ret)
            {
             
            cout
            <<"RegOpenKeyEx error ."<<endl;
            RegCloseKey(hkey);
            return FALSE;
            }
                                       
            DWORD dwIndex
            =0;//子鍵索引號
            DWORD dwKeyCnt;//子鍵數(shù)量
            DWORD dwKeyMaxLen;//子鍵名稱最大長度
            TCHAR *szKeyName;//子鍵名稱
             
            Ret
            =RegQueryInfoKey(hKey,NULL,NULL,NULL,&dwKeyCnt,&dwKeyMaxLen,NULL,NULL,NULL,NULL,NULL,NULL);
            if(ERROR_SUCCESS!=Ret)
            {
             
            cout
            <<"RegQueryInfoKey error ."<<endl;
            RegCloseKey(hKey);
            return FALSE;
            }
                        
                                         
             
            RegKeyInfo 
            * Tail;//尾指針
            *RKI=new RegKeyInfo;////構(gòu)造單鏈表的頭節(jié)點(diǎn)
            (*RKI)->dSunkeyCnt=dwKeyCnt;                       
            (
            *RKI)->next=NULL;
            Tail
            =*RKI;
            //開始枚舉所有子鍵
            for(;dwIndex<dwKeyCnt;dwIndex++)
            {
            DWORD dwKeySize
            =dwKeyMaxLen+1;
            szKeyName
            =new TCHAR[dwKeySize]; 
            RegEnumKeyEx(hKey,dwIndex,szKeyName,
            &dwKeySize,0,NULL,NULL,NULL);
            RegKeyInfo 
            *NewNode=new RegKeyInfo;
            strcpy(NewNode
            ->lpName,szKeyName);
            Tail
            ->next=NewNode;
            Tail
            =NewNode;
            }
            //for                            
                                         
            Tail
            ->next=NULL;                        
            return TRUE;                                                          
             }
            //end_fun
             
            /********************************************************/
            #include
            <windows.h>
            #include
            <iostream.h>
            void main()
            {
            RegValueInfo 
            * p1;
            RegKeyInfo 
            * p2;
             
            BOOL ret
            =FALSE;
            ret
            =MyRegEnumValue(HKEY_LOCAL_MACHINE,"software\\microsoft\\windows\\currentversion",KEY_ALL_ACCESS,&p1);
            if(FALSE==ret)
            {
            cout
            <<"wrong"<<endl;
            return;
            }

             
            cout
            <<"輸出鍵值信息"<<endl;
            cout
            <<"子鍵數(shù)量:"<<p->sValueCnt<<endl;
            for(p1=p1->next;p1;p1=p1->next)
            {cout<<p1->sValueName<<endl;
            cout
            <<p1->sValueData<<endl;
            cout
            <<p1->sType<<endl;
            }

            cout
            <<"=========================================="<<endl;
            cout
            <<"輸出子鍵信息"<<endl;
            ret
            =MyRegEnumValue(HKEY_LOCAL_MACHINE,"software\\microsoft\\windows\\currentversion",KEY_ALL_ACCESS,&p2);
            if(FALSE==ret)
            {
            cout
            <<"wrong"<<endl;
            return;
            }

            cout
            <<"子鍵數(shù)量:"<<p2->dSunkeyCnt;
            for(p=p->next;p;p=p->next)
            {cout<<p->lpName<<endl;} 
            }

            posted on 2008-06-14 09:39 楊彬彬 閱讀(292) 評論(0)  編輯 收藏 引用 所屬分類: Windows編程
            亚洲国产天堂久久久久久| www.久久99| 色8激情欧美成人久久综合电| 久久亚洲国产最新网站| 久久精品无码一区二区无码| 亚洲欧美国产日韩综合久久 | 国产成人精品综合久久久久| 国产精品久久久久天天影视| 亚洲国产精品久久久久婷婷老年| 久久精品国产久精国产果冻传媒| 久久综合九色综合久99| 国产精品伊人久久伊人电影| 国产精品欧美久久久天天影视| 久久久无码精品午夜| 久久狠狠高潮亚洲精品| 欧美久久综合九色综合| 久久精品国产福利国产秒| 99久久人妻无码精品系列蜜桃| 婷婷久久香蕉五月综合加勒比| 亚洲综合熟女久久久30p| 久久精品无码一区二区日韩AV| 国内精品久久久久久久亚洲 | 久久精品a亚洲国产v高清不卡| 久久久精品波多野结衣| 久久婷婷国产麻豆91天堂| 青青草国产精品久久久久| 久久这里只有精品18| 欧美久久精品一级c片片| 久久久久亚洲AV无码观看| 亚洲精品无码久久久久AV麻豆| 国产成人久久精品二区三区| 精品国产福利久久久| 欧美噜噜久久久XXX| 亚洲中文久久精品无码| 久久久久青草线蕉综合超碰| 久久精品国产亚洲AV忘忧草18| 四虎国产精品免费久久| 免费无码国产欧美久久18| 久久久精品免费国产四虎| 久久国产色AV免费观看| 久久精品国产免费|