日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
python動態(tài)函數(shù)入?yún)?python函數(shù)接受任意參數(shù)

請教python調(diào)用dll動態(tài)庫的傳參問題

第一步,我先從簡單的調(diào)用出發(fā),定義了一個簡單的函數(shù),該函數(shù)僅僅實現(xiàn)一個整數(shù)加法求和: LIBEXPORT_API int mySum(int a,int b){ return a+b;} C# 導入定義: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=CharSet.Auto,CallingConvention=CallingConvention.StdCall)] public static extern int mySum (int a,int b); } 在C#中調(diào)用測試: int iSum = RefComm.mySum(,); 運行查看結(jié)果iSum為5,調(diào)用正確。第一步試驗完成,說明在C#中能夠調(diào)用自定義的動態(tài)鏈接庫函數(shù)。 第二步,我定義了字符串操作的函數(shù)(簡單起見,還是采用前面的函數(shù)名),返回結(jié)果為字符串: LIBEXPORT_API char *mySum(char *a,char *b){sprintf(b,"%s",a); return a;} C# 導入定義: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=CharSet.Auto, CallingConvention=CallingConvention.StdCall)] public static extern string mySum (string a, string b); } 在C#中調(diào)用測試: string strDest=""; string strTmp= RefComm.mySum("45", strDest); 運行查看結(jié)果 strTmp 為"45",但是strDest為空。我修改動態(tài)鏈接庫實現(xiàn),返回結(jié)果為串b: LIBEXPORT_API char *mySum(char *a,char *b){sprintf(b,"%s",a) return b;} 修改 C# 導入定義,將串b修改為ref方式: public class RefComm { [DllImport("LibEncrypt.dll", EntryPoint=" mySum ", CharSet=CharSet.Auto,CallingConvention=CallingConvention.StdCall)] public static extern string mySum (string a, ref string b); } 在C#中再調(diào)用測試: string strDest=""; string strTmp= RefComm.mySum("45", ref strDest); 運行查看結(jié)果 strTmp 和 strDest 均不對,含不可見字符。再修改 C# 導入定義,將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)用測試: string strDest=""; string strTmp= RefComm. mySum("45", ref strDest); 運行查看結(jié)果 strTmp 為"45",但是串 strDest 沒有賦值。第二步實現(xiàn)函數(shù)返回串,但是在函數(shù)出口參數(shù)中沒能進行輸出。再次修改 C# 導入定義,將串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); } 運行時調(diào)用失敗,不能繼續(xù)執(zhí)行。 第三步,修改動態(tài)鏈接庫實現(xiàn),將b修改為雙重指針: LIBEXPORT_API char *mySum(char *a,char **b){sprintf((*b),"%s",a); return *b;} C#導入定義: 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)用測試: string strDest=""; string strTmp= RefComm. mySum("45", ref strDest); 運行查看結(jié)果 strTmp 和 strDest 均為"45",調(diào)用正確。第三步實現(xiàn)了函數(shù)出口參數(shù)正確輸出結(jié)果。 第四步,修改動態(tài)鏈接庫實現(xiàn),實現(xiàn)整數(shù)參數(shù)的輸出: LIBEXPORT_API int mySum(int a,int b,int *c){ *c=a+b; return *c;} C#導入的定義: 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)用測試: int c=0; int iSum= RefComm. mySum(,, ref c); 運行查看結(jié)果iSum 和c均為5,調(diào)用正確。 經(jīng)過以上幾個步驟的試驗,基本掌握了如何定義動態(tài)庫函數(shù)以及如何在 C# 定義導入,有此基礎,很快我實現(xiàn)了變長加密函數(shù)在 C# 中的調(diào)用,至此目標實現(xiàn)。 三、結(jié)論 在 C# 中調(diào)用 C++ 編寫的動態(tài)鏈接庫函數(shù),如果需要出口參數(shù)輸出,則需要使用指針,對于字符串,則需要使用雙重指針,對于 C# 的導入定義,則需要使用引用(ref)定義。 對于函數(shù)返回值,C# 導入定義和 C++ 動態(tài)庫函數(shù)聲明定義需要保持一致,否則會出現(xiàn)函數(shù)調(diào)用失敗。定義導入時,一定注意 CharSet 和 CallingConvention 參數(shù),否則導致調(diào)用失敗或結(jié)果異常。運行時,動態(tài)鏈接庫放在 C# 程序的目錄下即可,我這里是一個 C# 的動態(tài)鏈接庫,兩個動態(tài)鏈接庫就在同一個目錄下運行。

成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供平原企業(yè)網(wǎng)站建設,專注與網(wǎng)站建設、網(wǎng)站設計、H5頁面制作、小程序制作等業(yè)務。10年已為平原眾多企業(yè)、政府機構(gòu)等服務。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進行中。

Python 的函數(shù)是怎么傳遞參數(shù)的?

首先你要明白,Python的函數(shù)傳遞方式是賦值,而賦值是通過建立變量與對象的關聯(lián)實現(xiàn)的。

對于你的代碼:

執(zhí)行 d = 2時,你在__main__里創(chuàng)建了d,并讓它指向2這個整型對象。

執(zhí)行函數(shù)add(d)過程中:

d被傳遞給add()函數(shù)后,在函數(shù)內(nèi)部,num也指向了__main__中的2

但執(zhí)行num = num + 10之后,新建了對象12,并讓num指向了這個新對象——12。

如果你明白函數(shù)中的局部變量與__main__中變量的區(qū)別,那么很顯然,在__main__中,d仍在指著2這個對象,它沒有改變。因此,你打印d時得到了2。

如果你想讓輸出為12,最簡潔的辦法是:

在函數(shù)add()里增加return num

調(diào)用函數(shù)時使用d = add(d)

代碼如下:

def add(num):

num += 10

return num

d = 2

d = add(d)

print d

python怎么給函數(shù)傳參

函數(shù)參數(shù)傳遞機制問題在本質(zhì)上是調(diào)用函數(shù)(過程)和被調(diào)用函數(shù)(過程)在調(diào)用發(fā)生時進行通信的方法問題?;镜膮?shù)傳遞機制有兩

種:值傳遞和引用傳遞。

推薦:Python教程

值傳遞(passl-by-value)過程中,被調(diào)函數(shù)的形式參數(shù)作為被調(diào)函數(shù)的局部變量處理,即在堆棧中開辟了內(nèi)存空間以存放由主調(diào)函數(shù)放

進來的實參的值,從而成為了實參的一個副本。值傳遞的特點是被調(diào)函數(shù)對形式參數(shù)的任何操作都是作為局部變量進行,不會影響主調(diào)函

數(shù)的實參變量的值。

引用傳遞(pass-by-reference)過程中,被調(diào)函數(shù)的形式參數(shù)雖然也作為局部變量在堆棧中開辟了內(nèi)存空間,但是這時存放的是由主調(diào)函

數(shù)放進來的實參變量的地址。被調(diào)函數(shù)對形參的任何操作都被處理成間接尋址,即通過堆棧中存放的地址訪問主調(diào)函數(shù)中的實參變量。正

因為如此,被調(diào)函數(shù)對形參做的任何操作都影響了主調(diào)函數(shù)中的實參變量。

更多技術請關注Python視頻教程。


當前題目:python動態(tài)函數(shù)入?yún)?python函數(shù)接受任意參數(shù)
文章轉(zhuǎn)載:http://www.dlmjj.cn/article/hedijh.html