下载
中文
注册

示例代码

关于多线程、多Stream的场景,请参见Stream管理

基本原理

您需要按顺序依次申请如下运行管理资源:DeviceContextStream,确保可以使用这些资源执行运算、管理任务。所有数据处理都结束后,需要按顺序依次释放运行管理资源:StreamContextDevice

  • 关于Context和Stream
    • 显式创建Context时,调用aclrtCreateContext接口,此时需显式调用aclrtDestroyContext接口释放。
    • 显式创建Stream时,调用aclrtCreateStream接口,此时需显式调用aclrtDestroyStream接口释放。
    • 如果不显式创建Context和Stream,您可以使用aclrtSetDevice接口隐式创建的默认Context和默认Stream,但默认Context和默认Stream存在如下限制:
      • 一个Device对应一个默认Context,默认Context不能通过aclrtDestroyContext接口来释放。
      • 一个Device对应一个默认Stream,默认Stream不能通过aclrtDestroyStream接口来释放。默认Stream作为接口入参时,直接传NULL。
      • 默认Context、默认Stream,是在调用aclrtResetDevice接口后自动释放。
  • 关于单进程、单线程、单Stream场景
    • 单进程:一个应用程序对应一个进程。
    • 单线程:不显式创建多个线程时,默认只有一个线程。
    • 单Stream:整个开发的过程中使用同一个Stream。

      对于同一个Stream中的异步任务,AscendCL会按照应用程序中任务的顺序执行任务,确保异步任务执行的顺序。

示例代码

您可以从样例介绍中获取完整样例代码。

调用接口后,需增加异常处理的分支,并记录报错日志、提示日志,此处不一一列举。以下是关键步骤的代码示例,不可以直接拷贝编译运行,仅供参考。

// 初始化变量
extern bool g_isDevice;

// =====运行管理资源申请=====
// 指定运算的Device
aclError ret = aclrtSetDevice(deviceId_);

// 显式创建一个Context,用于管理Stream对象
ret = aclrtCreateContext(&context_, deviceId_);

// 显式创建一个Stream
// 用于维护一些异步操作的执行顺序,确保按照应用程序中的代码调用顺序执行任务
ret = aclrtCreateStream(&stream_);

// 获取当前昇腾AI软件栈的运行模式,根据不同的运行模式,后续的接口调用方式不同
aclrtRunMode runMode;
ret = aclrtGetRunMode(&runMode);
g_isDevice = (runMode == ACL_DEVICE);
// =====运行管理资源申请=====

// ......

// =====运行管理资源释放=====
ret = aclrtDestroyStream(stream_);
ret = aclrtDestroyContext(context_);
ret = aclrtResetDevice(deviceId_);
// =====运行管理资源释放=====

// ......