24.08.13

day11

1.函数

	函数是具有特定功能的代码块。
        
        
        
函数的一般形式:
        数据类型  函数名(形参列表)
    {
        代码块;
            
        return ?;     
    }


    int  Add(int x, int y)
    {
        return x + y;
    }


函数的调用:
    函数名(实参列表)Add(x, y);


函数的声明:
    int  Add(int x, int y);
    函数在声明的时候形参变量名可以不同,也可以不写。

练习

1.实现减法函数的封装
int Sub(int x, int y)
{
     return x - y;
}
2.设计一个交换函数
 int  swap(int *x, int *y)
 {
     int temp;
     temp = *x;
     *x = *y
     *y = temp;    
 }



 int a = 10, b = 20;
 printf("a:%d b:%d", a, b);
 swap();
 printf("a:%d b:%d", a, b);
	



int swap(int **x, int **y)
{
    int *temp;
    //printf("x:%p y:%p\n", x, y);
    temp = *x;
    *x = *y;
    *y = temp;
    //printf("x:%p y:%p\n", x, y);

    return 0;
}



int main(int argc, char *argv[])
{
    int a = 10, b = 20;
    int *p = &a, *q = &b;
    printf("p:%p q:%p\n", p, q);
    swap(&p, &q);
    printf("p:%p q:%p\n", p, q);

    return 0;
}

函数的传参

1.复制传递

   复制传递方式是函数间传递数据常用的方式。调用函数将实参传递给被调用函数,被调用函数将创建同类型的形参并用实参初始化。即把实参赋给一个新的变量,把实参复制到新建形参的存储区域中。采用复制传递方式传递数据,即使改变形参的值也不会影响实参的值,一旦被调用函数完成了其任务时,这些形参通常就释放其占用空间 。
2.地址传递方式
	地址传递方式和复制传递方式正好相反,这种方式是将调用函数的参数本身传给被调用函数。因此,被调用函数中对形参的操作,将直接改变实参的值。调用函数将实参的地址传送给被调用函数,被调用函数对该地址的目标操作,相当于对实参本身的操作。按地址传递,实参为变量的地址,而形参为同类型的指针。
1.传一位数组
	传的是一维数组的首地址。
        
int func(int a[5]);

int func(int a[]);

int func(int *p);  


eg:
    int arr_show(int *p, int n)
{

    int i;
    for(i = 0; i < n; i++)
    {   
        printf("%d\t", p[i]);
    }   
    puts("");

    return 0;
}


int main(int argc, char *argv[])
{ 
    int a[5] = {1,2,3,4,5};
    int b[10] = {1,2,3,4,5,6,7,8,9,10};

    arr_show(a, sizeof(a) / sizeof(a[0]));
    arr_show(b,sizeof(b) / sizeof(int) );

    return 0;
} 

练习
1.实现封装整型一维数组的排序函数

srand(time(NULL));  //随机数发生器
int ret = rand() %  20          //产生随机数 用ret变量接收, 并控制范围为 0 ~ 19


    
int arr_init(int *p, int n)
{
    srand(time(NULL));
    int i;
    for(i = 0; i < n; i++)
    {   
        p[i] = rand() % 21; 
    }   
}



int arr_show(int *p, int n)
{

    int i;
    for(i = 0; i < n; i++)
    {   
        printf("%d\t", p[i]);
    }   
    puts("");

    return 0;
}


int arr_sort(int *p, int n)
{
    int i, j;
    for(i = 0; i < n -1; i++)
    {   
        for(j = 0; j < n - i - 1; j++)
        {
            if(p[j] > p[j+1])
            {
                int temp;
                temp = p[j];
                p[j] = p[j + 1]; 
                p[j + 1] = temp;
            }
        }
    }   
}


int main(int argc, char *argv[])
{ 
    int a[5] = {1,2,3,4,5};
    int b[10] = {1,2,3,4,5,6,7,8,9,10};

    arr_init(b, 10);
    arr_show(b, 10);
    arr_sort(b, 10);
    arr_show(b, 10);

    
    //arr_show(b,sizeof(b) / sizeof(int) );

    return 0;
} 
    
2.传二维数组
	传的是行地址。
        
int arr_show(int a[3][4]int h, int l); 

int arr_show(int a[][4]int h, int l);  

int arr_show(int (*p)[4]int h, int l);  



    传一级指针
int  arr_show(int *p, int n);   
3.全局变量传参
在函数里,如果全局变量和局部变量名字相同,会优先使用局部变量
         全局变量和局部变量名字不相同,或没有变量的定义,使用全局变量。
    
    
