当前位置:  技术问答>linux和unix

关于线程特定数据共享全局变量的一个程序

    来源: 互联网  发布时间:2017-03-17

    本文导语:  我有一个问题,线程特定数据怎么理解,我看了些小程序,差不多是不是这个意思,进程有一个key,然后每个线程给进程的这个key设定一个值(指针),各个线程的值是独立的,于是我看了下下面这个程序,表示不淡...

我有一个问题,线程特定数据怎么理解,我看了些小程序,差不多是不是这个意思,进程有一个key,然后每个线程给进程的这个key设定一个值(指针),各个线程的值是独立的,于是我看了下下面这个程序,表示不淡定了,共享全局变量的问题。
#include 
#include 

int my_errno = 0;
pthread_key_t key;

void *thread2(void *arg)
{
my_errno = 2;
pthread_setspecific(key, &my_errno);

printf("thread2: %u; pkey address: %p; pkey value: %d, my_errno = %d, my_errno address = %pn",
(unsigned int)pthread_self(), (int *)pthread_getspecific(key), 
*((int *)pthread_getspecific(key)), my_errno, &my_errno);
}

void *thread1(void *arg)
{
my_errno = 1;
pthread_setspecific(key, &my_errno);

printf("thread2: %u; pkey address: %p; pkey value: %d, my_errno = %d, my_errno address = %pn",
(unsigned int)pthread_self(), (int *)pthread_getspecific(key), 
*((int *)pthread_getspecific(key)), my_errno, &my_errno);
}

int main(void)
{
pthread_t thid1, thid2;

printf("main thread begins running, my_errno=%d, my_errno address = %pn",my_errno, &my_errno);
pthread_key_create(&key, NULL);

pthread_create(&thid1, NULL, thread1, NULL);
pthread_create(&thid2, NULL, thread2, NULL);
sleep(2);
pthread_key_delete(key);
printf("main thread exitn");
return 0;
}
程序输出:

main thread begins running, my_errno=0, my_errno address = 0x8049adc
thread2: 3067120496; pkey address: 0x8049adc; pkey value: 2, my_errno = 2, my_errno address = 0x8049adc
thread2: 3077610352; pkey address: 0x8049adc; pkey value: 1, my_errno = 1, my_errno address = 0x8049adc
main thread exit

我发现共享的全局变量的地址是一样的 0x8049b0c,但是值不一样,既然是特定数据,我的理解是每个线程为此数据单独开辟一个空间存储,相当于存储副本,但是事实好像不是这样子,麻烦高手帮忙解释一下吧。

|
因为第一个线程执行完了退出了, 第二个线程才执行的。

楼主想多了,更多问题可在CU讨论。

|
因为第一个线程执行完了退出了, 第二个线程才执行的。

楼主想多了,更多问题可在CU讨论。

    
 
 

您可能感兴趣的文章:

  • 除了全局变量,线程还可以通过哪些方法向定时器传递数据?
  • errno是个全局的马〉?还是一个线程一个?
  • linux 多线程 问题 全局变量 共享问题,恳请赐教,帮助>>
  • linux下如何安全地让三个不同线程处理一个全局的链表
  • 关于Linux下多线程情况下全局变量保护的问题,求个解决方案
  • 关于多个线程访问一个全局的共享buf
  • 线程调度对循环体和全局变量的影响问题
  • 浅析MySQL内存的使用说明(全局缓存+线程缓存)
  • c++的boost库多线程(Thread)编程(线程操作,互斥体mutex,条件变量)详解
  • 请问在多线程得程序中,函数内的局部变量是否线程安全的
  • 困惑:子线程如何使用主线程的变量?
  • 关于多线程编程的条件变量问题
  • 多线程共享变量只是读取会不会冲突?
  • 线程同步读取变量可不可以不用互斥锁
  • UNIX线程共用一个变量,出现core dump
  • 一个线程里头可以等待多过条件变量吗?
  • pthread_create所创建的线程中的static变量
  • 有关不同线程同时访问同一公共Vector变量的问题(欢迎讨论)
  • 线程里互斥和条件变量一起使用的问题,有点迷惑.
  • 多线程共享变量问题
  • 我觉得POSIX的线程里的条件变量的API设计得很不合理!
  • 在一个线程中的run()方法里面用无限循环的方式来检测某一个类中的变量的状态,当检测到该状态为true时,再判断该变量如果连续维持true状
  • 线程中变量的作用范围
  • java通过共享变量结束run停止线程的方法示例
  • 请问怎么防止pthread_mutex_lock锁定一个被另一个线程已经锁定的mutex变量时出现死锁?谢谢
  • 看到线程的条件变量这部分时有些糊涂!
  • 有没有办法在线程的run()里面改变外面的类的变量的值,有例子
  • 可以用一个pthread_t变量接收所有子线程返回吗?
  • 如何不留后遗症地取消处于等待条件变量信号的线程?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Java中多线程相关类Thread介绍
  • 一个进程创建了两个线程,如何使得当任何一个线程(比如线程a)结束时,同时也结束线程b,也就是使两个线程一起死掉,怎么办呢?
  • c#多线程更新窗口(winform)GUI的数据
  • java 线程,对当前线程(非主线程)调用sleep,为什么主线程(窗口)也没反应了
  • Windows和Linux下C++类成员方法作为线程函数方法介绍
  • 如何实现一个线程组内多线程的非同不执行,即一个线程执行完毕后再执行下一个线程???
  • Linux下GCC内置原子操作函数(多线程资源访问)介绍
  • 请问:进程创建的线程是怎样运行的啊,线程的处理函数运行完了,线程就退出了吗?
  • 关于线程的问题,什么样的线程不是active线程?
  • 请问Linux核心支持多线程吗?开发库有线程库吗?线程好用吗?(稳定?)
  • 请问,在一个进程中创建多线程时如何能避免不同的线程获得同一个线程标识
  • 我的一个多线程服务里, 总是有一个线程莫名其妙的变成僵尸线程。
  • 能否通过线程id控制线程的状态?或是观察到线程的状态?
  • 如何在一个线程中启动另外一个线程,然后本线程就退出?
  • 我要设置一个线程的优先级, 这个属性结构并没有线程的id,它怎么知道是设置哪个线程呢?
  • 请问在java多线程中,是只有run(){}内的代码运行在一个新线程下呢?还是这个类中的代码都运行在一个新线程下?
  • gcc链接的库,分不分单线程版本的和多线程版本的?
  • 内核栈~ 内核线程 ~用户线程 之间关系 问题
  • 子线程的数据如何返回给主线程?
  • 如果父线程死掉 那么子线程会不会死掉呢
  • 多线程为何比单线程慢许多?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3