实战项目开发细节:C语言分离一个16进制数取出相应的位1或0

简介: 最近在公司开发一个关于钢琴的PCBA项目,项目大概是这样的,完成各种功能的测试,准备去工厂量产的时候可以通过软件快速甄别硬件是否短路,断路等问题。       其中,甄别好坏的方法是通过比如按键,或者其它的操作然后响应音频信号的输出来甄别的,那到底原理是怎么样的呢?       音频信号定制为如果是0则输出1000hz,如果是1则输出3000hz。

最近在公司开发一个关于钢琴的PCBA项目,项目大概是这样的,完成各种功能的测试,准备去工厂量产的时候可以通过软件快速甄别硬件是否短路,断路等问题。

      其中,甄别好坏的方法是通过比如按键,或者其它的操作然后响应音频信号的输出来甄别的,那到底原理是怎么样的呢?

      音频信号定制为如果是0则输出1000hz,如果是1则输出3000hz。

      音频信号是一个16进制数,比如0xfd----->1111 1101 

      那么它的输出应该是这样的,从左边最高位开始,输出3000hz ,3000hz ,3000hz, 3000hz , 3000hz , 3000hz , 1000hz , 3000hz .

     如果要求改一下,从右边最低位到最高位输出也是可以的,这个具体可以通过示波器来测量相应的信号输出波形。

      原理我们搞明白了,就这么简单,于是我们就可以用C语言位运算来实现这个操作,由于公司保密特权,我不方便公开我的项目的详细细节,这样,我只能写个模拟的C语言测试程序来模仿这个过程,好了,我们开始写代码:

     

#include <stdio.h>
void pri() ; 
void pri1() ;
int play_sound_lowtohigh(unsigned int num) ;
int bit0o1(int it,int position) ;
int play_sound_hightolow(unsigned int num) ;
int   main() 
{
	unsigned int num = 0xfd ; //1111 1101
	play_sound_lowtohigh(num);
	putchar('\n');
	play_sound_hightolow(num);
    	
return   0;   
}
//从低位往高位 
int play_sound_lowtohigh(unsigned int num)
{
	int i   = 0;
	int bit = 0 ;
	for(i = 1 ; i < 9 ; i++)
	{
    	bit = bit0o1(num,i);
    	if(bit == 0)
    		pri();
    	else if(bit == 1)
    		pri1() ;
	}		
}
//从高位往低位 
int play_sound_hightolow(unsigned int num)
{
	int i   = 0;
	int bit = 0 ;
	for(i = 8 ; i > 0 ; i--)
	{
    	bit = bit0o1(num,i);
    	if(bit == 0)
    		pri();
    	else if(bit == 1)
    		pri1() ;
	}		
}

//it 表示数据
//position 表示第几位 
int bit0o1(int it,int position)
{
    int oc=1;
    oc<<=(position-1);
    return (oc&it)!=0?1:0;
}

void pri()
{
	printf("1000hz\n") ; 
}

void pri1()
{
	printf("3000hz\n") ;
}

运行结果:


或者更简单一点:

#include <stdio.h>  
int test_bit(int num)
{
	int i ; 
	for(i = 7 ; i >= 0 ; i--)
	{
		if(num & (1 << i))
			printf ("3000hz\n") ; 
		else 
			printf ("1000hz\n") ; 
	}
}
int main(void)  
{  
	test_bit(0xfd) ;  
}
这样也是对的。

