msp430f149+ds3231 模拟iic 怎么没有sda信号?哪里不对了? 10C

#define DS_SCL BIT4 //DS_SCL = P5.4

#define DS_SDA BIT6 //DS_SDA = P2.6

#define DS_SCL_IN P5DIR &= ~DS_SCL

#define DS_SCL_OUT P5DIR |= DS_SCL

#define DS_SCL0 P5OUT &= ~DS_SCL

#define DS_SCL1 P5OUT |= DS_SCL

#define DS_SDA_IN P2DIR &= ~DS_SDA

#define DS_SDA_OUT P2DIR |= DS_SDA

#define DS_SDA0 P2OUT &= ~DS_SDA

#define DS_SDA1 P2OUT |= DS_SDA

#define DS_SDA_BIT P2IN & DS_SDA

void Init_CLK(void)

{

unsigned int i;

BCSCTL1 &= ~XTS;

do{

IFG1 &= ~OFIFG;

for(i=0xFF;i>0;i--);

}

while((IFG1 & OFIFG)!=0);

BCSCTL2 |= SELS+SELM1;

_EINT();

P5SEL|=0x30;

DS_SCL_OUT;  //SCLK对应的IO设置为输出状态

P2DIR&=0xbf;

P2OUT|=BIT6;

DS_SCL0;     //SCLK=0

delay_us(5);

}

void DS3231_Write(u8 write_address,u8 write_data)

{

u8 Device_Address = 0xD0; //DS3231写设备地址

iic_Start();                   //开始

iic_SendByte(Device_Address);  //发送设备地址

iic_Ack();



iic_SendByte(write_address);   //发送地址

iic_Ack();                     //应答



iic_SendByte(write_data);      //发送数据

iic_Ack();                     //应答



iic_Stop();                    //停止

}

u8 DS3231_Read(u8 read_address)

{

u8 Receive_Data; //数据接收

u8 Device_Address = 0xD0; //DS3231写设备地址



iic_Start();                   //开始

iic_SendByte(Device_Address);  //发送设备地址

iic_Ack();                     //应答



iic_SendByte(read_address);    //发送地址

iic_Ack();                     //应答



iic_Start();                   //重复开始

Device_Address = 0xD1;         //DS3231读设备地址

iic_SendByte(Device_Address);  //发送地址

iic_Ack();                     //应答



iic_in();

Receive_Data = iic_ReceiveByte();  //接收数据

iic_out();

iic_NAck();                    //不应答



iic_Stop();                    //停止



return Receive_Data;           //返回数据

}

void delay_us(u8 time)

{

for(int i=0;i<time;i++)

_NOP();

}

view plaincopy to clipboardprint?



//------------iic开始-----------

void iic_Start(void)

{

DS_SDA_OUT;

DS_SCL_OUT;

DS_SCL1;

delay_us(5);

DS_SDA1;

delay_us(10);

DS_SDA0;

delay_us(5);

DS_SCL0;

delay_us(5);

DS_SDA_IN;

}

//------------iic结束-----------

void iic_Stop(void)

{ DS_SDA_OUT;

DS_SCL_OUT;

DS_SCL1;

delay_us(10);    

DS_SDA0;

delay_us(5);

DS_SDA1;

delay_us(5); 

  DS_SDA_IN;

}

//------------iic应答-----------

void iic_Ack(void)

{

DS_SCL0;

DS_SDA0;

delay_us(5);

DS_SCL1;

delay_us(5);

DS_SCL0;

delay_us(5);

}

//------------iic不应答---------

void iic_NAck(void)

{

DS_SCL0;

DS_SDA1;

delay_us(5);

DS_SCL1;

delay_us(5);

DS_SCL0;

delay_us(5);

}

//------------iic发送-----------

void iic_SendByte(u8 SendData)

{

DS_SDA_OUT;

DS_SCL_OUT;

DS_SCL0;

u8 i;

for(i=0;i<8;i++)

{

    DS_SCL0;

delay_us(5);

if(SendData&0x80)         //MSB在前

        DS_SDA1;

else

                    DS_SDA0;

DS_SCL1;

delay_us(2);

DS_SCL0;

SendData<<=1;

}

//delay_us(5);

//DS_SDA1;

//delay_us(5);

//DS_SDA_IN;

}

//------------iic接收-----------

u8 iic_ReceiveByte(void)

{

u8 i,temp=0;

delay_us(5);

DS_SDA1;

delay_us(5);

for(i=0;i<8;i++)

{

    temp<<=1;

DS_SCL0;

delay_us(5);

DS_SCL1;

delay_us(2);

temp=DS_SDA_BIT;

if(temp==0x80)

        temp=temp|0x01;

else

        temp=temp&0xFE;

}

DS_SCL0;

delay_us(2);

return temp;

}

void iic_in()

{

DS_SCL_OUT;

DS_SDA_IN;

}

void iic_out()

{

DS_SCL_OUT;

DS_SDA_OUT;

DS_SCL1;

delay_us(5);

DS_SDA1;

delay_us(2);

}

1个回答

我自己用的软IIC程序,IAR平台,芯片STM8f103,你稍作修改可以适用别的平台和芯片。
整个IIC驱动严格按照IIC标准时序做的,为了这个,连延时函数都是半周期。
你可以分析一下我程序里面延时函数是用法,来进一步了解IIC时钟、数据、ACK之间的时序关系。
被控制芯片我的程序里面是ADS1115 AD芯片,这个修改一下芯片地址就可以用到任何芯片上,控制指令每个芯片不同,必须按照你选择的芯片重新修改。
写IIC程序其实和传统软串口没什么本质区别,只是动作更多点而已,当然由于IIC通信速率比较高,因此对信号的时序要求就比较高,否则容易引起通信失败。
这个软IIC时序,是根据延时函数确定速率的,修改该函数,可以实现各种通信速率,按照我的程序里面,机器时钟是16MHz,速率大概近400KHz。
通过示波器观察过,我这个IIC程序的波形和标准IIC时序图比较非常标准。

 #define    ADS1115_ADD        0X90           
