当前位置: 首页 > news >正文

中国银行建设网站首页微博搜索引擎优化

中国银行建设网站首页,微博搜索引擎优化,房屋装修设计网,wordpress后台新建慢目录 一,线程函数 1.获取当前线程ID 2.创建线程 3.退出线程 4.阻塞线程 5.分离线程 6.取消线程 7.线程比较 8.测试代码(线程函数总结) 二,线程同步 1.互斥锁 2.读写锁 3.条件变量 4.信号量 一,线程函数 …

目录

一,线程函数

1.获取当前线程ID

2.创建线程

3.退出线程

4.阻塞线程

5.分离线程

6.取消线程

7.线程比较

8.测试代码(线程函数总结)

二,线程同步

1.互斥锁

2.读写锁

3.条件变量

4.信号量


一,线程函数

  • 参考文章: 线程 | 爱编程的大丙

man command                //Linux终端命令

# 查阅 command 命令的使用手册,包含了绝大部分的命令和函数的详细使用说明

获取当前线程IDpthread_t pthread_self(void);
创建线程int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine)(void *),void *arg);
退出线程void pthread_exit(void *retval);
阻塞线程int pthread_join(pthread_t thread, void **retval);
分离线程int pthread_detach(pthread_t thread);
取消线程(杀死线程)int pthread_cancel(pthread_t thread);
线程比较int pthread_equal(pthread_t t1, pthread_t t2);

1.获取当前线程ID

//获取当前线程的线程ID,ID类型为pthread_t,它是一个无符号长整型数
pthread_t pthread_self(void);
  • 返回值: 永远返回成功,返回被调用者的线程ID

2.创建线程

//在进程中调用线程创建函数来创建一个子线程
int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine)(void *),void *arg);
参数介绍
thread输出参数,线程创建成功会将线程ID写入到该指针所指向的内存中
attr线程的属性,一般设置为NULL,即线程的创建使用默认属性
start_routine函数指针,子线程的业务处理函数,即传入的函数指针会在该子线程中执行
arg函数参数,和start_routine指针指向的函数参数匹对,即该参数是传递给start_routine指针所指向的函数
  • 返回值:创建成功返回0,创建失败返回一个错误号并且*thread值未定义

3.退出线程

//线程退出不会影响到其它线程的正常运行,子线程或主线程都可以调用
void pthread_exit(void *retval);
  • 参数:被调用线程退出时,其它线程可通过retval获取线程退出时携带的数据。不需要数据可以指定为NULL

4.阻塞线程

//函数被调用一次,只会回收一个子线程,如果有多个线程需要循环传入线程ID进行回收
int pthread_join(pthread_t thread, void **retval);
  • 参数介绍
    • thread:要被阻塞的线程ID,指定的线程必须是可被阻塞的
    • retval:所指向一级指针的地址是一个输出参数,该地址中存储了pthread_exit()传出的数据,不需要数据可以指定为NULL
  • 返回值:成功返回0,失败返回一个错误码

5.分离线程

/*
1.传入分离子线程的线程ID,便会与主线程分离,当子线程退出的时候,其占用的资源就会被系统的其它进程接管并回收。
2.不可对同一线程重复分离,不然会出现未定义行为
*/
int pthread_detach(pthread_t thread);

6.取消线程

int pthread_cancel(pthread_t thread);

7.线程比较

int pthread_equal(pthread_t t1, pthread_t t2);

8.测试代码(线程函数总结)

#include <cstdio>
#include <stdlib.h>
#include <unistd.h>
#include <pthread.h>//子线程处理代码
void* threadFun(void *_arg){printf("子线程线程ID:%ld 传入参数值:%ld\n", pthread_self(),*(int*)_arg);for (int i = 0; i < 5; i++){sleep(1);printf("subThread-i: = %d\n", i);if (i == 3) {int* val = (int*)malloc(sizeof(int));*val = i;pthread_exit(val);  //子线程退出携带的数据val可以被主线程中调用pthread_join获取}}return nullptr;
}int main()
{printf("主线程线程ID:%ld\n", pthread_self());for (int i = 0; i < 5; i++){sleep(1);printf("main-i: = %d\n", i);}pthread_t tid;  //创建一个子线程int thread_arg = 1008;   //传给threadFun()线程工作函数的参数int flag = pthread_create(&tid, nullptr, threadFun, (void*)&thread_arg);if (flag == 0){printf("子线程创建成功,线程ID:%ld  传入threadFun()线程函数的参数值:%d\n", tid,thread_arg);}//pthread_detach(tid);    /** 线程分离之后在主线程使用pthread_join()就会报段错误(核心已转储)* ,因为子线程退出时,其占用的内核资源被系统其它进程回收了,然而你又对它进行操作。*/void *subTd_retval = nullptr;pthread_join(tid, &subTd_retval);   //阻塞子线程,并获取子线程退出时的数据printf("子线程 %ld 返回的数据:%ld\n", tid, *(int*)subTd_retval);pthread_detach(tid);    //这里让子线程与主线程分离pthread_exit(nullptr);  //让主线程自己退出return 0;
}

二,线程同步

 参考文章: 线程同步 | 爱编程的大丙

1.当多个线程对共享资源(多个线程共同访问的变量)进行访问的时候就会出现数据混乱的问题,所以就需要进行线程同步,所谓的线程同步实际上是各线程按先后顺序依次对共享资源进行访问,而不是同时进行的,其实也就是让各线程去抢占CPU时间片,抢到就访问数据,没抢到就挂起,这之间会涉及到上下文的切换。虽然降低了运行效率,但提高了数据访问的安全性,这是值得的。

2.线程同步有四种方式:互斥锁,读写时,条件变量,信号量。

3.互斥锁,读写时,条件变量在头文件pthread中,信号量在头文件semaphore中。

1.互斥锁

//每一个共享资源对应一把锁,锁的个数和线程的个数无关
pthread_mutex_t mutex;//初始化互斥锁,被restrict修饰的指针可以访问指向的内存地址
int pthread_mutex_init(pthread_mutex_t *restrict mutex, const pthread_mutexattr_t *restrict attr);//释放互斥锁资源
int pthread_mutex_destroy(pthread_mutex_t *mutex);//修改互斥锁状态,对传入的互斥锁进行加锁
int pthread_mutex_lock(pthread_mutex_t *mutex);//对传入的互斥锁进行尝试加锁,
int pthread_mutex_trylock(pthread_mutex_t *mutex);//对传入的互斥锁进行解锁
int pthread_mutex_unlock(pthread_mutex_t *mutex);

2.读写锁

//读写锁是互斥锁的升级版,读锁是共享的,写锁是互斥(独占)的。写锁优先级比读锁高
pthread_rwlock_t rwlock;//初始化读写锁,attr默认为NULL就行
int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock, const pthread_rwlockattr_t *restrict attr);//释放读写锁占用的系统资源
int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);//修改读写锁状态,锁定读操作,读锁可以重复锁
int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);//对传入的读写锁进行尝试加读锁
int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwlock);//对传入的读写锁进行加写锁
int pthread_rwlock_wdlock(pthread_rwlock_t *rwlock);//对传入的读写锁进行尝试加写锁
int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock);

