test.c(動態(tài)庫源代碼)
姚安網站建設公司成都創(chuàng)新互聯(lián)公司,姚安網站設計制作,有大型網站制作公司豐富經驗。已為姚安數(shù)千家提供企業(yè)網站建設服務。企業(yè)網站搭建\成都外貿網站建設公司要多少錢,請找那個售后服務好的姚安做網站的公司定做!
[cpp] view plain copy
// 編譯生成動態(tài)庫: gcc -g -fPIC -shared -o libtest.so test.c
#include stdio.h
#include string.h
#include stdlib.h
typedef struct StructPointerTest
{
char name[20];
int age;
}StructPointerTest, *StructPointer;
StructPointer test() // 返回結構體指針
{
StructPointer p = (StructPointer)malloc(sizeof(StructPointerTest));
strcpy(p-name, "Joe");
p-age = 20;
return p;
}
編譯:gcc -g -fPIC -shared -o libtest.so test.c
call.py(python調用C語言生成的動態(tài)庫):
[python] view plain copy
#!/bin/env python
# coding=UTF-8
from ctypes import *
#python中結構體定義
class StructPointer(Structure):
_fields_ = [("name", c_char * 20), ("age", c_int)]
if __name__ == "__main__":
lib = cdll.LoadLibrary("./libtest.so")
lib.test.restype = POINTER(StructPointer)
p = lib.test()
print "%s: %d" %(p.contents.name, p.contents.age)
最后運行結果:
[plain] view plain copy
[zcm@c_py #112]$make clean
rm -f *.o libtest.so
[zcm@c_py #113]$make
gcc -g -fPIC -shared -o libtest.so test.c
[zcm@c_py #114]$./call.py
Joe: 20
[zcm@c_py #115]$
python對指針做了良好的封裝,一切都是對象。一切對象都有一個變量,指向他這個變量就是指針。跟java不一樣, 他不可以隨機移動,不可以運算。包括函數(shù)也是一個對象,用一個變量指向它,就是指向函數(shù)的入口地址。
如果您曾經使用過C或C ++等低級語言,那么您可能已經聽說過指針。指針允許您在部分代碼中創(chuàng)建高效率。它們也會給初學者帶來困惑,并且可能導致各種內存管理錯誤,即使對于專家也是如此。那么在Python中有指針的存在嗎?
指針廣泛用于C和C ++。本質上,它們是保存另一個變量的內存地址的變量。有關指針的更新,可以考慮在C指針上查看此概述。
為什么Python沒有指針?
實際上指針為何不存在的原因現(xiàn)在還不知道,也許指針違背了Python的禪宗。指針鼓勵隱含的變化而不是明確的變化。但通常情況下,它們很復雜而不是很簡單,特別是對于初學者。更糟糕的是,當他們用指針指向自己的方法,或做一些非常危險的事情,比如從你無法獲取的的一些變量中讀取數(shù)據。
Python更傾向于嘗試從用戶那里抽象出內存地址來實現(xiàn)具體細節(jié),所以Python通常關注可用性而不是速度。因此,Python中的指針并沒有多大意義。但是在有些情況下,Python會為您提供使用指針的一些好處。
想要理解Python中的指針,需要理解Python實現(xiàn)指針功能的具體細節(jié)。簡單來說,需要了解這些知識點:
不可變對象和可變對象【Python中的對象】
Python變量/名稱【Python中的變量】
【在Python中模擬實現(xiàn)指針】