热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

基于嵌入式SQL和C语言多线程的DB2workload开发

本文将系统的介绍基于嵌入式SQL和C语言多线程的DB2workload开发的流程,并提供详细的程序示例清单。通过本文对C语言多线程的深入介绍和对构建支持多线程访问的嵌入式SQL上下文环境的分析,读者可以快速的掌握这种DB2workload的开发方法,创建高

本文将系统的介绍基于嵌入式 SQL 和 C 语言多线程的 DB2 workload 开发的流程,并提供详细的程序示例清单。通过本文对 C 语言多线程的深入介绍和对构建支持多线程访问的嵌入式 SQL 上下文环境的分析,读者可以快速的掌握这种 DB2 workload 的开发方法,创建高

由于程序示例代码的重用性较高,可以大大的提高需要使用这种 DB2 workload 的软件自动化测试人员,使用 C 语言多线程访问 DB2 的软件开发人员的工作效率。

众所周知,在使用 DB2 的实际生产环境中, 我们会遇到各种各样的应用,例如基于不同的开发语言,基于不同的体系架构或者基于不同的连接方式等等。针对这些不同的 workload, 我们从事 DB2 性能监控工具测试工作的软件人员,必须开发一些相对应的 workload 去模拟这些生产环境,才能得到较为合理的测试结果,更多的发现 DB2 性能监控工具存在的潜在问题。

查看了很多 DB2 上运行的 workload 介绍,发现基于嵌入式 SQL 和 C 语言多线程的 workload 相对较少,针对这种情况,本文在系统分析了 C 语言多线程技术和构建支持多线程访问的嵌入式 SQL 上下文环境的基础上,提出并详细介绍了基于嵌入式 SQL 和 C 语言多线程的 DB2 workload 的开发流程,最后使用了一个具体的代码实例详细的演示了这个开发流程。

C 语言多线程介绍

一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源。进程是由多个线程所组成的。线程是程序中的一个执行流,每个线程都有自己的专有寄存器 ( 栈指针、程序计数器等 ),但代码区是共享的,即不同的线程可以执行同样的函数和代码段。多线程是指程序中包含多个执行流,即在一个程序中可以同时运行多个不同的线程来执行不同的任务,也就是说允许单个程序创建多个并行执行的线程来完成各自的任务。

C 语言最初并未设计多线程的机制,由于随着软硬件的发展及需求的扩展,C 语言才开发了线程库以支持多线程的操作、应用。本文主要介绍 Linux 下的 C 语言多线程, Linux 系统下的 C 语言多线程遵循 POSIX 线程接口,称为 pthread。Linux 下 pthread 的实现是通过系统调用 clone() 来实现的。Clone() 是 Linux 所特有的系统调用。编写 Linux 下的 C 语言多线程程序,需要使用头文件"pthread.h",连接时需要使用库 libpthread.a。因此,必须在编译中加入 -lpthread 选项,否则提示找不到 pthread_create() 等相关的多线程函数。下面将详细的介绍一些重要的 Linux 下 C 语言多线程程序调用的 API。

线程的创建:

int pthread_create(pthread_t*restrict tidp,const pthread_attr_t *restrict attr,
 void *(*start_rtn)(void),void *restrict arg);
  • 创建线程成功时,函数返回 0,若不为 0 则说明创建线程失败,常见的错误返回代码为 EAGAIN 和 EINVAL。前者表示系统限制创建新的线程,例如线程数目过多了;后者表示第二个参数代表的线程属性值非法。
  • 第一个参数为指向线程标识符的指针,第二个参数用来设置线程属性,第三个参数是线程运行函数的起始地址,最后一个参数是运行函数的参数。

线程的挂起和退出:

int pthread_join(pthread_t thread, void **value_ptr);
  • 该函数的作用使得当前线程挂起,等待另一个线程返回才继续执行,也就是说当程序运行到这个地方时,程序会先停止,然后等线程 id 为 thread 的这个线程返回,然后程序才会断续执行。
  • 第一个参数为被等待的线程标识符,第二个参数为一个用户定义的指针,它可以用来存储被等待线程的返回值。
 void pthread_exit(void *rval_ptr);
  • 一个线程的结束有两种途径,一种是函数结束了,调用它的线程也就结束了;另一种方式是通过调用函数 pthread_exit 来实现。
  • 唯一的参数是函数的返回代码。

线程间的互斥锁:

int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutex_attr_t* attr);
  • 互斥锁初始化:第一个参数是互斥锁变量指针,第二个参数是互斥锁属性,传入 NULL 使用默认属性。
int pthread_mutex_lock(pthread_mutex_t *mutex);
  • 互斥锁锁定:唯一参数是互斥锁变量指针。如果互斥锁已经被锁定,当前线程将被阻塞,直到,其他线程对互斥锁解锁。
int pthread_mutex_unlock(pthread_mutex_t *mutex);
  • 互斥锁解锁:唯一的参数是互斥锁变量指针。如果当前线程拥有参数 mutex 所指定的互斥锁,该调用将该互斥锁解锁。

Linux 系统下的 C 语言多线程程序的执行流程如下:

图 1. 多线程程序执行流程


采用了 C 语言多线程技术的应用程序可以更好地利用系统资源,其主要优势在于充分利用了 CPU 的空闲时间片,可以用尽可能少的时间来对用户的要求做出响应,既使得进程的整体运行效率得到较大提高,又同时增强了应用程序的灵活性。

推荐阅读
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 学习SLAM的女生,很酷
    本文介绍了学习SLAM的女生的故事,她们选择SLAM作为研究方向,面临各种学习挑战,但坚持不懈,最终获得成功。文章鼓励未来想走科研道路的女生勇敢追求自己的梦想,同时提到了一位正在英国攻读硕士学位的女生与SLAM结缘的经历。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 近年来,大数据成为互联网世界的新宠儿,被列入阿里巴巴、谷歌等公司的战略规划中,也在政府报告中频繁提及。据《大数据人才报告》显示,目前全国大数据人才仅46万,未来3-5年将出现高达150万的人才缺口。根据领英报告,数据剖析人才供应指数最低,且跳槽速度最快。中国商业结合会数据剖析专业委员会统计显示,未来中国基础性数据剖析人才缺口将高达1400万。目前BAT企业中,60%以上的招聘职位都是针对大数据人才的。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文主要讨论了在xps15上安装双系统win10和MacOS后,win10无法正常更新的问题。分析了可能的引导问题,并提供了解决方法。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • 树莓派Linux基础(一):查看文件系统的命令行操作
    本文介绍了在树莓派上通过SSH服务使用命令行查看文件系统的操作,包括cd命令用于变更目录、pwd命令用于显示当前目录位置、ls命令用于显示文件和目录列表。详细讲解了这些命令的使用方法和注意事项。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
author-avatar
五月妖精23
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有