首页
|
新闻
|
新品
|
文库
|
方案
|
视频
|
下载
|
商城
|
开发板
|
数据中心
|
座谈新版
|
培训
|
工具
|
博客
|
论坛
|
百科
|
GEC
|
活动
|
主题月
|
电子展
注册
登录
论坛
博客
搜索
帮助
导航
默认风格
uchome
discuz6
GreenM
»
MCU 单片机技术
»
PowerPC
» 关于 Unified Parallel C 中的指针1
返回列表
回复
发帖
发新话题
发布投票
发布悬赏
发布辩论
发布活动
发布视频
发布商品
关于 Unified Parallel C 中的指针1
发短消息
加为好友
look_w
当前离线
UID
1066743
帖子
8283
精华
0
积分
4142
阅读权限
90
在线时间
233 小时
注册时间
2017-6-23
最后登录
2019-5-18
论坛元老
UID
1066743
1
#
打印
字体大小:
t
T
look_w
发表于 2018-1-7 13:20
|
只看该作者
关于 Unified Parallel C 中的指针1
UPC 语言中的指针类型UPC 语言把数据分为共享类型和私有类型。一个指针所指向的数据可能为共享类型或者私有类型,并且指针本身也可以是共享类型或者私有类型。因此 UPC 语言中的指针共有以下四种类型,参见图 1
指向私有数据私有类型指针
指向共享数据私有类型指针
指向私有数据共享类型指针
指向共享数据共享类型指针
图 1. UPC 语言指针类型
指向私有数据私有类型指针如图 1 中的 p1 指针,是一个指向私有数据的私有类型指针。该指针类似于 C 语言中的普通的指针。当声明一个这样的指针时,UPC 语言会在每个线程的私有内存中为该指针的副本分配内存,即每个线程拥有该指针的一个副本。 该指针可以用来访问一个线程的私有数据。例如,下面的语句声明了一个指向私有数据私有类型指针:
1
int *p1;
清单 1. 指向私有数据私有类型指针
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# include <upc.h> // 假定由 2 个线程来运行该程序
# include <stdio.h>
# include <<stdlib.h>
int a=-1;
void main()
{
int *p1;
if(MYTHREAD == 1)
{
// p1 指向动态分配的私有内存。
p1=malloc(1*sizeof(int));
*p1=1;
}
else
{
// p1 指向变量 a.
p1=&a;
}
printf("Th=%d,*p1=%d\n",MYTHREAD,*p1);
}
图 2. 清单 1 程序内存视图
图 3:清单 1 程序输出
指向共享数据私有类型指针如图 1 中的 p2 指针,是一个指向共享数据的私有类型指针。当声明这个指针的时候,UPC 语言会为该指针,在每个线程的私有内存中分配内存,即每个线程均有该线程的一个副本。该指针可以用来访问共享数据。例如,下面语句声明了一个指向共享数据私有类型指针:
1
shared int *p2;
清单 2. 指向共享数据私有类型指针
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# include <upc.h> // 假定由 2 个线程来运行该程序
# include <stdio.h>
shared int a=0;
void main()
{
shared int *p2; // p2 是一个指向共享数据的私有类型指针
// 线程 1 对变量 a 进行初始化
if(MYTHREAD == 1)
a=-1;
upc_barrier;
// p2 指针指向共享变量 a 所在的地址
p2=&a;
// 每个对 p2 指针进行间接引用的线程都会得到同样的值
printf("Th=%d,*p2=%d\n",MYTHREAD,*p2);
}
图 4. 清单 2 程序内存视图
图 5. 清单 2 程序输出
指向私有数据共享类型指针如图 1 中的 p3,是一个指向是有数据的共享类型指针。虽然每个线程都可以间接引用该指针,但只有对其初始化的线程或者是和该指针在同一个计算节点的线程,此操作才有意义。由于该类型指针可以被任何线程来调用访问其他线程的私有数据,不鼓励使用这种类型指针。例如,下面的语句声明了一个指向私有数据共享类型指针:
1
int * shared p3;
清单 3. 指向私有数据共享类型指针
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# include <upc.h> // 假定由 2 个线程来运行该程序
# include <stdio.h>
int *shared p3;
void main()
{
int a=MYTHREAD+99;
if(MYTHREAD == 1)
{
// 将线程 1 将自己的私有变量 a 的地址赋给指针 p3.
p3=&a;
}
upc_barrier;
printf("Th=%d,*p3=%d\n",MYTHREAD,*p3);
}
图 6. 清单 3 程序内存视图
图 7. 清单 3 程序输出
收藏
分享
评分
回复
引用
订阅
TOP
返回列表
X86
测试测量
电源与功率管理
综合技术交流
电商论坛
Pine A64
资料下载
方案分享
FAQ
行业应用
消费电子
便携式设备
医疗电子
汽车电子
工业控制
热门技术
智能可穿戴
3D打印
智能家居
综合设计
示波器技术
存储器
电子制造
计算机和外设
软件开发
分立器件
传感器技术
无源元件
资料共享
PCB综合技术
综合技术交流
EDA
MCU 单片机技术
ST MCU
Freescale MCU
NXP MCU
新唐 MCU
MIPS
X86
ARM
PowerPC
DSP技术
嵌入式技术
FPGA/CPLD可编程逻辑
模拟电路
数字电路
富士通半导体FRAM 铁电存储器“免费样片”使用心得
电源与功率管理
LED技术
测试测量
通信技术
3G
无线技术
微波在线
综合交流区
职场驿站
活动专区
在线座谈交流区
紧缺人才培训课程交流区
意见和建议