3.条件变量

  • 条件变量不是处理线程同步的,而是进行线程的阻塞。多线程实现线程同步需要配合互斥锁来使用。
//条件变量类型的定义
pthread_cond_t cond;//初始化条件变量,一般attr默认为NULL就行
int pthread_cond_init(pthread_cond_t *restrict cond, const pthread_cond_t *restrict attr);//释放条件变量资源
int pthread_cond_destroy(pthread_cond_t *cond);//线程阻塞函数,哪个线程调用这个函数就会阻塞哪个线程
int pthread_cond_wait(pthread_cond_t *restrict cond, pthread_mutex_t *restrict mutex);//唤醒在条件变量上阻塞的线程(至少一个)
int pthread_cond_signal(pthread_cond_t *cond);//唤醒在条件变量阻塞的全部线程
int pthread_cond_broadcast(pthread_cond_t *cond);

4.信号量

  •  信号量 主要是阻塞线程,不能保证线程安全,如果要保证线程安全,需要信号量和互斥锁一起使用

1.定义信号量变量

sem_t sem;

2.初始化信号量

int sem_init(sem_t *sem, int pshared, unsigned int value);
  • 参数
    • sem:信号量变量地址
    • pshared:0-线程同步,!0-进程同步
    • value:初始化信号量*sem拥有的资源数(>=0),为0就会阻塞线程

3.销毁信号量

int sem_destroy(sem_t *sem);

4.锁住一个信号量资源,资源数=0时会阻塞线程

int sem_wait(sem_t *sem);
int sem_trywait(sem_t *sem);
int sem_timedwait(sem_t *sem, const struct timespec *abs_timeout);

5.释放一个信号量资源

int sem_post(sem_t *sem);

6.获取信号量的资源数

//sval是输出参数,可以通过sval获取信号量sem中拥有的资源数量
int sem_getvalue(sem_t *sem, int *sval);

http://www.yayakq.cn/news/524109/

相关文章:

  • 汽车类网站设计规划网站建设一下需要多少费用
  • 泰州公司做网站优化平台建设公司
  • 做网站哪家最好2018网站如何做seo
  • 用vs2010做免费网站模板网站宝建站助手
  • 台州企业网站排名优化租用服务器网站
  • 北京怀柔网站制作wordpress wordpress获取当前页面的父类id
  • 2018年靖边建设项目招投标网站wordpress转换成 dede
  • 网站建设对应的岗位网站建设 架构
  • 北京医院网站建设关键词优化诊断
  • 网站开发和网络工程师app音乐网站开发
  • 网站建设预付款比例北京网站建设公司完美湖南岚鸿首 选
  • 网站建设方案预算东莞网站建设部落
  • 高端大气网站禁忌网站有哪些
  • 那个网站教人做冰点建站之星极速版
  • 化工产品网站建设企业网站关键词排名
  • 怎样 建设电子商务网站医疗网站搭建
  • 电脑网站转换成手机网站义乌网
  • 网站建设色彩搭配用织梦系统做的2个网站要把它都上传到服务器上吗
  • qq赞网站推广免费怎样网站备案表
  • 做一个国外网站建网站建设网站
  • 高唐网站开发西宁思帽网站建设
  • 商务网站开发流程有三个阶段中山商城网站建设
  • 单县菏泽网站建设wordpress4.8.1模板
  • 网站浮窗代码如何对网站做进一步优化
  • logo网站设计网站建设需要英语吗
  • 网站设计原型做基网站
  • 江苏网站备案流程专门给小公司做网站
  • 三门峡网站建设价格多语言网站开发
  • wordpress cenos昆明seo和网络推广
  • 网站前置审批证书网站建设案例欣赏