嵌入式开发常用的C语言工具代码

发布时间:2024-01-30  

开发中常用的工具确实很重要。以下是一些利剑级别的工具示例,以及它们的简要讲解。

本文引用地址:

循环队列(Circular Buffer)

typedef struct {
   int buffer[SIZE];
   int head;
   int tail;
   int count;
} CircularBuffer;
void push(CircularBuffer *cb, int data) {
   if (cb->count < SIZE) {
       cb->buffer[cb->head] = data;
       cb->head = (cb->head + 1) % SIZE;
       cb->count++;
   }
}
int pop(CircularBuffer *cb) {
   if (cb->count > 0) {
       int data = cb->buffer[cb->tail];
       cb->tail = (cb->tail + 1) % SIZE;
       cb->count--;
       return data;
   }
   return -1; // Buffer is empty}

循环队列是一种高效的数据结构,适用于缓冲区和数据流应用,例如串口通信接收缓冲。

断言(Assertion)

#define assert(expression) ((void)0)
#ifndef NDEBUG
#undef assert
#define assert(expression) ((expression) ? (void)0 : assert_failed(__FILE__, __LINE__))
#endif

void assert_failed(const char *file, int line) {
   printf("Assertion failed at %s:%dn", file, line);
   // Additional error handling or logging can be added here}

断言用于在程序中检查特定条件是否满足,如果条件为假,会触发断言失败,并输出相关信息

位域反转(Bit Reversal)

unsigned int reverse_bits(unsigned int num) {
   unsigned int numOfBits = sizeof(num) * 8;
   unsigned int reverseNum = 0;
   for (unsigned int i = 0; i < numOfBits; i++) {
       if (num & (1 << i)) {
           reverseNum |= (1 << ((numOfBits - 1) - i));
       }
   }
   return reverseNum;
}

该函数将给定的无符号整数的位进行反转,可以用于某些系统中的位级操作需求。

固定点数运算(Fixed-Point Arithmetic)

typedef int16_t fixed_t;
#define FIXED_SHIFT 8
#define FLOAT_TO_FIXED(f) ((fixed_t)((f) * (1 << FIXED_SHIFT)))
#define FIXED_TO_FLOAT(f) ((float)(f) / (1 << FIXED_SHIFT))

fixed_t fixed_multiply(fixed_t a, fixed_t b) {
   return (fixed_t)(((int32_t)a * (int32_t)b) >> FIXED_SHIFT);
}

在某些系统中,浮点运算会较慢或不被支持。因此,使用固定点数运算可以提供一种有效的浮点数近似解决方案。

字节序转换(Endianness Conversion)

uint16_t swap_bytes(uint16_t value) { return (value >> 8) | (value << 8); }

用于在大端(Big-Endian)和小端(Little-Endian)字节序之间进行转换的函数。

位掩码(Bit Masks)

#define BIT_MASK(bit) (1 << (bit))

用于创建一个只有指定位被置位的位掩码,可用于位操作。

计时器计数(Timer Counting)

#include void setup_timer() {
   // Configure timer settings}
uint16_t read_timer() {
   return TCNT1;
}

在AVR嵌入式系统中,使用计时器(Timer)来实现时间测量和定时任务。

二进制查找(Binary Search)

int binary_search(int arr[], int size, int target) {
   int left = 0, right = size - 1;
   while (left <= right) {
       int mid = left + (right - left) / 2;
       if (arr[mid] == target) {
           return mid;
       } else if (arr[mid] < target) {
           left = mid + 1;
       } else {
           right = mid - 1;
       }
   }
   return -1; // Not found}

用于在已排序的数组中执行二进制查找的函数。

位集合(Bitset)

#includetypedef struct {
   uint32_t bits;
} Bitset;
void set_bit(Bitset *bitset, int bit) {
   bitset->bits |= (1U << bit);
}
int get_bit(Bitset *bitset, int bit) {
   return (bitset->bits >> bit) & 1U;
}

实现简单的位集合数据结构,用于管理一组位的状态。

这些示例代表了嵌入式开发中常用的一些利剑级别的工具代码。它们在嵌入式系统开发中具有广泛的应用,有助于优化性能、节省资源并提高代码的可维护性。

文章来源于:电子产品世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>