目录
相关文章
|
19天前
|
存储 C语言 开发者
C语言实战 | Flappy Bird游戏
【7月更文挑战第4天】Flappy Bird是由越南开发者制作的简单却极具挑战性的游戏,玩家需控制小鸟穿越水管障碍。游戏涉及角色初始化、显示和更新。小鸟和水管结构体存储数据,使用变量和数组。初始化小鸟和水管,显示背景、小鸟和水管,更新小鸟位置及碰撞检测。代码示例展示了小鸟和水管的状态管理,当小鸟与管道碰撞或触地时,游戏结束。游戏的成功在于其独特的虐心体验。
24 0
C语言实战 | Flappy Bird游戏
|
12天前
|
C语言
C语言实战 | 弹跳的小球
【7月更文挑战第6天】使用C语言实现了一个小球(小方块)在屏幕上斜向移动并反弹的程序。当小球碰到边界时,其运动方向会发生改变。代码分为三部分,分别处理初始化、主循环和更新位置及边界检测。变量drow和dcol控制移动方向,遇到边界时会反转它们的值。
14 3
C语言实战 | 弹跳的小球
|
20天前
|
存储 大数据 文件存储
C语言实战 | 用户管理系统重构
【7月更文挑战第3天】在大数据背景下,云存储成为关键。案例展示了如何创建一个用户管理系统,包含登录和注册功能,确保数据持久化。通过文件存储,即便程序重启,用户信息仍能被保留,实现登录状态的延续。代码图片省略。
17 2
C语言实战 | 用户管理系统重构
|
20天前
|
C语言 数据安全/隐私保护 UED
C语言实战 | 用户管理系统
【7月更文挑战第2天】近期推出的青少年防沉迷系统采用统一标准,管控未成年人上网时段、时长及内容。用户管理系统是其基础,包含登录和注册功能。代码示例展示了用户管理的流程,通过保存用户信息到文件实现持久化,避免重复注册,确保在限制游戏时间的同时提供更好的用户体验。
17 1
C语言实战 | 用户管理系统
|
13天前
|
存储 编译器 C语言
C语言实战 | “贪吃蛇”游戏
【7月更文挑战第5天】在C语言实战中,本文档介绍了如何构建一个简单的“贪吃蛇”游戏。游戏的核心是控制蛇移动并增长,当吃掉食物时,蛇的身体变长。数据结构使用固定大小的数组表示蛇的位置,变量存储食物位置和蛇的长度。初始化后,利用非阻塞式`getKey()`函数实现WASD键盘控制蛇的运动方向。虽然蛇的边界检测和吃食物后的增长尚未详细说明,但提到了这些问题作为练习留给读者解决,并预告将在后续章节讨论模块化编程以简化复杂代码。
24 0
C语言实战 | “贪吃蛇”游戏
|
21天前
|
存储 数据管理 C语言
C语言实战 | 使用链表完成“贪吃蛇”游戏
【7月更文挑战第1天】整体思维,即系统思维,强调以整体视角理解事物。在编程中,结构体体现这种思想,将相关变量打包处理。示例展示了如何用链表而非数组实现“贪吃蛇”游戏,链表提供了更灵活的动态数据管理。一系列代码图片详细描绘了链表结构体在游戏中的应用,包括节点定义、移动、碰撞检测等,凸显了使用链表的优势和代码的清晰组织。
18 0
C语言实战 | 使用链表完成“贪吃蛇”游戏
|
25天前
|
存储 移动开发 C语言
技术心得记录:嵌入式开发中常用到的C语言库函数
技术心得记录:嵌入式开发中常用到的C语言库函数
18 1
|
27天前
|
C语言
C语言实战项目——学生试卷分数统计
C语言实战项目——学生试卷分数统计
|
26天前
|
存储 C语言
C语言实战 | “贪吃蛇”游戏重构
在程序设计中,模块化思维至关重要,尤其对于复杂项目,它帮助分解任务,便于团队协作。以“贪吃蛇”游戏为例,游戏涉及两个角色:蛇和食物。使用数组存储蛇的位置,变量存储食物位置。游戏流程分为初始化、显示和更新数据。初始化时,食物位置随机,蛇的位置根据数组设定。显示数据则根据这些信息在屏幕上呈现角色。更新数据时,处理蛇的移动和增长以及食物的生成和消失。类似地,通过模块化方法可开发“打砖块”游戏,涉及球、球拍和砖墙,每个角色都有相应数据结构和更新逻辑。通过这种方式,游戏开发就像搭建积木,遵循框架逐步实现。
28 0
C语言实战 | “贪吃蛇”游戏重构
|
20天前
|
存储 C语言
C语言18---常用的进制
C语言18---常用的进制