libpq默认是可再入的并且是线程安全的。你可能需要使用特殊的编译器命令行选项来编译你的应用代码。参考你的系统文档来了解如何编译启用线程的应用,或者在src/Makefile.global
中查找PTHREAD_CFLAGS
和PTHREAD_LIBS
。这个函数允许查询 libpq的线程安全状态:
PQisthreadsafe
返回libpq库的线程安全状态。
int PQisthreadsafe();
如果libpq是线程安全的则返回 1,否则返回 0。
一个线程限制是不允许两个线程同时尝试操纵同一个PGconn
对象。特别是你不能从不同的线程通过同一个连接对象发出并发的命令(如果你需要运行并发命令,请使用多个连接)。
PGresult
对象在创建后通常是只读的,并且因此可以在线程之间自由地被传递。但是,如果你使用任何第 33.11 节或第 33.13 节中描述的 PGresult
修改函数,你需要负责避免在同一个PGresult
上的并发操作。
被废弃的函数PQrequestCancel
以及PQoidStatus
不是线程安全的并且不应当在多线程程序中使用。 PQrequestCancel
可以被替换为PQcancel
。 PQoidStatus
可以被替换为PQoidValue
。
如果你在应用中使用 Kerberos (除了在libpq中之外),你将需要对 Kerberos 调用加锁,因为 Kerberos 函数不是线程安全的。参考libpq源代码中的PQregisterThreadLock
函数,那里有在libpq和应用之间做合作锁定的方法。
备案信息: 粤ICP备15087711号-2
Copyright © 2008-2024 啊嘎哇在线工具箱 All Rights.
本站所有资料来源于网络,版权归原作者所有,仅作学习交流使用,如不慎侵犯了您的权利,请联系我们。