#define SCL              PB_ODR_ODR4
#define SDA              PB_ODR_ODR5
#define SDA_IN           PB_IDR_IDR5
#define SET_SCL_OUT()    {PB_DDR_DDR4=1;PB_CR1_C14=0;PB_CR2_C24=0;}
#define SET_SDA_OUT()    {PB_DDR_DDR5=1;PB_CR1_C15=0;PB_CR2_C25=0;}
#define SET_SDA_IN()    {PB_DDR_DDR5=0;PB_CR1_C15=0;PB_CR2_C25=0;}

void Init_IIC(void)
   {
      I2C_CR1 &= 0xFE;      //  PE=0, disable IIC module  
      SET_SDA_OUT();
      SDA=1;
      SET_SCL_OUT();
      SCL=1;
   }

//--------------------------------------------------------------
//IIC主时钟定时用延时函数
//--------------------------------------------------------------
void Delay_CLK()
   {
      NOP();NOP();NOP();NOP();NOP();
   }

//--------------------------------------------------------------
//IIC 启动信号发送
//--------------------------------------------------------------
void IIC_Start(void)
   {
      SDA = 0;                   
      Delay_CLK();                
      SCL = 0;                    
   }

//--------------------------------------------------------------
//IIC 停止信号发送
//-------------------------------------------------------------- 
void IIC_Stop(void)
   {
      SDA = 1;                   
      Delay_CLK();                
      SCL = 1;
   }

//--------------------------------------------------------------
//MASTER模式 发送ACK应答
//--------------------------------------------------------------
void IIC_SendACK(u8 ACK)
   {
      SDA = ACK;
      SCL = 1;                   
      Delay_CLK(); 
      Delay_CLK();
      SCL = 0;
   }

//--------------------------------------------------------------
//IIC单字节发送+ACK检测
//--------------------------------------------------------------

u8 IIC_SendByte(u8 Send_DAT)
   {
      u8    CHK_ACK;
      for (u8 i=0;i<8;i++)         
         {
            SCL = 0;                
            Delay_CLK();
            SDA=Send_DAT>>7;
            Send_DAT <<=  1;
            SCL = 1;                
            Delay_CLK();Delay_CLK(); 
         } 
      SCL = 0;                
      Delay_CLK();
      SET_SDA_IN();
      Delay_CLK(); 
      SCL = 1;    
      CHK_ACK = (u8)SDA_IN;
      SET_SDA_OUT();
      Delay_CLK();   
      SCL = 0;   
      Delay_CLK();  
      return CHK_ACK;   
   }

//--------------------------------------------------------------
//IIC 单字节接受
//--------------------------------------------------------------
u8 IIC_RecvByte()
   {
      u8 Recv_DAT = 0;
      SDA = 1;     
      SET_SDA_IN();
      for (u8 i=0; i<8; i++)         
         { 
            Recv_DAT <<= 1;
            SCL = 1;
            Delay_CLK(); 
            Recv_DAT+=(u8)SDA_IN;   
            NOP();NOP();
            SCL = 0;                
            Delay_CLK();  
         }
      SET_SDA_OUT();
      return Recv_DAT;
   }

//--------------------------------------------------------------
//ADS1115 写控制项
//--------------------------------------------------------------
void config_ads1115(u8 regadd,u8 wdata,u8 wdata1)
   {
      IIC_Start();
      IIC_SendByte(ADS1115_ADD);//根据需要,这里可以加上ACK检测
      IIC_SendByte(regadd);
      IIC_SendByte(wdata);
      IIC_SendByte(wdata1);
      IIC_Stop();             
   }
