本文目录一览:
- 1、C语言程序设计, char s[]=“adc\0def” strlen(s)=? sizeo
- 2、51单片机 C语言ADC程序怎么写
- 3、51单片机c语言,ADC模数转换的问题
- 4、AVR单片机ADC控制LED程序(C语言)
- 5、C语言实现ADC采样问题
C语言程序设计, char s[]=“adc\0def” strlen(s)=? sizeo
s[]="abc\0def",因为是字符串,所以实际存储为'a','b','c','\0','d','e','f','\0'
一共是8个字符,sizeof(s)是统计s的字节数,而一个字符占一个字节,所以sizeof(s)的结果是8,strlen(s)是统计s的长度,以'\0'字符为结束,所以是3
51单片机 C语言ADC程序怎么写
typedef unsigned char BYTE;
typedef unsigned int WORD;
#include "reg51.h"
#include "intrins.h"
/*Declare SFR associated with the ADC */
sfr ADC_CONTR = 0xBC;
sfr ADC_RES = 0xBD;
sfr ADC_LOW2 = 0xBE;
sfr P1ASF = 0x9D;
sfr P2M0 = 0x96;
sfr P2M1 = 0x95;
/*Define ADC operation const for ADC_CONTR*/
#define ADC_POWER 0x80
#define ADC_FLAG 0x10
#define ADC_START 0x08
#define ADC_SPEEDLL 0x00
#define ADC_SPEEDL 0x20
#define ADC_SPEEDH 0x40
#define ADC_SPEEDHH 0x60
//延时
void Delay(WORD n)
{
WORD x;
while (n--)
{
x = 5000;
while (x--);
}
}
//初始AD寄存器
void InitADC()
{
P1ASF = 0xff;
ADC_RES = 0;
ADC_CONTR = ADC_POWER | ADC_SPEEDLL;
Delay(2);
}
//AD转换
BYTE GetADCResult(BYTE ch)
{
ADC_CONTR = ADC_POWER | ADC_SPEEDLL | ch | ADC_START;
_nop_();
_nop_();
_nop_();
_nop_();
while (!(ADC_CONTR ADC_FLAG));
ADC_CONTR = ~ADC_FLAG;
return ADC_RES;
}
void main()
{ BYTE temp;
P2M1=0; P2M0=0x03; //P2.0和P2.1强推挽
InitADC();
while (1)
{
temp=GetADCResult(0);//转换P1.0
if(temp1)
P2|=0x03; //P1.0有电压 P2.0和P2.1输出高
else
P2=0xFC; //P1.0无电压 P2.0和P2.1输出低
}
}
51单片机c语言,ADC模数转换的问题
对于这个,要这么看:
假设中断A是优先级高的中断,中断B是优先级低的中断
如果在正常执行的过程中,发生中断A,那么,中断A执行完成后,会返回正常程序;
如果在正常执行过程中,发生中断B,又在中断B处理过程中发生中断A,那么,中断A执行完成后,一定要返回的是中断B,这是由硬件决定的,不是软件决定的,所以,软件没有任何指令可以让中断A执行完成后直接跳过还没有执行完的中断B而直接回到主程序,因为这是硬件决定的,软件做不到,即便你在高级中断A中关闭了中断B,但是因为你原来的中断B还没有执行完,所以,仍然要把没执行完的部分执行下去,才能返回到正常程序.
对于ARM系列的可以,对于51来说,是不行的,因为51软件指令不允许修改PC寄存器的值
AVR单片机ADC控制LED程序(C语言)
给你写一个吧,反正很简单一个程序,用mega8实现,单片机型号你可以改,只要改掉中断向量号就行:
#include iom8v.h
#include macros.h
#define LED1_ON PORTB|= BIT(1)
#define LED1_OFF PORTB=~BIT(1)
//一下你可以再写七个灯或者更多
#define uchar unsigned char
#define uint unsigned int
uint adc_count = 0 ; //控制AD转换速度计数
uint a_time = 0 ; //用于AD数字滤波计数
uchar mode = 0 ; //用于AD处理结果赋值
void port_init(void)
{
DDRB = 0xff;
PORTB = 0x00;
DDRC = 0x00;
PORTC = 0xff;
DDRD = 0xf0;
PORTD = 0x00;
}
// 定时器分频: 64
// 设定定时值: 1ms
// 真实定时值: 1ms (0.0%)
void timer0_init(void)
{
TCCR0 = 0x00; //stop
TCNT0 = 0x83; //set count
TIMSK |= 0x01;
TCCR0 = 0x03; //start timer
}
#pragma interrupt_handler timer0_ovf_isr:10
void timer0_ovf_isr(void)
{
TCNT0 = 0x83; //reload counter value
adc_count++;
if(adc_count==50) //用于控制AD转换速度
{
adc_count=0;
ADCSRA = 0xCF;
}
else
{
ADCSRA = 0x00;
}
}
void adc_init(void)
{
ADCSRA = 0x00; //禁止AD转换
ADMUX = 0x07;
SFIOR |= 0x00;
ACSR = 0x80; //禁止模拟比较器
ADCSRA = 0xCF;
//ADCSRA = 0xED;
}
unsigned int adc_calc(void)
{
//计算实际电压
unsigned long value=0;
unsigned int voltage=0; //电压单位为(mV)
value=ADCL; //首先读低位
value|=(int)ADCH 8; //然后读高位
voltage=(value*5000)/1023;
ad_flag=1;
return voltage;
}
//采用AD取平均值的方式
#pragma interrupt_handler adc_isr:15
void adc_isr(void)
{
//转换完成后中断处理
unsigned int voltage1;
a_time++;
if(a_time8)
{voltage1=adc_calc();voltage2=voltage2+voltage1;}//数字滤波
while(a_time==8)
{
a_time=0;voltage=voltage2/8;voltage2=0;
if((voltage)1130){dianliang=0;}
if((voltage=1130)(voltage1300)){mode=1;}
if((voltage=1300)(voltage1560)){mode=2;}
if((voltage=1560)(voltage1750)){mode=3;}
if((voltage=1750)(voltage1950)){mode=4;}
if((voltage=1950)(voltage2150)){mode=5;}
if((voltage=2150)(voltage2341)){mode=6;}
if((voltage=2341)(voltage2560)){mode=7;}
if((voltage=2560)(voltage2710)){mode=8;}
if((voltage=2710)(voltage2870)){mode=9;}
}
else{mode=0;}
}
void LED_DISP(void) //用于控制LED显示
{
switch(mode)
{
case 0: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 1: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 2: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 3: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 4: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 5: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 6: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 7: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 8: /*此处写上你要控制的灯的亮或灭*/ ;break;
case 9: /*此处写上你要控制的灯的亮或灭*/ ;break;
default: break;
}
}void init_devices(void)
{
CLI(); //禁止所有中断
MCUCR = 0x00;
MCUCSR = 0x80;//禁止JTAG
GICR = 0x00;
timer0_init();
port_init();
adc_init();
//SEI();//开全局中断
}
void main(void)
{
init_devices();
while(1)
{
LED_DISP();
}
}
C语言实现ADC采样问题
我的理解是这样的:
我不知道ADC_TEMP 是否已经被初始化为零了。如果是,思路就是这样 0000 0000 0000 0000 0000 0000 这是ADC_temp,AD_DATA 应该就是采样的 每一位 的数 比如采样你说的 101101,其实应该把前面的0补齐,也就是0000 0000 0000 0000 0010 1101 。然后经过for循环,从第一位开始取,当遇到1的时候,执行ADC_temp|= 1; 我们知道或运算的规则,1和什么都是1。所以就从第一位0开始取,直到取完最后一位,每取一位左移一位,再和输出的AD_DATA 或运算。前提是,这个AD_DATA是高位输出。