Linux 和 多线程
每次都是用到,查一下,写下,这次稍微记录下笔记。
和Thread相关,基本的有3个概念:线程的建立和销毁;线程锁;线程条件
关于建立线程:
ret = pthread_create(&thread_id, NULL, Do_Thread, &Do_Thread_Para);
// 第2参数是thread 属性,一般我不用设置
// 第4个参数是Do_Thread的入口参数,一般我传一个结构体进去
关于销毁线程:
等待线程结束:pthread_join
强行杀掉线程:pthread_exit
让线程自生自灭:pthread_detach
我一般用的是第一个:
pthread_join(thread_id, &Do_Thread_ret);
// 第二个参数是线程返回值
关于线程锁:当要在多个线程共享某些变量的时候,就需要用锁。这样可以保证一个时间点,只有一个线程能够访问这个线程
pthread_mutex_t mMutexData;
pthread_mutex_init(&(mMutexData), NULL); // 第2个参数是锁的属性,我一般用默认,NULL
pthread_mutex_lock(&mMutexData); // 加锁
pthread_mutex_unlock(&mMutexData) // 去锁
pthread_mutex_destroy(&mMutexData) // 销毁
关于条件:当某个线程需要等待其他线程处理完某个数据(运行到某个点)的话,就需要用条件,一般加个时间参数,以防止死等下去。
pthread_cond_t *sConditionData;
pthread_cond_init(&(sConditionData), NULL); // 第2个参数是锁的属性,我一般用默认,NULL
pthread_mutex_lock(&mMutexData); // 一般条件必须和锁加在一起用,以保证条件变量不重入
pthread_cond_signal(&sConditionData); // 发信号
pthread_mutex_unlock(&mMutexData);
struct timespec ts;
struct timeval sTime;
struct timezone sTimeZone;
long res;
pthread_mutex_lock(&(pApp->mMutexData));
gettimeofday(&sTime, &sTimeZone);
ts.tv_sec = sTime.tv_sec;
ts.tv_nsec += 5sTime. tv_usec * 1000 +20*1000*1000; // 20 ms
ret = pthread_cond_timedwait(&(pApp->sConditionData), &(pApp->mMutexData), &ts); // 等候
if(ret == ETIMEDOUT)
{
pthread_mutex_unlock(&(pApp->mMutexData));
 
相关文档:
Linux基金会执行董事Jim Zemlin声称Linux的市场地位十分稳固,尽管几位Linux内核的关键维护者已经头发花白。
Linux Weekly News的主编Jonathan Corbet在上周举行的Linux基金会协作峰会上挑明了这一问题,他指出Linux内核团队的年龄一年比一年长,而年轻一代的开发者没有参与进来。为什么Linux现在无法吸引年轻开发 ......
vi/vim 中可以使用 :s 命令来替换字符串。以前只会使用一种格式来全文替换,今天发现该命令有很多种写法(vi 真是强大啊,还有很多需要学习),记录几种在此,方便以后查询。
:s/vivian/sky/ 替换当前行第一个 vivian 为 sky
:s/vivian/sky/g 替换当前行所有 vivian 为 sky
:n,$s/vivian/sky/ 替换第 n 行 ......
利用
下载的这段代码,成功实现了守护进程,原来守护进程是很简单的事情。
在main函数中执行
init_daemon();//初始化为Daemon
就可以把进程变成守护进程
#include
#include
#include
#include
#include
void
init_daemon(void
)
{
int
pid;
int
i;
if
(pid=fork()) ......
oracle dataguard是指一种数据库级别的HA方案,最主要的功能是容灾,数据保护,故障恢复等
在生产数据库的事务一致性时,使用产生的物理全备份创建备库,备库通过传输过来的归档日志自动维护备用数据库
将重做的数据应用到备用库上。
1,前提:
primary:192.168.18.1;
oracle_SID:db1
  ......