//--------------------------------------------------------------
//ADS1115 读转换结果
//--------------------------------------------------------------
int Read_ads1115(u8 REG_ADD)
   {
      int READ_TMP;
      IIC_Start();            
      IIC_SendByte(ADS1115_ADD);   //写地址为7位器件地址+读写位=0   
      IIC_SendByte(REG_ADD); 
      IIC_Stop();
      IIC_Start();    
      IIC_SendByte(ADS1115_ADD|1); //读地址为7位器件地址+读写位=1   
      *((u8*)(&READ_TMP))= IIC_RecvByte();
      IIC_SendACK(0);
      *((u8*)(&READ_TMP)+1)= IIC_RecvByte();
      IIC_SendACK(0);
      IIC_Stop();
      return READ_TMP;
   }
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
msp430f149+ds3231 模拟iic 怎么没有sda信号?哪里不对了?
#define DS_SCL BIT4 //DS_SCL = P5.4 #define DS_SDA BIT6 //DS_SDA = P2.6 #define DS_SCL_IN P5DIR &= ~DS_SCL #define DS_SCL_OUT P5DIR |= DS_SCL #define DS_SCL0 P5OUT &= ~DS_SCL #define DS_SCL1 P5OUT |= DS_SCL #define DS_SDA_IN P2DIR &= ~DS_SDA #define DS_SDA_OUT P2DIR |= DS_SDA #define DS_SDA0 P2OUT &= ~DS_SDA #define DS_SDA1 P2OUT |= DS_SDA #define DS_SDA_BIT P2IN & DS_SDA void Init_CLK(void) { unsigned int i; BCSCTL1 &= ~XTS; do{ IFG1 &= ~OFIFG; for(i=0xFF;i>0;i--); } while((IFG1 & OFIFG)!=0); BCSCTL2 |= SELS+SELM1; _EINT(); P5SEL|=0x30; DS_SCL_OUT; //SCLK对应的IO设置为输出状态 P2DIR&=0xbf; P2OUT|=BIT6; DS_SCL0; //SCLK=0 delay_us(5); } void DS3231_Write(u8 write_address,u8 write_data) { u8 Device_Address = 0xD0; //DS3231写设备地址 iic_Start(); //开始 iic_SendByte(Device_Address); //发送设备地址 iic_Ack(); iic_SendByte(write_address); //发送地址 iic_Ack(); //应答 iic_SendByte(write_data); //发送数据 iic_Ack(); //应答 iic_Stop(); //停止 } u8 DS3231_Read(u8 read_address) { u8 Receive_Data; //数据接收 u8 Device_Address = 0xD0; //DS3231写设备地址 iic_Start(); //开始 iic_SendByte(Device_Address); //发送设备地址 iic_Ack(); //应答 iic_SendByte(read_address); //发送地址 iic_Ack(); //应答 iic_Start(); //重复开始 Device_Address = 0xD1; //DS3231读设备地址 iic_SendByte(Device_Address); //发送地址 iic_Ack(); //应答 iic_in(); Receive_Data = iic_ReceiveByte(); //接收数据 iic_out(); iic_NAck(); //不应答 iic_Stop(); //停止 return Receive_Data; //返回数据 } void delay_us(u8 time) { for(int i=0;i<time;i++) _NOP(); } view plaincopy to clipboardprint? <br> //------------iic开始----------- void iic_Start(void) { DS_SDA_OUT; DS_SCL_OUT; DS_SCL1; delay_us(5); DS_SDA1; delay_us(10); DS_SDA0; delay_us(5); DS_SCL0; delay_us(5); DS_SDA_IN; } //------------iic结束----------- void iic_Stop(void) { DS_SDA_OUT; DS_SCL_OUT; DS_SCL1; delay_us(10); DS_SDA0; delay_us(5); DS_SDA1; delay_us(5); DS_SDA_IN; } //------------iic应答----------- void iic_Ack(void) { DS_SCL0; DS_SDA0; delay_us(5); DS_SCL1; delay_us(5); DS_SCL0; delay_us(5); } //------------iic不应答--------- void iic_NAck(void) { DS_SCL0; DS_SDA1; delay_us(5); DS_SCL1; delay_us(5); DS_SCL0; delay_us(5); } //------------iic发送----------- void iic_SendByte(u8 SendData) { DS_SDA_OUT; DS_SCL_OUT; DS_SCL0; u8 i; for(i=0;i<8;i++) { DS_SCL0; delay_us(5); if(SendData&0x80) //MSB在前 DS_SDA1; else DS_SDA0; DS_SCL1; delay_us(2); DS_SCL0; SendData<<=1; } //delay_us(5); //DS_SDA1; //delay_us(5); //DS_SDA_IN; } //------------iic接收----------- u8 iic_ReceiveByte(void) { u8 i,temp=0; delay_us(5); DS_SDA1; delay_us(5); for(i=0;i<8;i++) { temp<<=1; DS_SCL0; delay_us(5); DS_SCL1; delay_us(2); temp=DS_SDA_BIT; if(temp==0x80) temp=temp|0x01; else temp=temp&0xFE; } DS_SCL0; delay_us(2); return temp; } void iic_in() { DS_SCL_OUT; DS_SDA_IN; } void iic_out() { DS_SCL_OUT; DS_SDA_OUT; DS_SCL1; delay_us(5); DS_SDA1; delay_us(2); }
msp430f149控制lcd12864显示汉字
msp430f149控制lcd12864显示汉字代码,msp430f149控制lcd12864显示汉字代码下载
关于通过MSP430F149实现对RC522的写卡操作。
我是一个新人,刚刚接触嵌入式。 前几日在淘宝购买了 MSP430F149和RFID RC522。收到货之后,按照流程测试了MSP430F149,正常。 并且按照PDF《RFID RC522读卡模块使用说明》对RC522进行了读卡操作,也正常。但是想要学习进行写卡操作,打开IC调试程序之后,寻卡总是失败。请问原因是什么? 需要重新烧录哪一个程序吗?还是接线方式需要更改,连接上也没有使用说明上的蜂鸣声。谢谢! (我在百度和搜狗查询很久,基本都是po出来一段代码) 程序和软件这个链接里面: 提取码:mjir [程序和代码](https://pan.baidu.com/s/1Zz-4E5Kw_Hv1HQZwjOM5mA "提取码:mjir ")
单片机MSP430f5529看门狗定时器
MSP430f5529,用看门狗定时器使p3.7引脚相连的LED每秒点亮一次,灯亮的时间为定时的四分之一
MSP430F149定时器运用问题?
程序开始一直检测是否在充电,如果在充电,就让LED闪烁,否则循环检测。怎么实现? led闪烁就要循环了,那外层循环还有什么用啊? 求大神帮助
MSP430单片机用DS1302在LCD1602上显示为什么会闪烁
#include <msp430g2553.h> typedef unsigned char uchar; typedef unsigned int uint; /**************宏定义***************/ #define DataDir P1DIR #define DataPort POUT #define Busy 0x80 #define CtrlDir P2DIR #define CLR_RS P2OUT&=~BIT0; //RS = P2.0 #define SET_RS P2OUT|=BIT0; #define CLR_RW P2OUT&=~BIT1; //RW = P2.1 #define SET_RW P2OUT|=BIT1; #define CLR_EN P2OUT&=~BIT2; //EN = P2.2 #define SET_EN P2OUT|=BIT2; /**************宏定义***************/ #define DS_RST BIT3 //DS_RST = P2.3 #define DS_SCL BIT4 //DS_SCL = P2.4 #define DS_SDA BIT5 //DS_SDA = P2.5 #define DS_RST_IN P2DIR &= ~DS_RST #define DS_RST_OUT P2DIR |= DS_RST #define DS_RST0 P2OUT &= ~DS_RST #define DS_RST1 P2OUT |= DS_RST #define DS_SCL_IN P2DIR &= ~DS_SCL #define DS_SCL_OUT P2DIR |= DS_SCL #define DS_SCL0 P2OUT &= ~DS_SCL #define DS_SCL1 P2OUT |= DS_SCL #define DS_SDA_IN P2DIR &= ~DS_SDA #define DS_SDA_OUT P2DIR |= DS_SDA #define DS_SDA0 P2OUT &= ~DS_SDA #define DS_SDA1 P2OUT |= DS_SDA #define DS_SDA_BIT P2IN & DS_SDA uchar flag;//定义一个读标志位 uchar second,minute,hour,week,day,month,year;//秒、分、时、星期、日、月、年 /******************************************* 函数名称:delay 功 能:延时一段时间 参 数:time--延时长度 ********************************************/ void delay(uint time) { uint i; for(i = 0;i < time;i++) _NOP(); }  /******************************************* 函数名称:Delay5ms 功 能:延时约5ms ********************************************/ void Delay5ms(void) { uint i=40000; while (i != 0) { i--; } } /******************************************* 函数名称:WaitForEnable 功 能:等待1602液晶完成内部操作 ********************************************/ void WaitForEnable(void) { P1DIR &= 0x00; //将P1口切换为输入状态 CLR_RS; SET_RW; _NOP(); SET_EN; _NOP(); _NOP(); while((P1IN & Busy)!=0); //检测忙标志 CLR_EN; P4DIR |= 0xFF; //将P1口切换为输出状态 }  /******************************************* 函数名称:write_com 功 能:向液晶模块写入命令 ********************************************/ void write_com(uchar cmd) { WaitForEnable(); // 检测忙信号? CLR_RS;  CLR_RW; _NOP(); DataPort = cmd; //将命令字写入数据端口 _NOP();  SET_EN; //产生使能脉冲信号 _NOP(); _NOP(); CLR_EN;  } /******************************************* 函数名称:write_data 功 能:向液晶显示的当前地址写入显示数据 参 数:data--显示字符数据 返回值 :无 ********************************************/ void write_data( uchar data ) { WaitForEnable(); //等待液晶不忙 SET_RS; CLR_RW; _NOP(); DataPort = data; //将显示数据写入数据端口 _NOP(); SET_EN; //产生使能脉冲信号 _NOP(); _NOP(); CLR_EN;  } void Write1602(uchar add,uchar dat) { write_com(add); write_data(dat); } void zifuchuan(uchar *ch) { while(*ch!=0) write_data(*ch++); Delay5ms();  } /******************************************* 函数名称:LcdReset 功 能:对1602液晶模块进行复位操作 ********************************************/ void LcdReset(void) { CtrlDir |= 0x07; //控制线端口设为输出状态 DataDir = 0xFF; //数据端口设为输出状态 write_com(0x38);//规定的复位操作 Delay5ms(); write_com(0x38);  Delay5ms(); write_com(0x38); Delay5ms(); write_com(0x38);//显示模式设置  write_com(0x06);//写字符时整体不移动 write_com(0x0c);//显示开,不开游标,不闪烁 write_com(0x01);//显示清屏 Write1602(0x80,'2'); Write1602(0x81,'0'); Write1602(0x80+4,'-'); Write1602(0x80+7,'-'); Write1602(0x80+0x40+5,':'); Write1602(0x80+0x40+8,':'); } /******************************************* 函数名称:Reset_DS1302 功 能:对DS1302进行复位操作 ********************************************/ void Reset_DS1302(void) { DS_RST_OUT; //RST对应的IO设置为输出状态 DS_SCL_OUT; //SCLK对应的IO设置为输出状态 DS_SCL0; //SCLK=0 DS_RST0; //RST=0 delay(10); DS_SCL1; //SCLK=1 } /******************************************* 函数名称:Write1Byte 功 能:对DS1302写入1个字节的数据 ********************************************/ void Write_Byte(uchar wdata) { uchar i; DS_SDA_OUT; //SDA对应的IO设置为输出状态 DS_RST1; //REST=1; for(i = 8; i > 0; i--) { if(wdata&0x01) DS_SDA1; else DS_SDA0; DS_SCL0; delay(10); DS_SCL1; delay(10); wdata >>= 1; } } /******************************************* 函数名称:Read1Byte 功 能:从DS1302读出1个字节的数据 ********************************************/ uchar Read_Byte() { uchar i; uchar rdata = 0X00; DS_SDA_IN; //SDA对应的IO设置为输入状态 DS_RST1; //REST=1; for(i = 8; i > 0; i--) { DS_SCL1; delay(10); DS_SCL0; delay(10); rdata >>= 1; if(DS_SDA_BIT) rdata |= 0x80; } return(rdata); } /******************************************* 函数名称:Write_dat 功 能:向某个寄存器写入一个字节数据 参 数:add--寄存器地址 dat--写入的数据 ********************************************/ void Write_dat(uchar add, uchar dat) { DS_RST0; DS_SCL0;  _NOP(); DS_RST1; Write_Byte(add); //写入地址 Write_Byte(dat); //写入数据 DS_SCL1; DS_RST0; } /******************************************* 函数名称:Read_dat 功 能:从某个寄存器读出一个字节数据 参 数:addr--寄存器地址 返回值 :读出的数据 ********************************************/ uchar read_1302add(uchar add) { uchar rdata;  DS_RST0; DS_SCL0; _NOP(); DS_RST1; Write_Byte(add); //写入地址 rdata = Read_Byte(); //读出数据 DS_SCL1; DS_RST0; return(rdata); } /***********初始化1302*************/ void init_1302() { flag=read_1302add(0x81);//读秒寄存器最高位,读出时钟状态 if(flag&0x80);//判断时钟是否关闭,若内部关闭,则初始化,否则继续走 { Write_dat(0x8e,0x00); Write_dat(0x80,((55/10)<<4|(55%10)));//写秒寄存器,并写入初值55 Write_dat(0x82,((59/10)<<4|(59%10)));//写分寄存器,并写入初值59 Write_dat(0x84,((22/10)<<4|(22%10)));//写小时寄存器,并写入初值23 Write_dat(0x86,((24/10)<<4|(24%10)));//写日寄存器,并写入初值18 Write_dat(0x88,((2/10)<<4|(2%10)));//写月寄存器,并写入初值2 Write_dat(0x8a,((5/10)<<4|(5%10)));//写周寄存器,并写入初值5 Write_dat(0x8c,((12/10)<<4|(12%10)));//写年寄存器,并写入初值12,不能写2012年 Write_dat(0x90,0xa5);//写充电方式 Write_dat(0x8e,0x80);//加上写保护  } } /*****************读出秒的十进制数***************************/ uchar readsecond() { uchar dat; dat=read_1302add(0x81); second=((dat&0x70)>>4)*10+(dat&0x0f); return second; } /*****************读出分的十进制数***************************/ uchar readminute() { uchar dat; dat=read_1302add(0x83); minute=((dat&0x70)>>4)*10+(dat&0x0f); return minute; } /*****************读出小时的十进制数***************************/ uchar readhour() { uchar dat; dat=read_1302add(0x85); hour=((dat&0x70)>>4)*10+(dat&0x0f); return hour; } /*****************读出天的十进制数***************************/ uchar readday() { uchar dat; dat=read_1302add(0x87); day=((dat&0x70)>>4)*10+(dat&0x0f); return day; } /*****************读出月的十进制数***************************/ uchar readmonth() { uchar dat; dat=read_1302add(0x89); month=((dat&0x70)>>4)*10+(dat&0x0f); return month; } /*****************读出周的十进制数***************************/ uchar readweek() { uchar dat; dat=read_1302add(0x8b); week=((dat&0x70)>>4)*10+(dat&0x0f); return week; } /*****************读出年的十进制数***************************/ uchar readyear() { uchar dat; dat=read_1302add(0x8d); year=((dat&0xf0)>>4)*10+(dat&0x0f); return year; } /************************读出所有时间**********************/ void readtime() { readsecond(); readminute(); readhour(); readday(); readmonth(); readweek(); readyear(); } /*********************向1602写入时间****************************/ void write_second() { uchar shi,ge; shi=second/10; ge=second%10; Write1602(0x80+0x40+9,0x30+shi); Write1602(0x80+0x40+10,0x30+ge); } void write_minute() { uchar shi,ge; shi=minute/10; ge=minute%10; Write1602(0x80+0x40+6,0x30+shi); Write1602(0x80+0x40+7,0x30+ge); } void write_hour() { uchar shi,ge; shi=hour/10; ge=hour%10; Write1602(0x80+0x40+3,0x30+shi); Write1602(0x80+0x40+4,0x30+ge); } void write_day() { uchar shi,ge; shi=day/10; ge=day%10; Write1602(0x80+8,0x30+shi); Write1602(0x80+9,0x30+ge); } void write_month() { uchar shi,ge; shi=month/10; ge=month%10; Write1602(0x80+5,0x30+shi); Write1602(0x80+6,0x30+ge); } void write_year() { uchar shi,ge; shi=year/10; ge=year%10; Write1602(0x80+2,0x30+shi); Write1602(0x80+3,0x30+ge); } void write_week() { Write1602(0x80+12,0x30+week); //uchar week; switch(week) { case 1: Write1602(0x80+12,'M'); Write1602(0x80+13,'O'); Write1602(0x80+14,'N'); break; case 2:Write1602(0x80+12,'T'); Write1602(0x80+13,'U'); Write1602(0x80+14,'E'); break; case 3:Write1602(0x80+12,'W'); Write1602(0x80+13,'E'); Write1602(0x80+14,'N'); break; case 4:Write1602(0x80+12,'T'); Write1602(0x80+13,'H'); Write1602(0x80+14,'U'); break; case 5:Write1602(0x80+12,'F'); Write1602(0x80+13,'R'); Write1602(0x80+14,'I'); break; case 6:Write1602(0x80+12,'S'); Write1602(0x80+13,'A'); Write1602(0x80+14,'T'); break; case 7:Write1602(0x80+12,'S'); Write1602(0x80+13,'U'); Write1602(0x80+14,'N'); break; } } /*************************主函数*************************/ void main( void ) { /*下面六行程序关闭所有的IO口*/ P1DIR = 0XFF;P1OUT = 0XFF; P2DIR = 0XFF;P2OUT = 0XFF; WDTCTL = WDTPW + WDTHOLD; //关狗  LcdReset(); //zifuchuan("The time is:"); //循环读数显示 init_1302(); while(1) { readtime(); write_second(); write_minute(); write_hour(); write_day(); write_month(); write_year(); write_week(); }  }
msp430关于编译的问题
msp430g2553使用ccs编译时,出现这个问题应该如何处理。谢谢![图片](https://img-ask.csdn.net/upload/201703/26/1490511513_653778.jpg)
MSP430F149串口接收中断数据存储问题,SOS~
我在使用串口接收中断读取NFC模块数据时,我想将NFC模块回传的状态指令存储于数组中。通过串口助手,NFC模块可以收到单片机发送的请求指令,同时会向MSP430单片机发送状态指令。但是数组中并没有相关数据,请各位指点迷津,感激不尽!代码如下: ``` /********************************************************************** USART0 接收中断函数 ***********************************************************************/ #pragma vector = USART0RX_VECTOR __interrupt void Usart0_Rx(void) { IE1&=~URXIE0; //关闭串口中断使能 uint i=3; uchar *pq0=value; //value[N_Data]={0xfe,0xfe,0xfe,0xf,...} SendUart(pq0,N_Data); //发送数据请求指令 Add_UsData(RXBUF0); //接收NFC状态 while(P2IN==1) //有手机靠近NFC { i--; if(aRxBuff[9]==0xE7) { TXBUF0 = (uchar)times0; } else SendUart(pq0,20); if(i==0) break; } IE1|=URXIE0; // 使能USART0的接收中断 } /********************************************************************** 功能:发送函数。采用查询方式。 PBuffer:指向发送数据缓冲区的指针 n_byte:发送的字节数 ***********************************************************************/ void SendUart(uint *pBuffer,uint n_byte) { uint q0; for(q0=0;q0<n_byte;q0++) { while((IFG1&UTXIFG0)==0); //判断是否发送完毕 TXBUF0=*pBuffer; pBuffer++; } pBuffer=0; } /********************************************************************** 处理NFC状态数据 ***********************************************************************/ void Add_UsData(uchar *sq0) { if(NRxBuff<N_Data) { while((IFG1&URXIFG0)==0); //判断是否接收完毕 aRxBuff[NRxBuff]=*sq0; NRxBuff++; } NRxBuff=0; } ```
大神们求助关于msp430f5529
求一个基于msp430f5529的贪吃蛇和走迷宫的小游戏代码(>﹏<)(>﹏<)(>﹏<)(>﹏<)
msp430f5529驱动安装后在我的电脑上无显示
最开始msp430f5592lp安装驱动成功后在我的电脑显示为fat,现在没有窗口了,请问该怎么样弄才能打开里面的文件呢?
求msp430F149避障小车C程序,要是是智能小车更好
谢谢!请发送邮箱875604452@qq.com!,加分!避障用hc-sr04
MSP430程序疑问,求大神帮忙
图1,peaksignal( )中,for(i=4096;i>0;i--)这段程序4096什么意思,后面备注写的16bit=4096不懂它什么回事? longtoascii( ),这个do…while语句是怎么转为ASCII的不明白 图2,systemperature( ),temp=temp+((xtemp-673)*42300)/1024这里面的参数什么意思,求大神帮忙
msp430f5529关于灯闪烁间隔问题
请问下我想用timerA来使灯的闪烁间隔为20s,就是灯亮20s,灭20s,但他的极限就只有几秒,怎么改进来实现或者用其他方法
msp430F5529A中断程序运行卡顿
菜鸟写了一段程序如下,希望实现电子秤的功能。中断的话是两个按键触发的,首次按下S1,清零;第二次按下S1进行称重;按下S2则关机。 真正运行起来卡的不行甚至动不起来,请问是不是我的主函数设计有问题? 还有求多个触发中断的例程,感觉自己写的结构确实很不合理。 谢谢啦 void main(void) { P1DIR = 0X00;//调零,按下S1+开始称重,按下S1:设置P1.7为输入状态 P1IE = 0X80;//设置P1.7开中断 P1IES = 0X00;//设置P1.7中断为上升沿中断 P1IFG = 0;//清除P1的中断标志,无所谓,因为不用这个标志判断进入何种中断程序 _EINT();//开全局中断 P2DIR = 0X00;//关机,按下S2(P2.2),设为输入状态 P2IE = 0X04;//设置P2.2开中断 P2IES = 0X00;//设置P2中断为上升沿中断 _EINT();//开全局中断 welcome(); LPM3; } 具体的中断响应是这样的: #pragma vector = PORT1_VECTOR __interrupt void P1_ISR(void) { switch(m) //m为全局变量,初始值为1 { case 1: { m = 0; ADC(); zero[0] = results[0]; display0(); LPM3; } //实现清零功能 case 0: //实现称重功能 { ADC(); //称量程序 char q[4]; results[0] = results[0] - zero[0]; for(int i=3 ; i>=0; --i) { q[i] = results[0]%10+48; results[0]=results[0]/10; } display(q); LPM3; } } } #pragma vector = PORT2_VECTOR __interrupt void P2_ISR(void) { switch(k) { case 1: { k = 0; display2(); LPM3; } case 0: { k =1; welcome(); } } } 拜谢
MSP430F247串口发送问题,求高手帮忙看一下,谢谢,实在是弄不出来了~
我的程序是这样的: #include <msp430f247.h> void delay_us(int n) { for(int i=0; i<n; i++) for(int j=0; j<8; j++); } void UartInit() { UCA0CTL1 |= UCSWRST; P3SEL |= 0x30; // P3.4,5 = USART0 TXD/RXD UCA0CTL1 |= UCSSEL1; //8Mhz, 115200 UCA0CTL0 = 0; // UCA0CTL0 &= ~UC7BIT; //no parity, 8-bit data, uart mode UCA0BR0 = 69; UCA0BR1 = 0; UCA0MCTL |= UCBRS2; UCA0CTL1 &= ~UCSWRST; IE2 |= UCA0RXIE; // Enable USCI_A0 RX interrupt } int main( void ) { volatile unsigned int i; // Stop watchdog timer to prevent time out reset WDTCTL = WDTPW + WDTHOLD; //clock set BCSCTL1 &= ~XT2OFF; // XT2on BCSCTL2 |= SELM1 + SELS + DCOR; do { IFG1 &= ~OFIFG; // Clear OSCFault flag delay_us(50); }while((IFG1 & OFIFG)); // BCSCTL3 |= XT2S1; //uart init UartInit(); //spi init // SpiInit(); _BIS_SR(LPM0_bits + GIE); // Enter LPM0 w/ interrupt while(1) { while (!(IFG2&UCA0TXIFG)); UCA0TXBUF = 0xab; } } #pragma vector=USCIAB0RX_VECTOR __interrupt void USCI0RX_ISR(void) { while (!(IFG2&UCA0TXIFG)); // USCI_A0 TX buffer ready? UCA0TXBUF = UCA0RXBUF; // TX -> RXed character } 实在是弄不明白为什么每次启动单片机就发送了个0xE0然后就没了,但是我的while里面是一直发送的啊,而中断程序里的发送是正常的,也就是当pc给单片机发送的时候单片机将收到的字节发送回来是可以的,怎么调都是这样的,求大神指点一二,谢谢了~
关于MSP430F5529单片机的串口问题
一句话,我要疯了,,现在的问题是,使用的串口调试助手来调试的,开发环境从IAR低版本到高版本以及CCS,程序是官方程序和自己编写的,以及网友的。板子是标准板,还有个自己的板子。USB转串口线两条。但是结果都一样。 主要是使用串口调试助手发送字符串,然后接收相同的。结果是,如果我发较长的字符串,前四位会丢失。单个发送字符,根本没有任何返回信息。我简直要疯了,真的不知道原因了,期待大神拯救啊 代码如下: #include <msp430.h> int main(void) { WDTCTL = WDTPW + WDTHOLD; // Stop WDT P3SEL = BIT3+BIT4; // P3.4,5 = USCI_A0 TXD/RXD UCA0CTL1 |= UCSWRST; // **Put state machine in reset** UCA0CTL1 |= UCSSEL_2; // SMCLK UCA0BR0 = 6; // 1MHz 9600 (see User's Guide) UCA0BR1 = 0; // 1MHz 9600 UCA0MCTL = UCBRS_0 + UCBRF_13 + UCOS16; // Modln UCBRSx=0, UCBRFx=0, // over sampling UCA0CTL1 &= ~UCSWRST; // **Initialize USCI state machine** UCA0IE |= UCRXIE; // Enable USCI_A0 RX interrupt P4OUT=0; __bis_SR_register(LPM0_bits + GIE); // Enter LPM0, interrupts enabled __no_operation(); // For debugger } // Echo back RXed character, confirm TX buffer is ready first #pragma vector=USCI_A0_VECTOR __interrupt void USCI_A0_ISR(void) { switch(__even_in_range(UCA0IV,4)) { case 0:break; // Vector 0 - no interrupt case 2: // Vector 2 - RXIFG while (!(UCA0IFG&UCTXIFG)); // USCI_A0 TX buffer ready? UCA0TXBUF = UCA0RXBUF; // TX -> RXed character break; case 4:break; // Vector 4 - TXIFG default: break; } }
单片机msp430实验求解
谁有单片机msp430汽车转向灯实验的程序和proteus仿真图啊,急求啊,谢谢
MSP4305438a下载软件?谁有啊,跪求
msp430f5438a单片机,刚买来,下载配套的下载器win10用不了,求下载器软件。
编了一个MSP430f249捕获脉冲宽度的程序,没有捕获到数据,麻烦大神们帮忙看看
程序代码如下: main.c文件: /*定时器B测量某输入信号脉冲宽度*/ #include <msp430f249.h> #include"lcd.h" #define M1 10 unsigned int cap1,N1; long width[10]={0,0,0,0,0,0,0,0,0,0}; char m=0; char lcd_buf[]={0,0,0,0,0,0}; long data; const char table[]="0123456789"; const char table1[]="width(us)"; void data_to_buf(unsigned long data2)//值送显示缓冲区函数 { unsigned char i; for(i=0;i<6;i++) { lcd_buf[i]=table[data2%10];//此时低位在前 data2=data2/10; } for(i=5;i>0;i--) { if(lcd_buf[i]=='0') lcd_buf[i]=' ';//数字其那面的0不显示 else break; } } void main( void ) { char num,k1; // Stop watchdog timer to prevent time out reset WDTCTL = WDTPW + WDTHOLD;//关闭看门狗 BCSCTL2=SELS+DIVS0+DIVS1;//SMCLK=XT2 P4SEL|=0x01;//P4.0作为捕获模块功能输入端输入方波 P5DIR=0xFF;//设置P5端为输出 P6DIR=0xFF;//设置P6端为输出 lcdinit(); //TBCCTL0=0;//捕获源为P4.0,即CCI0A(也是CCI0B) TBCCTL0|=CM_1+SCS+CAP+CCIE;//上升沿捕获,同步捕获,工作在捕获模式 //+终端允许 TBCTL|=TBSSEL_2+MC_2+TBIE;//选择SMCLK+连续计数模式 //+终端允许 write_com(0x80);//显示第一行字 for(num=0;num<10;num++) write_data(table1[num]); _EINT();//中断允许 while(1) { data=0; for(k1=0;k1<M1;k1++) data+=width[k1]; data=data/M1; //data=10000; if(m==0) { data_to_buf(data);//数据送显示缓冲区 write_com(0x80+0x40);//第二行显示频率 for(num=0;num<6;num++) write_data(lcd_buf[5-num]); } } } #pragma vector=TIMERB0_VECTOR __interrupt void TimerB0(void)//定时器TB的CCR0的中断,用于检测脉冲上升与下降 { if(TBCCTL0&CM1)//捕获到下降沿 { width[m++]=65536*N1+TBCCR0-cap1;//记录下结束时间 N1=0; TBCCTL0=CM_1+SCS+CAP+CCIE;//+TBCLR; //改为上升沿捕获,CM1置0,CM0置1 if(m==M1) m=0; } else if(TBCCTL0&CM0)//捕获到上升沿 { cap1=TBCCR0; N1=0; TBCCTL0=CM_2+SCS+CAP+CCIE;//+TBCLR; //改为下降沿捕获,CM0置0,CM1置1 } } //Timer_B7 Interrupt Vector(TBIV) handler #pragma vector=TIMERB1_VECTOR __interrupt void Timer_B(void) { switch(TBIV) { case 14:N1++;break;//溢出 } } lcd.c文件: #include<msp430f169.h> #define lcdrs_0 P6OUT&=~BIT0;//P6.0=0命令 #define lcdrs_1 P6OUT|=BIT0;//P6.0=1 #define lcden_0 P6OUT&=~BIT2;//P6.2=0 #define lcden_1 P6OUT|=BIT2;//P6.2=1 void delay(unsigned int z) { unsigned int i,j; for(i=z;i>0;i--) for(j=110;j>0;j--); } void write_com(char com) //写入 { lcdrs_0;//LCD选择输入命令 P5OUT=com;//向P0端口输入命令 delay(5);//延时 lcden_1;//打开LCD使能 delay(5);//一个高脉冲 lcden_0;//关闭LCD使能 } void write_data(char dataout) { lcdrs_1;//设置为输入数据 P5OUT=dataout;//将数据赋给P0端口 delay(5);//延时 lcden_1;//置高 delay(5);//高脉冲 lcden_0;//置低,完成高脉冲 } void lcdinit() { lcden_0; write_com(0x38);//设置16X2显示5X7点阵,8位数据接口 write_com(0x0c);//设置开始显示,不显示光标 write_com(0x06);//写一个字符后地址指针加1 write_com(0x01);//显示清零,数据指针清零 } lcd.h文件: extern void delay(unsigned int z); extern void write_com(char com); extern void write_data(char dataout); extern void lcdinit(); 仿真结果如下: ![图片说明](https://img-ask.csdn.net/upload/201504/06/1428309208_679265.png) 在单片机上试结果一样没有。
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
Linux(服务器编程):15---两种高效的事件处理模式(reactor模式、proactor模式)
前言 同步I/O模型通常用于实现Reactor模式 异步I/O模型则用于实现Proactor模式 最后我们会使用同步I/O方式模拟出Proactor模式 一、Reactor模式 Reactor模式特点 它要求主线程(I/O处理单元)只负责监听文件描述符上是否有事件发生,有的话就立即将时间通知工作线程(逻辑单元)。除此之外,主线程不做任何其他实质性的工作 读写数据,接受新的连接,以及处...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
五年程序员记流水账式的自白。
不知觉已中码龄已突破五年,一路走来从起初铁憨憨到现在的十九线程序员,一路成长,虽然不能成为高工,但是也能挡下一面,从15年很火的android开始入坑,走过java、.Net、QT,目前仍处于android和.net交替开发中。 毕业到现在一共就职过两家公司,目前是第二家,公司算是半个创业公司,所以基本上都会身兼多职。比如不光要写代码,还要写软著、软著评测、线上线下客户对接需求收集...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
一文详尽系列之模型评估指标
点击上方“Datawhale”,选择“星标”公众号第一时间获取价值内容在机器学习领域通常会根据实际的业务场景拟定相应的不同的业务指标,针对不同机器学习问题如回归、分类、排...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
压测学习总结(1)——高并发性能指标:QPS、TPS、RT、吞吐量详解
一、QPS,每秒查询 QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。 二、TPS,每秒事务 TPS:是TransactionsPerSecond的缩写,也就是事务数/秒。它是软件测试结果的测量单位。一个事务是指一...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
程序员该看的几部电影
1、骇客帝国(1999) 概念:在线/离线,递归,循环,矩阵等 剧情简介: 不久的将来,网络黑客尼奥对这个看似正常的现实世界产生了怀疑。 他结识了黑客崔妮蒂,并见到了黑客组织的首领墨菲斯。 墨菲斯告诉他,现实世界其实是由一个名叫“母体”的计算机人工智能系统控制,人们就像他们饲养的动物,没有自由和思想,而尼奥就是能够拯救人类的救世主。 可是,救赎之路从来都不会一帆风顺,到底哪里才是真实的世界?如何...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
还记得那个提速8倍的IDEA插件吗?VS Code版本也发布啦!!
去年,阿里云发布了本地 IDE 插件 Cloud Toolkit,仅 IntelliJ IDEA 一个平台,就有 15 万以上的开发者进行了下载,体验了一键部署带来的开发便利。时隔一年的今天,阿里云正式发布了 Visual Studio Code 版本,全面覆盖前端开发者,帮助前端实现一键打包部署,让开发提速 8 倍。 VSCode 版本的插件,目前能做到什么? 安装插件之后,开发者可以立即体验...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
2019年除夕夜的有感而发
天气:小雨(加小雪) 温度:3摄氏度 空气:严重污染(399) 风向:北风 风力:微风 现在是除夕夜晚上十点钟,再有两个小时就要新的一年了; 首先要说的是我没患病,至少现在是没有患病;但是心情确像患了病一样沉重; 现在这个时刻应该大部分家庭都在看春晚吧,或许一家人团团圆圆的坐在一起,或许因为某些特殊原因而不能团圆;但不管是身在何处,身处什么境地,我都想对每一个人说一句:新年快乐! 不知道csdn这...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
2020年的1月,我辞掉了我的第一份工作
其实,这篇文章,我应该早点写的,毕竟现在已经2月份了。不过一些其它原因,或者是我的惰性、还有一些迷茫的念头,让自己迟迟没有试着写一点东西,记录下,或者说是总结下自己前3年的工作上的经历、学习的过程。 我自己知道的,在写自己的博客方面,我的文笔很一般,非技术类的文章不想去写;另外我又是一个还比较热衷于技术的人,而平常复杂一点的东西,如果想写文章写的清楚点,是需要足够...
别低估自己的直觉,也别高估自己的智商
所有群全部吵翻天,朋友圈全部沦陷,公众号疯狂转发。这两周没怎么发原创,只发新闻,可能有人注意到了。我不是懒,是文章写了却没发,因为大家的关注力始终在这次的疫情上面,发了也没人看。当然,我...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
节后首个工作日,企业们集体开晨会让钉钉挂了
By 超神经场景描述:昨天 2 月 3 日,是大部分城市号召远程工作的第一天,全国有接近 2 亿人在家开始远程办公,钉钉上也有超过 1000 万家企业活跃起来。关键词:十一出行 人脸...
Java基础知识点梳理
虽然已经在实际工作中经常与java打交道,但是一直没系统地对java这门语言进行梳理和总结,掌握的知识也比较零散。恰好利用这段时间重新认识下java,并对一些常见的语法和知识点做个总结与回顾,一方面为了加深印象,方便后面查阅,一方面为了掌握好Android打下基础。
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
相关热词 c# 为空 判断 委托 c#记事本颜色 c# 系统默认声音 js中调用c#方法参数 c#引入dll文件报错 c#根据名称实例化 c#从邮件服务器获取邮件 c# 保存文件夹 c#代码打包引用 c# 压缩效率
立即提问