int a = 10; 

void func1(int a)
{
    a = 20; 
}

void func2()
{
    a = 100;
}

int main(int argc, char *argv[])
{ 
    printf("%d\n", a); 
    func1(1314);
    printf("%d\n", a); 
    func2();
    printf("%d\n", a); 

    return 0;
} 

1.const 关键字

1.修饰变量
    const int a = 10//a 变量的值不可以被修改 
    a = 30//error
    
    int *p = &a;
    *p = 202.修饰指针
    
    指针常量(指针是一个常量)
    	指针的指向不能被修改,指针指向的内容可以修改
    	 int * const p;
    
    
    
    常量指针(常量的指针)
        指针的指向能被修改,指针指向的内容不可以修改
       
        const int *p;
        int const *p;



    const  int  * const  p;
练习
1.封装一个mystrlen
int MyStrlen(const char *str)
{
    int len = 0;

    while(*str != '\0')
    {
        str++;
        len++;
    }

    return len;
}


int main(int argc, char *argv[])
{
    char str[32] = {0};

    printf(":>");
    gets(str);

    printf("%ld  %d\n", strlen(str), mystrlen(str));

    retur

2.指针函数

	是一个函数。返回为指针的函数。

注意:
    1.不能返回局部变量的地址  
    2.可以返回static 修饰的局部变量的地址    
练习
1.实现mystrcpy
har *mystrcpy(char *dest, const char *src)
{
    char *ret = dest;

    while(*src)
    {
        *dest++ = *src++;
    }
    *dest = '\0';

    return ret;
}



int main(int argc, char *argv[])
{

    char str1[32] = "123456789";
    char str2[32] = "xxxxxx";


    puts(mystrcpy(str1, str2));


    return 0;
}
  • 12
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个基本的nrf24l01.c和nrf24l01.h文件的程序示例,仅供参考: nrf24l01.h 文件: ```c #ifndef __NRF24L01_H #define __NRF24L01_H #include "stm32f10x.h" //定义NRF24L01的寄存器地址 #define NRF24L01_CONFIG 0x00 #define NRF24L01_EN_AA 0x01 #define NRF24L01_EN_RXADDR 0x02 #define NRF24L01_SETUP_AW 0x03 #define NRF24L01_SETUP_RETR 0x04 #define NRF24L01_RF_CH 0x05 #define NRF24L01_RF_SETUP 0x06 #define NRF24L01_STATUS 0x07 #define NRF24L01_OBSERVE_TX 0x08 #define NRF24L01_CD 0x09 #define NRF24L01_RX_ADDR_P0 0x0A #define NRF24L01_RX_ADDR_P1 0x0B #define NRF24L01_RX_ADDR_P2 0x0C #define NRF24L01_RX_ADDR_P3 0x0D #define NRF24L01_RX_ADDR_P4 0x0E #define NRF24L01_RX_ADDR_P5 0x0F #define NRF24L01_TX_ADDR 0x10 #define NRF24L01_RX_PW_P0 0x11 #define NRF24L01_RX_PW_P1 0x12 #define NRF24L01_RX_PW_P2 0x13 #define NRF24L01_RX_PW_P3 0x14 #define NRF24L01_RX_PW_P4 0x15 #define NRF24L01_RX_PW_P5 0x16 #define NRF24L01_FIFO_STATUS 0x17 #define NRF24L01_DYNPD 0x1C #define NRF24L01_FEATURE 0x1D //定义NRF24L01指令 #define NRF24L01_R_REGISTER 0x00 #define NRF24L01_W_REGISTER 0x20 #define NRF24L01_R_RX_PAYLOAD 0x61 #define NRF24L01_W_TX_PAYLOAD 0xA0 #define NRF24L01_FLUSH_TX 0xE1 #define NRF24L01_FLUSH_RX 0xE2 #define NRF24L01_REUSE_TX_PL 0xE3 #define NRF24L01_NOP 0xFF //定义NRF24L01寄存器位 #define NRF24L01_CONFIG_MASK_RX_DR 0x40 #define NRF24L01_CONFIG_MASK_TX_DS 0x20 #define NRF24L01_CONFIG_MASK_MAX_RT 0x10 #define NRF24L01_CONFIG_EN_CRC 0x08 #define NRF24L01_CONFIG_CRCO 0x04 #define NRF24L01_CONFIG_PWR_UP 0x02 #define NRF24L01_CONFIG_PRIM_RX 0x01 #define NRF24L01_STATUS_RX_DR 0x40 #define NRF24L01_STATUS_TX_DS 0x20 #define NRF24L01_STATUS_MAX_RT 0x10 #define NRF24L01_STATUS_TX_FULL 0x01 #define NRF24L01_RF_SETUP_CONT_WAVE 0x80 #define NRF24L01_RF_SETUP_RF_DR_LOW 0x20 #define NRF24L01_RF_SETUP_PLL_LOCK 0x10 #define NRF24L01_LNA_HCURR 0x01 #define NRF24L01_RX_PW_PX_DEFAULT 0x00 #define NRF24L01_SPI_TIMEOUT 100 //定义NRF24L01模块的IO口 #define NRF24L01_CE_PORT GPIOB #define NRF24L01_CE_PIN GPIO_Pin_0 #define NRF24L01_CSN_PORT GPIOB #define NRF24L01_CSN_PIN GPIO_Pin_1 #define NRF24L01_IRQ_PORT GPIOB #define NRF24L01_IRQ_PIN GPIO_Pin_5 void NRF24L01_GPIO_Init(void); void NRF24L01_SPI_Init(void); void NRF24L01_Init(void); void NRF24L01_CE(uint8_t level); void NRF24L01_CSN(uint8_t level); uint8_t NRF24L01_ReadWriteByte(uint8_t txData); uint8_t NRF24L01_ReadReg(uint8_t regAddr); void NRF24L01_WriteReg(uint8_t regAddr, uint8_t txData); void NRF24L01_ReadBuf(uint8_t regAddr, uint8_t *pBuf, uint8_t len); void NRF24L01_WriteBuf(uint8_t regAddr, uint8_t *pBuf, uint8_t len); void NRF24L01_SetupRxMode(void); void NRF24L01_SetupTxMode(void); void NRF24L01_TxPacket(uint8_t *txBuf, uint8_t len); uint8_t NRF24L01_RxPacket(uint8_t *rxBuf); #endif ``` nrf24l01.c 文件: ```c #include "nrf24l01.h" static uint8_t NRF24L01_SPI_SendByte(uint8_t txData) { uint8_t retry = NRF24L01_SPI_TIMEOUT; while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET) { if (--retry == 0) { return 0; } } SPI_I2S_SendData(SPI1, txData); retry = NRF24L01_SPI_TIMEOUT; while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET) { if (--retry == 0) { return 0; } } return SPI_I2S_ReceiveData(SPI1); } void NRF24L01_GPIO_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE); GPIO_InitStructure.GPIO_Pin = NRF24L01_CE_PIN; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(NRF24L01_CE_PORT, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = NRF24L01_CSN_PIN; GPIO_Init(NRF24L01_CSN_PORT, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = NRF24L01_IRQ_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; GPIO_Init(NRF24L01_IRQ_PORT, &GPIO_InitStructure); } void NRF24L01_SPI_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; SPI_InitTypeDef SPI_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_SPI1, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(GPIOA, &GPIO_InitStructure); SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex; SPI_InitStructure.SPI_Mode = SPI_Mode_Master; SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b; SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low; SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge; SPI_InitStructure.SPI_NSS = SPI_NSS_Soft; SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_2; SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB; SPI_InitStructure.SPI_CRCPolynomial = 7; SPI_Init(SPI1, &SPI_InitStructure); SPI_Cmd(SPI1, ENABLE); } void NRF24L01_Init(void) { NRF24L01_GPIO_Init(); NRF24L01_SPI_Init(); NRF24L01_CE(0); NRF24L01_CSN(1); } void NRF24L01_CE(uint8_t level) { if (level) { GPIO_SetBits(NRF24L01_CE_PORT, NRF24L01_CE_PIN); } else { GPIO_ResetBits(NRF24L01_CE_PORT, NRF24L01_CE_PIN); } } void NRF24L01_CSN(uint8_t level) { if (level) { GPIO_SetBits(NRF24L01_CSN_PORT, NRF24L01_CSN_PIN); } else { GPIO_ResetBits(NRF24L01_CSN_PORT, NRF24L01_CSN_PIN); } } uint8_t NRF24L01_ReadWriteByte(uint8_t txData) { NRF24L01_CSN(0); uint8_t rxData = NRF24L01_SPI_SendByte(txData); NRF24L01_CSN(1); return rxData; } uint8_t NRF24L01_ReadReg(uint8_t regAddr) { NRF24L01_CSN(0); NRF24L01_SPI_SendByte(NRF24L01_R_REGISTER | regAddr); uint8_t regValue = NRF24L01_SPI_SendByte(NRF24L01_NOP); NRF24L01_CSN(1); return regValue; } void NRF24L01_WriteReg(uint8_t regAddr, uint8_t txData) { NRF24L01_CSN(0); NRF24L01_SPI_SendByte(NRF24L01_W_REGISTER | regAddr); NRF24L01_SPI_SendByte(txData); NRF24L01_CSN(1); } void NRF24L01_ReadBuf(uint8_t regAddr, uint8_t *pBuf, uint8_t len) { NRF24L01_CSN(0); NRF24L01_SPI_SendByte(NRF24L01_R_REGISTER | regAddr); for (uint8_t i = 0; i < len; i++) { pBuf[i] = NRF24L01_SPI_SendByte(NRF24L01_NOP); } NRF24L01_CSN(1); } void NRF24L01_WriteBuf(uint8_t regAddr, uint8_t *pBuf, uint8_t len) { NRF24L01_CSN(0); NRF24L01_SPI_SendByte(NRF24L01_W_REGISTER | regAddr); for (uint8_t i = 0; i < len; i++) { NRF24L01_SPI_SendByte(pBuf[i]); } NRF24L01_CSN(1); } void NRF24L01_SetupRxMode(void) { NRF24L01_CE(0); NRF24L01_WriteReg(NRF24L01_CONFIG, NRF24L01_CONFIG_EN_CRC | NRF24L01_CONFIG_CRCO | NRF24L01_CONFIG_PWR_UP | NRF24L01_CONFIG_PRIM_RX); NRF24L01_WriteReg(NRF24L01_EN_AA, 0x01); NRF24L01_WriteReg(NRF24L01_EN_RXADDR, 0x01); NRF24L01_WriteReg(NRF24L01_SETUP_RETR, 0x5F); NRF24L01_WriteReg(NRF24L01_RF_CH, 0x02); NRF24L01_WriteReg(NRF24L01_RF_SETUP, NRF24L01_RF_SETUP_RF_DR_LOW | NRF24L01_RF_SETUP_CONT_WAVE | NRF24L01_RF_SETUP_PLL_LOCK); NRF24L01_WriteReg(NRF24L01_RX_PW_P0, 0x20); NRF24L01_WriteReg(NRF24L01_FEATURE, 0x06); NRF24L01_CE(1); } void NRF24L01_SetupTxMode(void) { NRF24L01_CE(0); NRF24L01_WriteReg(NRF24L01_CONFIG, NRF24L01_CONFIG_EN_CRC | NRF24L01_CONFIG_CRCO | NRF24L01_CONFIG_PWR_UP | !NRF24L01_CONFIG_PRIM_RX); NRF24L01_WriteReg(NRF24L01_EN_AA, 0x01); NRF24L01_WriteReg(NRF24L01_EN_RXADDR, 0x01); NRF24L01_WriteReg(NRF24L01_SETUP_RETR, 0x5F); NRF24L01_WriteReg(NRF24L01_RF_CH, 0x02); NRF24L01_WriteReg(NRF24L01_RF_SETUP, NRF24L01_RF_SETUP_RF_DR_LOW | NRF24L01_RF_SETUP_CONT_WAVE | NRF24L01_RF_SETUP_PLL_LOCK); NRF24L01_WriteReg(NRF24L01_RX_PW_P0, 0x20); NRF24L01_WriteReg(NRF24L01_FEATURE, 0x06); NRF24L01_CE(1); } void NRF24L01_TxPacket(uint8_t *txBuf, uint8_t len) { NRF24L01_CE(0); NRF24L01_WriteBuf(NRF24L01_W_TX_PAYLOAD, txBuf, len); NRF24L01_CE(1); GPIO_ResetBits(NRF24L01_CE_PORT, NRF24L01_CE_PIN); delay_us(10); NRF24L01_CE(0); } uint8_t NRF24L01_RxPacket(uint8_t *rxBuf) { uint8_t status = NRF24L01_ReadReg(NRF24L01_STATUS); if (status & NRF24L01_STATUS_RX_DR) { NRF24L01_ReadBuf(NRF24L01_R_RX_PAYLOAD, rxBuf, 32); NRF24L01_WriteReg(NRF24L01_STATUS, status | NRF24L01_STATUS_RX_DR); return 1; } return 0; } ``` 这个程序示例是基于STM32F10x的,如果您使用其他单片机,您可能需要根据您的单片机进行适当的修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值