想把一些C++的类封装成Python的库,写测试和demo的时候快捷很多,试用了一下boost python,感觉挺不错,就把使用过程中几个常见的问题记录下来。
1 STL中的string可以直接对应到Python的str类型,因此无论是作为对象成员还是函数返回值都可以直接使用,但其它类型貌似不可以;
2 虽然不方便返回vector、list等,但可以定义一个简单的包装函数返回vector、list中的元素和大小等;
3 如果返回以'/0'结尾的字符串,则将char *类型作为对象成员或是函数返回值都可以;但如果返回的是字节数组,则无法判断数组的长度,这时可以将char *类型包装为string返回,string包含了字节数组和数组的长度;
4 如果返回的是一个对象的指针或者引用,包括内部对象和动态分配的对象,在def时都需要在第三个参数使用return_internal_reference<>(),否则编译错误;
5 如果函数的参数是自定义的对象,则可以在参数使用对象指针和引用,其效果和C++中相同;
6 如果不想让对象在Python中创建,则在def时指定no_init指名,可以指定多个构造函数,在多个def中使用init<argument-list>;
1 STL中的string可以直接对应到Python的str类型,因此无论是作为对象成员还是函数返回值都可以直接使用,但其它类型貌似不可以;
2 虽然不方便返回vector、list等,但可以定义一个简单的包装函数返回vector、list中的元素和大小等;
3 如果返回以'/0'结尾的字符串,则将char *类型作为对象成员或是函数返回值都可以;但如果返回的是字节数组,则无法判断数组的长度,这时可以将char *类型包装为string返回,string包含了字节数组和数组的长度;
4 如果返回的是一个对象的指针或者引用,包括内部对象和动态分配的对象,在def时都需要在第三个参数使用return_internal_reference<>(),否则编译错误;
5 如果函数的参数是自定义的对象,则可以在参数使用对象指针和引用,其效果和C++中相同;
6 如果不想让对象在Python中创建,则在def时指定no_init指名,可以指定多个构造函数,在多个def中使用init<argument-list>;