小编vse*_*har的帖子

具有自定义比较谓词的heapq

我正在尝试使用自定义排序谓词构建堆.由于进入它的值是'用户定义'类型,我无法修改它们的内置比较谓词.

有没有办法做这样的事情:

h = heapq.heapify([...], key=my_lt_pred)
h = heapq.heappush(h, key=my_lt_pred)
Run Code Online (Sandbox Code Playgroud)

或者甚至更好,我可以将heapq函数包装在我自己的容器中,这样我就不需要继续传递谓词了.

python sorting algorithm containers dictionary

61
推荐指数
4
解决办法
5万
查看次数

将SIGINT(Ctrl-C)发送到在Eclipse控制台中运行的程序

我在Eclipse中设置了运行配置,需要将SIGINT(Ctrl+ C)发送到程序.在SIGINT之后运行的程序中有清理代码,因此按下Eclipse的"终止"按钮将不起作用(我认为它们发送SIGKILL).在控制台中键入CTRL+ C也不起作用.

如何将SIGINT发送到在Eclipse控制台内运行的进程?

(FWIW我正在运行Twisted守护程序并且需要Twisted才能正确关闭,这只发生在SIGINT上)

python eclipse twisted sigint

25
推荐指数
1
解决办法
1万
查看次数

twisted - 获取OS选择的监听端口

我正在使用应用程序框架编写一个扭曲的P2P客户端.传入连接的侦听端口将位于随机(OS确定)端口上.但是,我需要一种方法来确定创建它后该端口是什么:

import twisted... etc.

application = service.Application('vmesh')
peerservice = MyPeerService()
servicecollection = service.IServiceCollection(application)
factory = MyPeerFactory(peerservice)
server = internet.TCPServer(0, factory) # listen on random port
listen_port = server.getHost().port # ??? doesn't work...
server.setServiceParent(servicecollection)
Run Code Online (Sandbox Code Playgroud)

我在文档中找不到有关查询由其创建internet.TCPServer()或由其reactor.listenTCP()转发的端口的任何内容.我不能简单地等待连接发生,因为客户端必须宣布其端口才能实现这些连接.

python p2p tcp twisted

9
推荐指数
1
解决办法
3599
查看次数

boost multi_index提取的密钥是否被缓存?

我正在使用boost :: multi_index,我希望根据数据类型对其进行索引.但是,此数据类型的size()成员函数执行起来很昂贵.multi_index是否缓存从其关键提取器获取的值?

例如,如果我创建了一个带有成员函数键(element.size())的有序索引的multi_index容器,并插入了一个大小将其放在容器中间某个位置的元素,那么容器是否会重新调用该大小()成员函数在查找正确的插入点之前遍历其内部数据结构时访问的所有元素?

c++ boost multi-index boost-multi-index

7
推荐指数
1
解决办法
513
查看次数

函数指针是否在进程间保持有效?

我编写了一个扩展模块,它使用C++函数指针来存储函数调用序列.我想使用python的multiprocessing模块在不同的进程中"运行"这些调用序列(没有共享状态,因此没有同步问题).

我需要知道,如果函数指针(不是数据指针)仍然有效,后multiprocessing做它的fork().

C++模块:

#include <list>
#include <boost/assert.hpp>
#include <boost/python.hpp>
#include <boost/python/stl_iterator.hpp>
#include <boost/foreach.hpp>

/*
 * Some functions to be called
 */
double funcA(double d) { return d; }
double funcB(double d) { return d + 3.14; }
double funcC(double d) { return d - 42.0; }

/*
 * My container of function pointers (picklable to allow use with multiprocessing)
 */
typedef double(*func_ptr_t)(double);
struct CallSequence {
    CallSequence() {
        _seq.push_back(funcA);
        _seq.push_back(funcB);
        _seq.push_back(funcC);
    }

    std::list<func_ptr_t> _seq;
}; …
Run Code Online (Sandbox Code Playgroud)

c++ python function-pointers multiprocessing python-extensions

6
推荐指数
1
解决办法
484
查看次数

有没有办法使用python apt模块添加ppa?

我需要使用python脚本向远程服务器添加一个ppa.bash相当于我想要做的是:

$ add-apt-repository ppa:user/ppa-name
Run Code Online (Sandbox Code Playgroud)

我假设它看起来像这样:

import apt
cache = apt.Cache()
# ?? add the ppa here ??
cache.update()
cache.open(None)
cache['package_from_ppa'].mark_install()
cache.upgrade()
cache.commit()
Run Code Online (Sandbox Code Playgroud)

但我在apt模块源中找不到与添加存储库相关的内容.

python ubuntu debian apt

5
推荐指数
1
解决办法
881
查看次数

未定义的 boost python 符号:boost::python::detail::init_module

尝试导入使用 boost python 编译的扩展时出现未定义符号错误,该符号应该包含在 boost 库中。

我使用的是 Boost 1.46.1、Python 3.1.2 和 GCC 4.4.5。

我使用以下方法构建了 boost:

$ ./bootstrap.sh --with-python-version=3.1
$ sudo ./bjam -j4 install
Run Code Online (Sandbox Code Playgroud)

然后我编译了以下简单的 Boost Python 库:

#include <boost/python.hpp>

struct mystruct {
    int i;
};

BOOST_PYTHON_MODULE(test) {
    using namespace boost::python;
    class_<mystruct>("Mystruct")
        .def_readwrite("i", &mystruct::i)
        ;
}
Run Code Online (Sandbox Code Playgroud)

使用命令:

$ g++ -shared question.cpp -I/usr/include/python3.1 -lboost_python3 -lpython3.1 -otest.so
Run Code Online (Sandbox Code Playgroud)

成功而没有错误。

然后我尝试在 python 中运行它,但它似乎找不到 init_module 函数 boost python 应该提供:

$ python3
Python 3.1.2 (release31-maint, Sep 17 2010, 20:34:23) 
[GCC 4.4.5] on linux2
Type "help", "copyright", "credits" …
Run Code Online (Sandbox Code Playgroud)

python boost-python python-3.x

4
推荐指数
1
解决办法
6620
查看次数