线程是任务调度的基本单位,一个进程中可以有多个线程,每个线程有自己的堆栈空间,

进程中的代码段、数据段和堆栈对进程中的线程是可见的。在使用线程时通常都要考虑数据的安全访问。

常用的线程同步方法有:

  • 互斥变量
  • 读写锁
  • 条件变量
  • 屏障
  • 自旋锁(用于CPU,锁住后CPU将不执行其他事情,即一直等待)

在OCCI程序中使能线程安全,则应指定THREADED_MUTEXED选项创建运行环境

例如:
Environment *env =
Environment::createEnvironment(Environment::THREADED_MUTEXED)

注意:

  • 如果应用程序是单线程,则使用默认值创建环境即可;

    如果指定THREADED_MUTEXED选项创建将会影响应用程序性能。
  • OCCI中的线程安全仅仅指的是EnvironmentMapConnectionPool

    StatelessConnectionPoolConnection对象。对于StatementResultSet

    SQLExceptionStream等不是线程安全的,因此不应该在多个线程中共享。

以下例子创建一个只有一个连接的无状态连接池,创建两个线程去竞争从池中得到连接

当以线程安全创建环境时程序运行正常,当使用默认选项创建环境时,程序将抛出异常:

what():  ORA-03117: two-task save area overflow
#include <iostream>
#include <cstdlib> #include <pthread.h>
#include <unistd.h>
#include <occi.h> #define USERNAME "scott"
#define PASSWORD "scott"
#define DBNAME "//192.168.42.135:1521/orcl"
#define MAXCON 1
#define MINCON 0
#define INCCON 1 using namespace oracle::occi;
using namespace std; void *displayAllRows(void *arg);
void *updateRow(void *arg); int main(void)
{
Environment *env = Environment::createEnvironment(Environment::THREADED_MUTEXED); //创建无状态连接池
StatelessConnectionPool *scp =
env->createStatelessConnectionPool(
USERNAME, PASSWORD, DBNAME, MAXCON, MINCON, INCCON,
StatelessConnectionPool::HOMOGENEOUS); //设置池中的连接空闲超时时间,超时后OCCI会自动释放此连接,需要时在创建
scp->setTimeOut(10); cout << "*****************Information**************************" << endl;
cout << "Open Connection : " << scp->getOpenConnections() << endl;
cout << "Busy Connection : " << scp->getBusyConnections() << endl;
cout << "Time Out Connection : " << scp->getTimeOut() << endl;
cout << "******************************************************" << endl; pthread_t tid_1, tid_2;
int err = 0;
err = pthread_create(&tid_1, NULL, displayAllRows, (void *)scp);
if (err != 0) {
cout << "create thread failure for tid_1." << endl;
} else {
cout << ">> create thread successful for tid_1." << endl;
} err = pthread_create(&tid_2, NULL, updateRow, (void *)scp);
if (err != 0) {
cout << "create thread failure for tid_2." << endl;
} else {
cout << ">> create thread successful for tid_2." << endl;
} pthread_join(tid_1, (void **)NULL);
pthread_join(tid_2, (void **)NULL); env->terminateStatelessConnectionPool(scp);
Environment::terminateEnvironment(env); return 0;
} void *displayAllRows(void *arg)
{
StatelessConnectionPool *scp = (StatelessConnectionPool *)arg; for ( ; ; )
{
std::cout << ">>>> displayAllRows thread runing [" << long(pthread_self()) << "]" << std::endl; Connection *conn = scp->getConnection(""); string sqlStmt = "SELECT * FROM DEPT WHERE DEPTNO=60"; Statement *stmt = conn->createStatement(sqlStmt); ResultSet *rset = stmt->executeQuery(); try {
while (rset->next()) {
cout << int(rset->getNumber(1)) << " ";
cout << rset->getString(2) << " ";
cout << rset->getString(3) << " ";
cout << endl;
}
}catch(SQLException &ex) {
cout << "display all rows failure." << endl;
cout << ex.getMessage();
cout << endl;
} sleep(5); stmt->closeResultSet(rset);
conn->terminateStatement(stmt);
scp->releaseConnection(conn, "");
} pthread_exit((void *)0);
} void *updateRow(void *arg)
{
StatelessConnectionPool *scp = (StatelessConnectionPool*)arg; for ( ; ; )
{
std::cout << ">>> updateRow thread running [" << long(pthread_self()) << "]" << std::endl; Connection *conn = scp->getConnection(""); string sqlStmt = "UPDATE DEPT SET LOC=:deptLocal WHERE DEPTNO=51"; Statement *stmt = conn->createStatement(sqlStmt); try {
stmt->setString(1, "ShangHai");
stmt->executeUpdate();
conn->commit();
} catch(SQLException &ex) {
cout << "update row failure." << endl;
cout << ex.getMessage();
cout << endl;
} conn->terminateStatement(stmt);
scp->releaseConnection(conn, ""); sleep(1);
} pthread_exit((void *)0);
}

最新文章

  1. 利用JS判断是否手机或pad访问
  2. LinkedList实现队列和堆栈的代码
  3. JAVA 中XML的解析
  4. c#实现分组服务器,单一无重复生成ID
  5. Swift - 开源框架总结
  6. stoneniqiu 理想就是自己喜欢做,并对社会和他人都有意义的事情!
  7. Android studio的深坑 导jar包重复的异常处理
  8. sql语句原则
  9. Python中split()函数的用法及实际使用示例
  10. HDU 3687 National Day Parade (暴力)
  11. Java通过socket实现smtp协议发送邮件
  12. 问题-Delphi在多线程中使用其他窗体上的控件,报“尚未调用CoInitialize”解决方法
  13. csqlite编译相关配置问题
  14. 利用CMake生成动态或静态链接库工程
  15. POJ_1631_Bridging_Signals_(动态规划,LIS)
  16. [leetcode]二分查找总结
  17. PHP操作MySQL数据库的相关函数
  18. Reorder the Books(规律)
  19. 毕业原版=[约克大学毕业证书]York原件一模一样证书
  20. Django 无名参数与有名参数

热门文章

  1. 对象池2(方法功能)Pools
  2. Linux raw socket
  3. WebGL 踩坑系列-2
  4. 学习JVM-GC原理
  5. angularjs ui-grid如何动态设置行高
  6. ASP.NET Core后台任务
  7. 一步步理解typedef
  8. Debug view 是个好工具
  9. PhoneGap&amp;jQuery Mobile应用开发环境配置(For Android)
  10. Struts2_HelloWorld_2