Vitis HLS 学习笔记--C/C++ static 关键字的作用

2024-04-27 12:36

本文主要是介绍Vitis HLS 学习笔记--C/C++ static 关键字的作用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1. 简介

2. c/c++共有性质

3. c++独有性质

4. 示例说明

5. static 对于 HLS 工具的影响

6. 总结


1. 简介

在Vitis HLS中,偶尔会用到 static 关键字。考虑到Vitis HLS同时兼容C和C++语言,有必要理解这两种语言中static关键字细微差异。本文旨在梳理和总结C与C++中static关键字的具体差别,以便于开发者更加精确地应用于Vitis HLS环境中。

2. c/c++共有性质

  • static 修饰全局变量

表明一个全局变量只对定义在同一文件中的函数可见。

全局变量的作用域被限制在定义它的文件内,这意味着该全局变量只能被同一源文件中的函数访问。

  • static 修饰局部变量

表明该变量的值不会因为函数终止而丢失。

局部变量的生命周期变为整个程序执行期间,但其作用域不变,仍然只在定义它的函数内。

这种特性使得static局部变量适合于实现需要记录之前状态或结果的功能,例如,用于计数函数被调用的次数。

  • static 修饰函数

表明该函数只在同一文件中调用。

函数的作用域被限制在其定义的文件中,这与 static 全局变量的行为是一致的。

3. c++独有性质

  • 修饰类的数据成员

表明对该类所有对象这个数据成员都只有一个实例。即该实例归所有对象共有。

  • 用static修饰不访问非静态数据成员的类成员函数。

这意味着一个静态成员函数只能访问它的参数、类的静态数据成员和全局变量。


如果不使用static关键词修饰函数或变量,它们就具有全局可见性,可以在其他文件中使用。在C++中,未被static关键词修饰的函数和变量都具有外部链接(external linkage),这意味着它们可以被其他文件引用。需要注意的是,如果在多个文件中定义了同名的全局函数或变量,编译器会报“multiple definition”错误。在这种情况下,可以将这些函数或变量定义为static,或者使用命名空间(namespace)来避免命名冲突。

4. 示例说明

Vitis-HLS-Introductory-Examples/Vitis/single_kernel/vadd_kernel/krnl_vadd.cpp at master · Xilinx/Vitis-HLS-Introductory-Examples · GitHubContribute to Xilinx/Vitis-HLS-Introductory-Examples development by creating an account on GitHub.icon-default.png?t=N7T8https://github.com/Xilinx/Vitis-HLS-Introductory-Examples/blob/master/Vitis/single_kernel/vadd_kernel/krnl_vadd.cpp

链接所示例子中,以下三个函数都static修饰,都只能在本文件中调用:

static void read_input(uint32_t* in, hls::stream<uint32_t>& inStream, int vSize)static void compute_add(hls::stream<uint32_t>& inStream1,...)static void write_result(uint32_t* out, hls::stream<uint32_t>& outStream, int vSize)

以下函数调用了上面三个函数,此函数在头文件中被申明,属于被别的文件调用,那么不能使用static修饰

void krnl_vadd(uint32_t* in1, uint32_t* in2, uint32_t* out, int vSize)

静态成员是类或结构体的成员,它们在整个程序执行期间都只有一个实例。

换句话说,静态成员在所有对象之间共享。这与非静态成员不同,非静态成员在每个对象中都有一个单独的实例。静态成员可以是变量或者函数。例如,定义如下类:

class MyClass {
public:// 静态成员变量static int staticVar;// 非静态成员变量int nonStaticVar;// 静态成员函数static void staticFunction() {// 静态成员函数可以访问静态成员变量,但不能访问非静态成员变量staticVar = 10;}// 非静态成员函数void nonStaticFunction() {// 非静态成员函数可以访问这两者:// 静态成员变量和非静态成员变量staticVar = 15;nonStaticVar = 20;}
};
// 静态成员变量需要在类外进行定义和初始化
int MyClass::staticVar = 0;int main() {MyClass obj1, obj2;MyClass::staticVar = 42; // 访问静态成员变量,它在所有对象之间共享std::cout << "obj1.staticVar: " << obj1.staticVar << std::endl; // 输出 42std::cout << "obj2.staticVar: " << obj2.staticVar << std::endl; // 输出 42// 访问非静态成员变量,它在每个对象中有一个单独的实例obj1.nonStaticVar = 5;obj2.nonStaticVar = 10;std::cout << "obj1.nonStaticVar: " << obj1.nonStaticVar << std::endl; // 输出 5std::cout << "obj2.nonStaticVar: " << obj2.nonStaticVar << std::endl; // 输出 10return 0; }

要点:

  • staticVar 是一个静态成员变量,它在所有 MyClass 对象之间共享。
  • nonStaticVar 是一个非静态成员变量,它在每个对象中都有一个单独的实例。
  • 静态成员函数 staticFunction() 只能访问静态成员变量,而非静态成员函数 nonStaticFunction() 可以访问静态成员变量和非静态成员变量。

5. static 对于 HLS 工具的影响

使用HLS工具进行综合时,输入和输出端口可以映射到实际的硬件接口,例如AXI接口。对于HLS中的数据流(stream)类型,数据可以通过FIFODMA等硬件模块进行传输。在综合过程中,这些数据流通常会被映射到FIFODMA硬件模块,并在硬件设计中使用。

尽管 inStream1 是一个在 HLS C++ 代码中定义的变量,但在硬件设计中,它可能被映射到一个FIFODMA硬件模块。在这种情况下,static 关键词的作用仅仅是限制变量的作用域,以避免与其他变量发生命名冲突。实际上,inStream1 的状态和值在运行时存储在FIFODMA中,而不是存储在静态内存中。

因此,在使用HLS工具进行硬件设计时,static关键词的作用主要是限制变量的作用域,而不是控制变量的存储方式。

6. 总结

本文通过具体实例探讨了C与C++中static关键字的使用差异,并针对其在Vitis HLS环境中的应用进行了详细梳理。尽管static在两种语言中都被广泛使用,但其在作用域管理、变量持久性以及对函数和变量的可见性方面的具体表现形式存在细微差别。

这篇关于Vitis HLS 学习笔记--C/C++ static 关键字的作用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/940520

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