*(unsigned int *)(a) = (v)

问:*(unsigned int *)(a) = (v) 的作用是什么?

答:地址a之后的sizeof(unsigned int)个字节的内存赋值为v。

更改指针类型,就是更改指针所能操作的内存单位长度,(unsigned int *)(a)意思就是只能操作a指向的4个字节的长度内存。

 

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
#include<reg52> //包含单片机寄存器的头文件 #include <intrins> #define ulong unsigned long #define uchar unsigned char #define uint unsigned int #define LCD1602_PORT P2 //用LED1602_PORT表示P2总线接口 #define PCF8591 0x90 //PCF8591 地址 #define NOP() _nop_() /* 定义空指令 */ #define _Nop() _nop_() /*定义空指令*/ // 位定义 sbit SCL=P1^0; //I2C 时钟 sbit SDA=P1^1; //I2C 数据 sbit LCD1602_RS = P0^5; //定义1602液晶显示屏的数据/命令选择端,数据/命令(H/L) sbit LCD1602_RW = P0^6; //定义1602液晶显示屏的读/写选择端,读/写(H/L) sbit LCD1602_EN = P0^7; //定义1602液晶显示屏的使能端 bit ack; /*应答标志位*/ // 变量定义 uchar AD_CHANNEL; ulong xdata LedOut[8]; //单片机内部存取器 ulong v,a,ss; uchar date; // 函数申明 extern bit ack;//起动总线函数 extern void Start_I2c();//结束总线函数 extern void Stop_I2c();//应答子函数 extern void Ack_I2c(bit a);//字节数据发送函数 extern void SendByte(uchar c);//有子地址发送多字节数据函数 extern bit ISendStr(uchar sla,uchar suba,uchar *s,uchar no) ;//无子地址发送多字节数据函数 extern bit ISendStrExt(uchar sla,uchar *s,uchar no);//无子地址读字节数据函数 extern uchar RcvByte(); void LCD1602_delay_ms(uint n); void LCD1602_write_com(uchar com); void LCD1602_write_data(ulong dat); void LCD1602_write_word(uchar *s); void Init_LCD1602(); bit ISendByte(uchar sla,uchar c); uchar IRcvByte(uchar sla); //MS延时函数(12M晶振下测试) void delay_ms(uint n) { unsigned int i,j; for(i=0;i<n i++) for(j=0;j xss=removed xss=removed xss=removed xss=removed xss=removed xss=removed xss=removed xss=removed>0) { LCD1602_write_data(*s); s++; } } //1602初始化函数 void Init_LCD1602() { LCD1602_EN = 0; LCD1602_RW = 0;//设置为写状态 LCD1602_write_com(0x38);//显示模式设定 LCD1602_write_com(0x0c);//开关显示、光标有无设置、光标闪烁设置 LCD1602_write_com(0x06);//写
51单片机IINA219 测电流电压和功率。 #include "LCD1602\LCD1602.h" #include "INA219_DRV\INA219_DRV.h" #include "common\common.h" #define TH0_VALUE 0x4B #define TL0_VALUE 0xFF //50ms per cycle. sbit BtnRefreshMode = P3^2; bit RefreshRate = 0; //0: 0.8s, 1: 0.5s bit RefreshFlag = 0; void RefreshData(void) { unsigned short BusVolt, Current, Power; unsigned short OffsetCurrent, OffsetPower; BusVolt = INA219_GetBusVolt(); PrintChar(0, 0, BusVolt/10000+48); PrintChar(1, 0, (BusVolt000)/1000+48); PrintChar(3, 0, (BusVolt00)/100+48); PrintChar(4, 0, (BusVolt0)/10+48); PrintChar(5, 0, BusVolt+48); OffsetCurrent = (BusVolt >> 9) + 2; //Gather statistics of the measured current under various voltage conditions when no load is connected to the output port. Use Excel to do curve fitting. Current = INA219_GetCurrent(); if(Current > OffsetCurrent) Current -= OffsetCurrent; else Current = 0; PrintChar(10, 0, Current/1000+48); PrintChar(12, 0, (Current00)/100+48); PrintChar(13, 0, (Current0)/10+48); PrintChar(14, 0, Current+48); OffsetPower = ((BusVolt >> 3) * OffsetCurrent)/125 + 6; Power = INA219_GetPower(); if(Power > OffsetPower) Power -= OffsetPower; else Power = 0; PrintChar(0, 1, Power/10000+48); PrintChar(1, 1, (Power000)/1000+48); PrintChar(3, 1, (Power00)/100+48); PrintChar(4, 1, (Power0)/10+48); PrintChar(5, 1, Power+48); } int main(void) { INA219_Init(); LCD_Init(); TMOD &= 0xF0; TMOD |= 0x01; //Timer 0 works in Mode 1 (16-bit Timer). TH0 = TH0_VALUE; TL0 = TL0_VALUE; PrintChar(2, 0, '.'); PrintChar(6, 0, 'V'); PrintChar(11, 0, '.'); PrintChar(15, 0, 'A'); PrintChar(2, 1, '.'); PrintChar(6, 1, 'W'); PrintStr(10, 1, "R:0.8s"); RefreshData(); EA = 1; //Global Interrupt Enable ET0 = 1; //Timer 0 Interrupt Enable TR0 = 1; //Enable Timer 0. while(1) { if(RefreshFlag) { RefreshData(); RefreshFlag = 0; } if(BtnRefreshMode == 0) //If the
这段代码中存在多个问题: 1.缺少头文件,例如avr/io.h 2.在main函数中没有开启总中断,需要添加sei()函数 3.在uart_init函数中设置波特率错误,应该设置为UBRR0=25,以获得波特率为19200 4.在uart_receive函数中,应该将UCSR0A的第7位(即RXC0)与0x80进行比较,而不是直接与0x08进行比较 5.在decode函数中,应该将ledbuf[0]的最高位清零,以显示数字"0" 修改后的代码如下: ``` #include <avr/io.h> const unsigned char disp[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xa7,0xa1,0x86,0x8e,0xff,0x7f}; unsigned char ledbuf[]={0xff,0xff,0xff,0xff}; unsigned char k=0; unsigned int x=0; unsigned int v=0; unsigned int i=0; unsigned char a[]={0x0e,0x0d,0x0b,0x07}; void delay(unsigned int x){ while(x--); } void io_init(void){ DDRC=0x0f; PORTC=0x0f; DDRB=0xff; PORTB=0xff; DDRD=0x02; } void t1_init(void){ TCCR1A=0x00; TCCR1B=0x0a; TCNT1=0; OCR1A=625; //ctc模式 ICR1=0xffff; } void uart_init(void){ UCSR0A=0b01000000; //异步,1起始位,八数据位,无校验,一停止 UCSR0B=0b00011000; //发送接收使能 UCSR0C=0b00000110; UBRR0=25;//baud=19200 } void uart_send(unsigned char d){//数据发送 while(!(UCSR0A&(1<<UDRE0))); //等待数据寄存器为空 UDR0=d; } unsigned char uart_receive(void){//数据接收 while(!(UCSR0A&(1<<RXC0))); return UDR0; } #pragma interrupt_handler Int_TCCR1A:12 void Int_TCCR1A(void){ k=(k+1)%4; PORTC=0x0f; PORTB=ledbuf[k]; PORTC=a[k]; } void decode(unsigned int v){ ledbuf[0]=disp[v/1000]; ledbuf[0]&=0x7f; //最高位清零 v=v%1000; ledbuf[1]=disp[v/100]; v=v%100; ledbuf[2]=disp[v/10]; ledbuf[3]=disp[v%10]; } int main(void){ uart_init(); io_init(); t1_init(); sei(); //开启总中断 TIMSK1=0x02; while(1){ if((PIND&0x04)==0x04){ uart_send('a'); } i=uart_receive(); decode(i); } } ``` 注意:这里只是对代码中存在的问题进行了修改,但并不能保证代码的正确性。在实际应用中,还需要根据具体需求进行修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值