python封装成库函数 python中封装函数( 三 )


大家考虑这一下这样的函数:
void foo(char*s)
{
s = (char*)malloc(10);
memcpy(s,"123456789",9);
}
s这个参数表面上看是输入,实际上是函数真正的输出 。函数中真正改变的东西是chars指向的字符串的值 。而且char这个类型,
python或者其他脚本语言里应该都没有对应的类型 。那么我们用cstring_output_allocate将这个函数转换成另外一个形式的python或者其他脚本语言的函数 。转换后的函数其实是这样的 , 以python为例str
foo() 。
!-- lang: cpp --
%module a
%include "cstring.i"
%{
void foo(char* s);
%}
%cstring_output_allocate(char *s, free(*$1));
void foo(char *s);
在python中的调用:
!-- lang: python --
import a
a.foo()
'123456789'
cstring_output_maxsize(char *path, int maxpath);
第一个参数也是可以改变的字符串首地址,第二个参数为字符串的最大长度 。在Python中调用的时候,只有maxpath这个参数,返回字符串 。
cstring_output_allocate(char *s, free($1));
第一个参数为指向字符串首地址的指针 , 第二个参数为释放指针的方法 。这个宏主要是封装一种直接在函数内部malloc空间的函数 。在Python中调用时没有参数 , 直接返回字符串 。
cstring_output_allocate_size(char *s, int slen, free(*$1));
这个相当于前面两个函数的组合 。在函数内部malloc空间,然后将字符串长度通过slen返回 。其实在调用的时候非常简单,没有参数,直接返回字符串 。
如何处理c++的std::string
std::string是C++标准类库STL中常见的类 。在平时工作中大家肯定是没少用 。在python中如何封装std::string? swig提供了标准库
例如函数:
!-- lang: cpp --
string Repeat(const string s)
{
return s+s;
}
只要在swig中加入这样几行:
!-- lang: cpp --
%include "std_string.i"
using namespace std;
string Repeat(const string s);
运行结果:
Python 2.6.6 (r266:84292, Dec 27 2010, 00:02:40)
[GCC 4.4.5] on linux2
Type "help", "copyright", "credits" or "license" for more information.
import cchar
cchar.Repeat('123')
'123123'
使用起来很方便,但需要注意的是,假如函数的参数的内容是可以被修改,就不能用这种方式封装 。
例如:
!-- lang: cpp --
void repeat(string s)
{
s+=s;
}
这样的函数直接使用 'std_string.i' 就是无效的 。遇到这种函数 , 只能用C语言封装成 void repeat(chars, int maxsize), 再用swig调用 'cstring_output_withsize' 这个宏再封装一次了 。
python如何封装函数可以定义一个类,类里定义很多函数(主要用它做什么)或直接定义函数在一个py文件中
在另一个文件中导入这个那个py包,调用类和方法
就是封装了
【python封装成库函数 python中封装函数】关于python封装成库函数和python中封装函数的介绍到此就结束了 , 不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

推荐阅读