關(guān)于英雄聯(lián)盟找不到程序入口點(diǎn)setupdiget這個(gè)問(wèn)題很多朋友還不知道,今天小六來(lái)為大家解答以上的問(wèn)題,現(xiàn)在讓我們一起來(lái)看看吧!
1、第一步,我先從簡(jiǎn)單的調(diào)用出發(fā),定義了一個(gè)簡(jiǎn)單的函數(shù),該函數(shù)僅僅實(shí)現(xiàn)一個(gè)整數(shù)加法求和: LIBEXPORT_API int mySum(int a,int b){ return a+b;} C# 導(dǎo)入定義: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=***.Auto,CallingConvention=CallingConvention.StdCall)] public static extern int mySum (int a,int b); } 在C#中調(diào)用測(cè)試: int iSum = RefComm.mySum(,); 運(yùn)行查看結(jié)果iSum為5,調(diào)用正確。
2、第一步試驗(yàn)完成,說(shuō)明在C#中能夠調(diào)用自定義的動(dòng)態(tài)鏈接庫(kù)函數(shù)。
3、 第二步,我定義了字符串操作的函數(shù)(簡(jiǎn)單起見(jiàn),還是采用前面的函數(shù)名),返回結(jié)果為字符串: LIBEXPORT_API char *mySum(char *a,char *b){sprintf(b,"%s",a); return a;} C# 導(dǎo)入定義: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=***.Auto, CallingConvention=CallingConvention.StdCall)] public static extern string mySum (string a, string b); } 在C#中調(diào)用測(cè)試: string strDest=""; string strTmp= RefComm.mySum("45", strDest); 運(yùn)行查看結(jié)果 strTmp 為"45",但是strDest為空。
4、我修改動(dòng)態(tài)鏈接庫(kù)實(shí)現(xiàn),返回結(jié)果為串b: LIBEXPORT_API char *mySum(char *a,char *b){sprintf(b,"%s",a) return b;} 修改 C# 導(dǎo)入定義,將串b修改為ref方式: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=***.Auto,CallingConvention=CallingConvention.StdCall)] public static extern string mySum (string a, ref string b); } 在C#中再調(diào)用測(cè)試: string strDest=""; string strTmp= RefComm.mySum("45", ref strDest); 運(yùn)行查看結(jié)果 strTmp 和 strDest 均不對(duì),含不可見(jiàn)字符。
5、再修改 C# 導(dǎo)入定義,將CharSet從Auto修改為Ansi: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=CharSet.Ansi,CallingConvention=CallingConvention.StdCall)] public static extern string mySum (string a, string b); } 在C#中再調(diào)用測(cè)試: string strDest=""; string strTmp= RefComm. mySum("45", ref strDest); 運(yùn)行查看結(jié)果 strTmp 為"45",但是串 strDest 沒(méi)有賦值。
6、第二步實(shí)現(xiàn)函數(shù)返回串,但是在函數(shù)出口參數(shù)中沒(méi)能進(jìn)行輸出。
7、再次修改 C# 導(dǎo)入定義,將串b修改為引用(ref): public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=CharSet.Ansi,CallingConvention=CallingConvention.StdCall)] public static extern string mySum (string a, ref string b); } 運(yùn)行時(shí)調(diào)用失敗,不能繼續(xù)執(zhí)行。
8、 第三步,修改動(dòng)態(tài)鏈接庫(kù)實(shí)現(xiàn),將b修改為雙重指針: LIBEXPORT_API char *mySum(char *a,char **b){sprintf((*b),"%s",a); return *b;} C#導(dǎo)入定義: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=CharSet.Ansi,CallingConvention=CallingConvention.StdCall)] public static extern string mySum (string a, ref string b); } 在C#中調(diào)用測(cè)試: string strDest=""; string strTmp= RefComm. mySum("45", ref strDest); 運(yùn)行查看結(jié)果 strTmp 和 strDest 均為"45",調(diào)用正確。
9、第三步實(shí)現(xiàn)了函數(shù)出口參數(shù)正確輸出結(jié)果。
10、 第四步,修改動(dòng)態(tài)鏈接庫(kù)實(shí)現(xiàn),實(shí)現(xiàn)整數(shù)參數(shù)的輸出: LIBEXPORT_API int mySum(int a,int b,int *c){ *c=a+b; return *c;} C#導(dǎo)入的定義: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=CharSet.Ansi,CallingConvention=CallingConvention.StdCall)] public static extern int mySum (int a, int b,ref int c); } 在C#中調(diào)用測(cè)試: int c=0; int iSum= RefComm. mySum(,, ref c); 運(yùn)行查看結(jié)果iSum 和c均為5,調(diào)用正確。
11、 經(jīng)過(guò)以上幾個(gè)步驟的試驗(yàn),基本掌握了如何定義動(dòng)態(tài)庫(kù)函數(shù)以及如何在 C# 定義導(dǎo)入,有此基礎(chǔ),很快我實(shí)現(xiàn)了變長(zhǎng)加密函數(shù)在 C# 中的調(diào)用,至此目標(biāo)實(shí)現(xiàn)。
12、 三、結(jié)論 在 C# 中調(diào)用 C++ 編寫(xiě)的動(dòng)態(tài)鏈接庫(kù)函數(shù),如果需要出口參數(shù)輸出,則需要使用指針,對(duì)于字符串,則需要使用雙重指針,對(duì)于 C# 的導(dǎo)入定義,則需要使用引用(ref)定義。
13、 對(duì)于函數(shù)返回值,C# 導(dǎo)入定義和 C++ 動(dòng)態(tài)庫(kù)函數(shù)聲明定義需要保持一致,否則會(huì)出現(xiàn)函數(shù)調(diào)用失敗。
14、定義導(dǎo)入時(shí),一定注意 CharSet 和 CallingConvention 參數(shù),否則導(dǎo)致調(diào)用失敗或結(jié)果異常。
15、運(yùn)行時(shí),動(dòng)態(tài)鏈接庫(kù)放在 C# 程序的目錄下即可,我這里是一個(gè) C# 的動(dòng)態(tài)鏈接庫(kù),兩個(gè)動(dòng)態(tài)鏈接庫(kù)就在同一個(gè)目錄下運(yùn)行。
本文分享完畢,希望對(duì)大家有所幫助。
標(biāo)簽:
免責(zé)聲明:本文由用戶上傳,如有侵權(quán)請(qǐng)聯(lián)系刪除!