在前面介绍线程时讲了线程是共享进程的内存空间的,接下来就举个代码示例进一步验证。
#include <stdio.h>
#include <pthread.h>
int g_data=0;
void *func1(void *arg)
{
printf("t1:%ld thread is creart\n",(unsigned long)pthread_self());
printf("t1:param is %d\n",*((int *)arg));
while(1)
{
printf("t1:%d\n",g_data++);
sleep(1);
}
}
void *func2(void *arg)
{
printf("t2:%ld thread is creart\n",(unsigned long)pthread_self());
printf("t2:param is %d\n",*((int *)arg));
while(1)
{
printf("t2:%d\n",g_data++);
sleep(1);
}
}
int main()
{
int param=100;
char *pret=NULL;
int ret1;
int ret2;
pthread_t t1;
pthread_t t2;
ret1=pthread_create(&t1, NULL,func1, (void *)¶m);
ret2=pthread_create(&t1, NULL,func2, (void *)¶m);
if(ret1 == 0)
{
printf("main:create t1 successed\n");
}
if(ret2 == 0)
{
printf("main:create t2 successed\n");
}
printf("main:%ld\n",(unsigned long)pthread_self());
while(1)
{
printf("main:%d\n",g_data++);
sleep(1);
}
pthread_join(t1,NULL);
printf("main: t1 quit:%s\n",pret);
pthread_join(t2,NULL);
printf("main: t2 quit:%s\n",pret);
return 0;
}
总结:
main函数与两个新线程中的函数都对g_data进行加加,如果它们三个是独立的空间的话,g_data输出的值就是各自内存中的值,但是从上面的代码运行情况来看,g_data都是一直在进行加的,所以说明它们三个用的g_data是同一个,也就说明,线程是共享进程的内存空间的。
但是如果你多次运行这个代码你就会发现,到底哪个线程最先开始运行是不确定的吗,有时候是t1,有时候是t2,但是有些情况我们必须先让t1运行完毕,才让t2运行呢?或者说当g_data等于3的时候t1线程就退出,那如果t2拿到了g_data=3,那么t1线程就无法退出了。这种情况就需要使用到下一节中锁的概念。