欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 高考 > CUDA原子操作

CUDA原子操作

2024/10/25 0:36:17 来源:https://blog.csdn.net/m0_73777202/article/details/140353165  浏览:    关键词:CUDA原子操作

代码

#include <cuda_runtime.h>
#include <stdio.h>__global__ void atomicAddAndGet(int *result, int *valueToAdd) {// 原子加法int addedValue = atomicAdd(result, *valueToAdd);// 通过原子操作后读取值,确保是加法后的值addedValue += *valueToAdd;printf("Thread %d: Added value: %d\n", threadIdx.x, addedValue);
}int main() {int result = 0;int valueToAdd = 5;int *d_result, *d_valueToAdd;// 在GPU上分配内存cudaMalloc((void**)&d_result, sizeof(int));cudaMalloc((void**)&d_valueToAdd, sizeof(int));// 将数据从主机内存复制到GPU内存cudaMemcpy(d_result, &result, sizeof(int), cudaMemcpyHostToDevice);cudaMemcpy(d_valueToAdd, &valueToAdd, sizeof(int), cudaMemcpyHostToDevice);// 启动CUDA核函数atomicAddAndGet << <1, 32 >> > (d_result, d_valueToAdd);// 将结果从GPU内存复制回主机内存cudaMemcpy(&result, d_result, sizeof(int), cudaMemcpyDeviceToHost);// 输出结果printf("Result after atomic addition: %d\n", result);// 释放GPU上的内存cudaFree(d_result);cudaFree(d_valueToAdd);return 0;
}

结果
在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com