void increase() { //增加学生信息 int m, flag, i = n, j;//n是一开始定义的n=0赋值给i printf("请输入待添加的学生人数:\n"); scanf("%d", &m);//输入整数并赋值给m if (m > 0) {//可输入人数 do {//先执行后判断 flag = 1; while (flag != 0) {//循环一直到flag不等于0 flag = 0; printf("请输入第%d位学生的学号:\n", i + 1);//控制i>j 并且能够进行下一次的循环 getchar(); gets(stu[i].num);//学生数组序号 for (j = 0; j < i; j++) { //i就是n是学生的总数控制j小于50,j不断增加i为人数i与j相等人数重复 if (strcmp(stu[i].num, stu[j].num) == 0) { //用于比较两个字符串根据比较结果两个字符串相等为0 printf("该学号已存在,请重新输入!\n"); flag = 1;//flag等于1满足初始跳出循环 break; } } } printf("请输入第%d位学生姓名:\n", i + 1); gets(stu[i].name); printf("请输入第%d位学生性别:\n", i + 1); gets(stu[i].sex); printf("请输入第%d位学生年龄:\n", i + 1); scanf("%d", &stu[i].age); printf("请输入第%d位学生籍贯:\n", i + 1); scanf("%s", &stu[i].baera); printf("请输入第%d位学生系别:\n", i + 1); scanf("%s", &stu[i].department); printf("请输入第%d位学生专业:\n", i + 1); scanf("%s", &stu[i].major); printf("请输入第%d位学生班级:\n", i + 1); scanf("%s", stu[i].Class); i++; } w
时间: 2023-06-13 11:08:41 浏览: 155
hile (--m > 0); //如果还有剩余的待添加学生,继续执行循环 n = i; //将添加学生后的总人数赋值给n,便于后续操作。} else {//不可输入人数 printf("输入有误,请重新输入!\n"); }}
这是一个用于增加学生信息的函数,通过输入待添加的学生人数,然后逐一输入学生信息,包括学号、姓名、性别、年龄、籍贯、系别、专业、班级等信息。在输入学号时,通过对已有学号进行比较,确保输入的学号唯一。最后将添加学生后的总人数赋值给n,以便于后续操作。
相关问题
优化这段代码//按键控制舵机 #include <msp430.h> #define CPU_F ((double)1000000) #define delay_us(x) __delay_cycles((long)(CPU_F*(double)x/1000000.0))//重新定义延时函数 #define delay_ms(x) __delay_cycles((long)(CPU_F*(double)x/1000.0)) void TimeA0__PWM_Init(void) { P1SEL |= BIT3; //IO口复用 P1DIR |= BIT3; TA0CTL = TASSEL__SMCLK + MC_3; //SMCLK,增减模式,计数到CCR0处 TA0CCR0 = 10000 - 1; // PWM周期为20ms,对应时钟频率为1MHz TA0CCR2 = 250; //将占空比设置为50% (TACCR0 - TACCR2) / TACCR0 = (20000 - 10000) / 20000 = 0.5 TA0CCTL2 = OUTMOD_6; //选择比较模式,模式6:Toggle/set } void set_servo_angle(float angle) { if (angle < 0.0f) { angle = 0.0f; // 最小角度限制 //非常好,12个是90度 } // else if (angle > 360.0f) // { // angle = 359.0f; // 最大角度限制 // } unsigned int position = (angle / 360.0f) * (1250 - 250) + 250; TA0CCR2 = position; // 设置脉冲宽度,对应舵机位置 __delay_cycles(10000); // 延时等待舵机调整到目标位置 } int main(void) { WDTCTL = WDTPW | WDTHOLD; // stop watchdog timer TimeA0__PWM_Init(); P2DIR &= ~BIT1; // 设置P2.1为输入 P2REN |= BIT1; // 启用P2.1的上拉电阻 P2OUT |= BIT1; // 将P2.1的上拉电阻设置为上拉 unsigned int angle = 0; while(1) { set_servo_angle(angle); if ((P1IN & BIT1) == 0) // 检测按键是否按下 { angle += 10; // 每次按键增加10度 // if (angle > 360) // { // angle = 360; // 最大角度限制 // } set_servo_angle(angle); delay_ms(200); // 延时一段时间避免按键反弹 } } }
这段代码是用来按键控制舵机角度的。以下是对代码进行优化的一些建议:
1. 将硬编码的数值定义为常量,以提高代码的可读性。例如,将占空比50%的值定义为一个常量。
2. 使用位操作来设置和清除引脚状态。例如,使用`P1OUT |= BIT3`来设置P1.3引脚为高电平,使用`P1OUT &= ~BIT3`来清除P1.3引脚。
3. 考虑使用中断来检测按键状态,而不是在循环中轮询检测。这样可以减少CPU的负载,提高代码的效率。
4. 考虑使用定时器中断来实现舵机位置调整,而不是使用延时函数。这样可以避免在调整舵机位置时阻塞其他操作。
下面是优化后的代码示例:
```cpp
#include <msp430.h>
#define CPU_F ((double)1000000)
#define delay_us(x) __delay_cycles((long)(CPU_F*(double)x/1000000.0))
#define delay_ms(x) __delay_cycles((long)(CPU_F*(double)x/1000.0))
#define PWM_PERIOD 10000
#define PWM_DUTY_CYCLE 5000
#define ANGLE_INCREMENT 10
#define DEBOUNCE_DELAY 200
volatile unsigned int angle = 0;
void TimeA0_PWM_Init(void)
{
P1SEL |= BIT3;
P1DIR |= BIT3;
TA0CTL = TASSEL__SMCLK + MC_3;
TA0CCR0 = PWM_PERIOD - 1;
TA0CCR2 = PWM_DUTY_CYCLE;
TA0CCTL2 = OUTMOD_6;
}
void set_servo_angle(unsigned int angle)
{
if (angle > 360)
{
angle = 360;
}
unsigned int position = (angle / 360.0f) * (1250 - 250) + 250;
TA0CCR2 = position;
delay_us(10000);
}
void init_button_interrupt()
{
P2DIR &= ~BIT1;
P2REN |= BIT1;
P2OUT |= BIT1;
P2IE |= BIT1; // Enable interrupt for P2.1
P2IES |= BIT1; // Set interrupt edge select to falling edge
P2IFG &= ~BIT1; // Clear P2.1 interrupt flag
}
#pragma vector=PORT2_VECTOR
__interrupt void Port_2(void)
{
if ((P2IFG & BIT1) != 0) // Check if P2.1 caused the interrupt
{
angle += ANGLE_INCREMENT; // Increase angle by increment value
set_servo_angle(angle);
delay_ms(DEBOUNCE_DELAY); // Delay to avoid button bounce
P2IFG &= ~BIT1; // Clear P2.1 interrupt flag
}
}
int main(void)
{
WDTCTL = WDTPW | WDTHOLD;
TimeA0_PWM_Init();
init_button_interrupt();
__enable_interrupt();
while (1)
{
// Do other operations here
}
}
```
这个优化后的代码将使用定时器中断来检测按键状态,并使用位操作来设置和清除引脚状态。舵机位置调整也改为使用定时器中断,以避免阻塞其他操作。
void Dealwith_RS232(void) //RS485 is also handled at here { //stc_ring_buf_t *pstcBuffRing_Rcv = &g_stcBuffRing_Remote232_Rcv; _stc_rs232_info *pstcUart; //_stc_rs232_info *pstcRS232 = &g_stcRS232; uint8_t uart; for(uart=0; uart<2; uart++) //COM_RS232, COM_RS485 { if(COM_RS485 == uart) pstcUart = &g_stcRS485; else pstcUart = &g_stcRS232; if (pstcUart->unSend.u64Data)//if (g_stcRS232.unSend.u64Data) { pstcUart->State = STATE_REMOTE_SENDING; //g_stcRS232.State = STATE_REMOTE_SENDING; Dealwith_RS232_Send(uart);//Dealwith_RS232_Send(); } if (STATE_REMOTE_SENDING == pstcUart->State) break; //return; /* buffer ring pop out */ if (!BufferRing_RS232_Popout(uart, pstcUart))//if (!BufferRing_RS232_Popout(pstcBuffRing_Rcv, pstcRS232)) { return; } /* get cmd type and switch to branch */ switch(GetCmd_RS232(pstcUart))//switch(GetCmd_RS232(pstcRS232)) { case CMD_USER_GET_VERSION: RecvFromRS232_User_Get_Version(pstcUart);//RecvFromRS232_User_Get_Version(pstcRS232); break; case CMD_USER_GET_SN: RecvFromRS232_User_Get_SerialNbr(pstcUart);//RecvFromRS232_User_Get_SerialNbr(pstcRS232); break; #ifdef APP_LED case CMD_USER_STANDBY_IN: RecvFromRS232_User_Standby_In(pstcUart); break; case CMD_USER_STANDBY_OUT: RecvFromRS232_User_Standby_Out(pstcUart); break; case CMD_USER_BRIGHTNESS_GET: RecvFromRS232_User_Brightness_Get(pstcUart); break; case CMD_USER_BRIGHTNESS_SET: RecvFromRS232_User_Brightness_Set(pstcUart); break; case CMD_USER_BRIGHTNESS_DECREASE: RecvFromRS232_User_Brightness_Decrease(pstcUart); break; case CMD_USER_BRIGHTNESS_INCREASE: RecvFromRS232_User_Brightness_Increase(pstcUart); break; #endif case CMD_USER_DATE_SET: RecvFromRS232_User_Date_Set(pstcUart); break; case CMD_USER_DATE_GET: RecvFromRS232_User_Date_Get(pstcUart); break; case CMD_USER_TIME_SET: RecvFromRS232_User_Time_Set(pstcUart); break; case CMD_USER_TIME_GET: RecvFromRS232_User_Time_Get(pstcUart); break; case CMD_MFG_TEST: RecvFromRS232_Mfg_Test(pstcUart); break; case CMD_MFG_UPDATE_BOARD: RecvFromRS232_Mfg_Update_Board(pstcUart); break; case CMD_MFG_UPDATE_PANEL: RecvFromRS232_Mfg_Update_Panel(pstcUart); break; case CMD_MFG_EEPROM: RecvFromRS232_Mfg_Eeprom(pstcUart); break; case CMD_MFG_BEEPER: RecvFromRS232_Mfg_Beeper(pstcUart); break; case CMD_MFG_EXIT: RecvFromRS232_Mfg_Exit(pstcUart); break; //kk case CMD_OTA_INIT: RecvFromRS232_OTA_Init(pstcUart); break; default: RecvFromRS232_Invalid_Cmd_Param(pstcUart); break; } g_stcRS232.State = STATE_REMOTE_IDLE; return; } } 怎么让BufferRing_RS232_Popout(uart, pstcUart)时,要等到uart=1时,才能return
要实现这个功能,可以在for循环外面加一个变量flag,在for循环里面进行判断,如果uart等于1并且BufferRing_RS232_Popout返回false,就让flag等于1。然后在for循环结束后,再加一个判断,如果flag等于1,就return。代码示例:
```
void Dealwith_RS232(void)
{
_stc_rs232_info *pstcUart;
uint8_t uart;
int flag = 0; // 新增变量flag
for(uart=0; uart<2; uart++)
{
if(COM_RS485 == uart)
pstcUart = &g_stcRS485;
else
pstcUart = &g_stcRS232;
if (pstcUart->unSend.u64Data)
{
pstcUart->State = STATE_REMOTE_SENDING;
Dealwith_RS232_Send(uart);
}
if (STATE_REMOTE_SENDING == pstcUart->State)
break;
if (!BufferRing_RS232_Popout(uart, pstcUart))
{
if (uart == 1) // 判断是否是最后一个uart
flag = 1; // 如果是最后一个uart并且BufferRing_RS232_Popout返回false,flag等于1
continue;
}
switch(GetCmd_RS232(pstcUart))
{
// ...
}
g_stcRS232.State = STATE_REMOTE_IDLE;
if (uart == 1 && flag == 1) // 判断是否是最后一个uart并且flag等于1
return;
}
}
```
阅读全文