C语言—控制语句

控制语句就是用来实现对流程的选择、循环、转向和返回等控制行为。

分支语句

if语句

基本结构

if(表达式)

{

        语句块1;

}

else

{

        语句块2;

}

执行顺序: 

如果表达式判断成立(即表达式为真),则执行语句块1;如果表达式判断不成立(即表达式为假),则执行语句块2。

例如:

如果下雨就打印 “with umbrella” ,如果不下雨就打印 “no umbrella” 。

#include <stdio.h>
#include <stdlib.h>

#define RAIN 0

int main(int argc,char const * argv[])
{
    if(RAIN)
    printf("with umbrella\n");
    else
    printf("no nmbrella\n");
    return 0;
}

输入a和b两个整数,实现用较大的数减较小的数。

int a,b;
scanf("%d%d",&a,&b);
if(a>b)
    printf("%d\n",a-b);
else
    printf("%d\n",b-a);

以下程序的运行结果是(B

int main()
{
    unsigned int a;
    int b=-1;
    a=b;
    printf("%u",a);
    return 0;
}

A. -1        B. 65535        C. 32767        D. -32768

解析:

有符号数转换为无符号数就是该数的补码,即有符号数为正数时,转换为无符号数就是他本身;为负数时,转换为无符号数就是他的补码。

拓展:

同样字长的无符号数和有符号数之间相互转换的一般规则是:数值可能会变,但是位模式不变,如果转换的无符号数太大以至于超过了补码能够表示的范围,可能会得到该范围的最大值。

设有定义语句:

        char c1=92,c2=92;

则以下表达式中值为零的是(A

A. c1^c2        B. c1&c2        C. ~c2        D. c1|c2

如果a=1,b=2,则a | b的值为(D

A. 0        B. 1        C. 2        D. 3

实现大小写字符转换

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const * argv[])
{
    char c=getchar();
    if(c>'A'&&c<'Z')
        ch+=32;
    else if(c>'a'&&c<'z')
        ch-=32;
    else
    {
        printf("input error\n");
        return ;
    }
    putchar(c);
    putchar(10);
    return 0;
}

结合宏定义和三目运算实现求两个数的差

解析:在宏定义中定义了变量,在函数中不能出现同名变量

#include <stdio.h>
#include <stdlib.h>

/*三目运算结合宏*/
#define M 20
#define N 10
#define DIFF M>N?M-N:N-M

/*三目运算结合宏函数*/
#define DIFF_FUN(a,b) a>b?a-b:b-a

int main(int argc,char const *argv[])
{
    printf("%d\n",DIFF);
    printf("%d\n",DIFF_FUN(M,N));    //调用宏函数:M>N?M-N:N-M
    return 0;
}

分层结构

if(表达式1)

{

        语句块1;

}

else if(表达式2)

{

        语句块2;

}

else

{

        语句块3;

}

执行顺序:

先判断if后面的表达式1是否成立,如果成立(即结果为真)则执行语句块1,如果结果为假则继续判断else if里面的表达式2,如果表达式2成立则执行语句块2,如果结果为假,则执行else里面的语句块3。

例如:

判断两个数的大小关系。

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const * argv[])
{
    int a,b;
    scanf("%d %d",&a,&b);
    if(a>b)
        printf("a>b\n");
    else if(a<b)
        printf("a<b\n");
    else
        printf("a=b\n");
    return 0;
}

从终端输入一个学生的成绩,来判断学生成绩的等级并打印出来,等级评判如下:

90-100为A;80-89为B;70-79为C;60-69为D;60分以下为不及格(打印sorry,you fail )

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const * argv[])
{
    int score;
    scanf("%d",&score);
    if(score<=100&&score>=90)
        printf("A\n");
    else if(score>=80&&score<=89)
        printf("B\n");
    else if(score>=70&&score<=79)
        printf("C\n");
    else if(score>=60&&score<=69)
        printf("D\n");
    else if(score<=59)
        printf("sorry,you fail\n");
    else
        printf("input error\n");
    return 0;
}

嵌套结构

if(表达式1)

{

        if(表达式2)

        {

                语句块1;

        }

        else

        {

                语句块2;

        }

}

else

{

        语句块3;

}

执行顺序:

先判断if后面的表达式1,如果结果为真则判断嵌套的if后面的表达式2,如果表达式2结果为真 则执行语句块1,如果结果为假则执行语句块2,如果表达式1结果为假则执行语句块3。

从终端输入一个学生的成绩,来判断学生成绩的等级并打印出来,如果输入的不是int型数据则打印 “input error” ,等级评判如下:

90-100为A;80-89为B;70-79为C;60-69为D;60分以下为不及格(打印sorry,you fail )

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const * argv[])
{
    int score;
    scanf("%d",&score);
    if(score>=0&&score<=100)
    {
        if(score<=100&&score>=90)
            printf("A\n");
        else if(score>=80&&score<=89)
            printf("B\n");
        else if(score>=70&&score<=79)
            printf("C\n");
        else if(score>=60&&score<=69)
            printf("D\n");
        else if(score<=59)
            printf("sorry,you fail\n");
    }
    else
        printf("input error\n");
    return 0;
}

输入一个int类型的数据,如果大于0则打印大于0,并且再判断是否大于等于10,如果大于等于10则打印大于等于10,小于10则打印小于10,如果数据小于0则不打印任何东西。

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const * argv[])
{
    int num=0;
    scanf("%d",&num);
    if(num>=0)
    {
        printf("num>=0\n");
        if(num>=10)
        {
            printf("num>=10");
        }
        else
            printf("num<10\n");
    }
    return 0;
}

总结:

  1. 首先需要判断表达式是否成立 ,如果成立就执行if里面的语句块,否则执行else里面的语句块;
  2. if后面可以没有else,但是else前面必须有if,并且else必须紧跟着if后面,中间不能加任何语句;
  3. if和else下面语句块中如果只有一行语句则可以省略花括号。

switch…case语句

基本结构

switch(变量或表达式

{

        case 常量1:

                语句块1;

                break;

        case 常量2:

                语句块2;

                break;

        ……

        default:

                语句块n+1;

}

 执行顺序:

当switch后面括号中的变量或表达式与下面其中一个case后面的常量相符时,就执行相应case语句后面的语句块,并依次执行后面的case,直到遇到break语句跳出switch语句。如果变量或表达式与所有的case后面的常量都不相等,则执行default后面的语句块。

注意:

  1. switch后面的表达式不能是浮点型数据或字符串;
  2. case后面的break可以省略,但是省略后会从相符的case开始顺序执行,直到遇到break结束。

从终端输入一个学生的成绩,然后打印出来对应成绩的等级,要求用到switch…case结构编写,等级评判如下:

90-100为A;80-89为B;70-79为C;60-69为D;60分以下为不及格(打印sorry,you fail )

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char char const * argv[])
{
    int score;
    scanf("%d",&score);
    switch(score/10)
    {
        case 10:
        case 9:
            printf("A\n");break;
        case 8:
            printf("B\n");break;
        case 7:
            printf("C\n");break;
        case 6:
            printf("A\n");break;
        default:
            printf("sorry,you fail\n");break;
    }
    return 0;
}

从终端输入一个日期(年、月、日),判断这是这一年的第几天。

解析:

首先要先判断是闰年还是平年,闰年的二月份比平年的二月份多一天。普通年份除以4,有余数的是平年,没有余数的是闰年,对于整百的年份,要除以400,有余数的是平年,没有余数的是闰年。

方法一:

#include <stdio.h>
#include <stdlib.h>

int main(int argc, char const *argv[])
{
    int year, month, day, days = 0, leap = 0;
    scanf("%d %d %d", &year, &month, &day);
    if (year % 100 == 0)
    {
        if (year % 400 == 0)
            leap = 1;
        else
            leap = 0;
    }
    else
    {
        if (year % 4 == 0)
            leap = 1;
        else
            leap = 0;
    }
    switch (month)
    {
    case 1:
        days = day;
        break;
    case 2:
        days = 31 + day;
        break;
    case 3:
        days = 31 + 28 + leap + day;
        break;
    case 4:
        days = 31 + 28 + leap + 31 + day;
        break;
    case 5:
        days = 31 + 28 + leap + 31 + 30 + day;
        break;
    case 6:
        days = 31 + 28 + leap + 31 + 30 + 31 + day;
        break;
    case 7:
        days = 31 + 28 + leap + 31 + 30 + 31 + 30 + day;
        break;
    case 8:
        days = 31 + 28 + leap + 31 + 30 + 31 + 30 + 31 + day;
        break;
    case 9:
        days = 31 + 28 + leap + 31 + 30 + 31 + 30 + 31 + 31 + day;
        break;
    case 10:
        days = 31 + 28 + leap + 31 + 30 + 31 + 30 + 31 + 31 + 30 + day;
        break;
    case 11:
        days = 31 + 28 + leap + 31 + 30 + 31 + 30 + 31 + 31 + 30 + 31 + day;
        break;
    case 12:
        days = 31 + 28 + leap + 31 + 30 + 31 + 30 + 31 + 31 + 30 + 31 + 30 + day;
        break;
    default:
        printf("month err\n");
        break;
    }
    printf("%d\n",days);
    return 0;
}

方法二:

#include <stdio.h>
#include <stdlib.h>

int main()
{
	int year = 0, month = 0, day = 0, days = 0, leap = 1;
	scanf("%d %d %d", &year, &month, &day);
	leap = (year % 4 == 0 && year % 100 != 0 || year % 400 == 0);
	switch (month)
	{
	case 12:
		days += 30;
	case 11:
		days += 31;
	case 10:
		days += 30;
	case 9:
		days += 31;
	case 8:
		days += 31;
	case 7:
		days += 30;
	case 6:
		days += 31;
	case 5:
		days += 30;
	case 4:
		days += 31;
	case 3:
		days += 28 + leap;
	case 2:
		days += 31;
	case 1:
		days += day;
		break;
	default:
		printf("error!\n");
		break;
	}
	printf("%04d-%02d-%02d:这一年的第%d天\n", year, month, day, days);
    return 0;
}

总结:

  1. 执行顺序:先判断switch()括号中的条件是否满足switch语句块里的case,如果满足哪个case则执行那个case里面的语句块,如果不满足则执行default中的默认语句块,并且如果case后面没有break会依次向下执行,直到遇到break后结束。
  2. 如果case后面的语句块和上一个case中的语句块相同,那么可以省略,形式如下:

case 常量1:

case 常量2:

        语句块1;

        break;

switch…case语句要遵循的规则:

  1. 只能针对基本数据类型的整型数据或字符型数据,如果要判断的条件是其他类型必须用if;
  2. case后面的标签必须是常量;
  3. case后面的标签必须是唯一表达式,不能有两个重复的case。

循环语句

for循环

基本结构

for(表达式1;表达式2;表达式3)

{

        语句块;

}

说明:

表达式1:赋初值

表达式2:循环判断条件

表达式3:增值或减值

执行顺序:

首先执行表达式1进行赋初值,然后判断表达式2是否成立,如果成立就进入循环执行语句块,最后执行表达式3进行增值或者减值,再判断表达式2是否成立,如果成立就再次进入循环,直到判断表达式2不成立的时候退出循环。

例如:

求5的阶乘(5!)

int sum=1;
for(int i=1;i<=5;i++)
    sum*=i;
printf("%d\n",sum);

嵌套结构

for(表达式1;表达式2;表达式3)

{

        for(表达式4;表达式5;表达式6)

        {

                语句块;

        }

}

例如:

用for循环打印99乘法表

1*1=1

1*2=2  2*2=4

1*3=3  2*3=6  3*3=9

1*4=4  2*4=8  3*4=12  4*4=16

1*5=5  2*5=10  3*5=15  4*5=20  5*5=25

1*6=6  2*6=12  3*6=18  4*6=24  5*6=30  6*6=36

1*7=7  2*7=14  3*7=21  4*7=28  5*7=35  6*7=42  7*7=49

1*8=8  2*8=16  3*8=24  4*8=32  5*8=40  6*8=48  7*8=56  8*8=64

1*9=9  2*9=18  3*9=27  4*9=36  5*9=45  6*9=54  7*9=63  8*9=72  9*9=81

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const * argv[])
{
    for(int i=1;i<10;i++)
    {
        for(int j=1;j<=i;j++)
            printf("%d*%d=%d ",j,i,i*j);
        printf("\n");
    }
    return 0;
}

for循环变形 

变形一

表达式1;

for(;表达式2;表达式3)

{

        语句块;

}

变形二

表达式1;

for(;表达式2;)

{

        语句块;

        表达式3;

}

变形三

表达式1;

for(;;)

{

        if(表达式2)

        {

                语句块;

                表达式3;

        }

        else

        {

                break;

        }

}

例题:

打印所有的水仙花数

水仙花数:三位数的百位立方+十位立方+个位立方=原数

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const argv[])
{
    int g,s,b,num;
    for(int i=100;i<1000;i++)    
    {
        g=i%10;
        s=i/10%10;
        b=i/100;
        num=g*g*g+s*s*s+b*b*b;
        if(num==i)
            printf("%d\n",i);
    }
    return 0;
}

从终端输入行数,例如输入5,打印类似于下图的图形。

分析:

下半部分的行数和空格数关系表:

行数 i空格数 = i-1星星数 = 5 - i + 1
105 = 5 - 1 + 1
214 = 5 - 2 + 1
323 = 5 - 3 + 1
432 = 5 - 4 + 1
541 = 5 - 5 + 1

#include <stdio.h>
#include <stdlib.h>

int main(int argv,char const * argc[])
{
    int n;
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=i;j++)
            printf("*");
        printf("\n");
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<i;j++)
            printf(" ");
        for(int k=1;k<=n-1+1;k++)
            printf("*");
        printf("\n");
    }
    return 0;
}

while循环

基本结构

定义循环变量并赋初值;

while(判断条件)

{

        语句块;

        增值或减值语句;

}

执行顺序:

首先定义循环变量并赋初值,然后判断条件是否满足,如果满足则进入循环体系并进行增值或减值语句,然后再进行判断,如果满足则再次进入循环体系直到不满足条件就退出循环,类似于for循环的第二种变形。

例如:

用while循环求1到100的和

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const * argv[])
{
    int i=1,sum=0;
    while(i<=100)
    {
        sum+=i;
        i++;
    }
    printf("%d\n",sum);
    return 0;
}

do…while循环

基本结构

do

{

        语句块;

        增值或减值语句;

}while(判断条件);

执行顺序:

先执行再判断。

用do…while循环求1到100的和

#include <stdio.h>
#include <stdlib.h>

int main(int argc,char const * argv[])
{
    int i=1,sum=0;
    do
    {
        sum+=i;
        i++;
    }while(i<=100);
    printf("%d\n",sum);
    return 0;
}

上图中左边是do…while循环,右边是while循环

do…while和while的区别:

  1. 执行顺序不同:do…while先执行后判断,while先判断后执行。
  2. 执行次数不同:do…while至少执行一次,但是如果一开始满足判断条件则两者执行次数相同。

死循环

for(;;){}

while(1){}

while(1);

循环控制语句

break

break:直接结束循环,如果是嵌套的话是结束一层循环。

continue

continue:结束本次循环,继续下一次循环。

goto

goto:强制跳转到标签位置,可以用于多层嵌套循环(尽量不要使用goto)。

练习:

打印100-200中所有能被三整除的数

#include <stdio.h>
#include <stdlib.h>

int main(int argc, char const *argv[])
{
	int n;
	for(n=100;n<=200;n++)
	{
		if(n%3!=0) continue;
		printf("%d ",n);
	}
	printf("\n");
	return 0;
}

练习:

从终端上循环输入一个字符并在终端上输出 这个字符,当输入的字符为 ' q ' 时,程序结束。

#include <stdio.h>
#include <stdlib.h>
int main()
{
    char ch;
    while(1)
        {
            scanf("%c",&ch);
            //getchar();
            if(ch=='\n')
                continue;
            if(ch=='q')
                break;
            printf("%c\n",ch);
        }
    return 0;
}

死循环结束场景:

使用在循环语句中,为了结束循环在使用时需要加判断条件。

练习:

循环输入一个5位数,判断是不是回文数,当输入的数是0时循环结束,输入的数是回文数循环也结束。

解析:

        12321是回文数,即个位与万位相同,十位与千位相同。

#include <stdio.h>
#include <stdlib.h>
{
    int n=0,g,s,b,q,w;
    while(1)
    {
        scanf("%d",&n);
        g=n%10;
        s=n/10%10;
        b=n/100%10;
        q=n/1000%10;
        w=n/10000;
        if((g==w&&w!=0)&&q==s||n==0)
        {
            printf("%d\n",n);
            break;
        }
    }
    return 0;
}

输入任意两个数,输出两个数之间(包括这两个数)各偶数之和。

解析:

        从输入的较小的数开始依次加1判断是否为偶数,直到加到较大的数为止,每次都判断当前数是否是偶数,是则累加到sum中。

#include <stdio.h>
#include <stdlib.h>
int main()
{
    int a,b,c,sum=0;
    scanf("%d %d",&a,&b);
    if(a>b)
    {
        c=a;
        a=b;
        b=c
    }
    while(a<=b)
    {
        if(a%2==0)
            sum+=a;
        a++;
    }
    printf("sum=%d\n",sum);
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/595917.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

华为先进芯片麒麟9010效能再升级,挑战新高度 | 百能云芯

根据最新的彭博资讯报道&#xff0c;华为再次引领了智能手机行业的先进技术&#xff0c;其最新发布的Pura 70系列智能手机搭载了由中芯国际生产的麒麟9010高阶处理器。这一消息再次证明了华为在芯片设计和生产领域的持续创新能力&#xff0c;并且表明华为对于提升智能手机性能和…

什么是虚拟货币?

随着科技的进步&#xff0c;虚拟货币逐渐进入公众视野&#xff0c;其影响深远且复杂。本文将从专业角度分析虚拟货币的发展现状、未来趋势&#xff0c;以及面临的挑战&#xff0c;并尝试提出一些思考。 一、虚拟货币的定义与现状 虚拟货币是一种基于区块链技术的数字资产&…

从固定到可变:利用Deformable Attention提升模型能力

1. 引言 本文将深入探讨注意力机制的内部细节&#xff0c;这是了解机器如何选择和处理信息的基础。但这还不是全部&#xff0c;我们还将探讨可变形注意力的创新理念&#xff0c;这是一种将适应性放在首位的动态方法。 闲话少说&#xff0c;我们直接开始吧&#xff01; 2. 注…

Dockerfile创建Docker镜像

Dockerfile DOCKER镜像的组成 Docker 镜像的构建和使用是基于 UnionFS&#xff08;联合文件系统&#xff09;的原理。UnionFS 允许将多个目录挂载到一个虚拟文件系统下&#xff0c;并且可以对这些目录进行修改&#xff0c;这些修改会以一次提交的形式叠加在已有的文件系统层上…

CTF-WEB(MISC)

安全攻防知识——CTF之MISC - 知乎 CTF之MISC杂项从入门到放弃_ctf杂项 你的名字-CSDN博客 CTF MICS笔记总结_archpr 掩码攻击-CSDN博客 一、图片隐写 CTF杂项---文件类型识别、分离、合并、隐写_ctf图片分离-CSDN博客 EXIF&#xff08;Exchangeable Image File&#xff09;是…

笔记本电脑怎么多选删除文件?误删除文件怎么办

在日常使用笔记本电脑中&#xff0c;我们可能会遇到需要删除大量文件的情况&#xff0c;例如清理临时文件、整理文档或卸载不再需要的程序。手动一个一个地删除不仅效率低下&#xff0c;还可能遗漏某些文件。那么&#xff0c;如何在笔记本电脑上高效地进行多选删除操作呢&#…

Case中default的综合结果

在使用case语句时&#xff0c;不完备的case语句会导致Vivado综合时推断出锁存器。下面通过实例来详细看看各种情况下的综合结果&#xff1a; 1.完备的case语句 下述的verilog对应的电路结构是一个8选一的多路复用器&#xff1a; module case_test(input [2:0]sel,input data…

PostgreSQL连接拒绝如何解决和排查?

1. 服务器未运行 解决方案&#xff1a;确保 PostgreSQL 服务已启动。在 Linux 上&#xff0c;你可以使用如下命令来检查服务状态&#xff1a;sudo systemctl status postgresql如果服务未运行&#xff0c;使用以下命令启动它&#xff1a;sudo systemctl start postgresql2. Po…

【软考】模拟考卷错题本2024-05-05

1 算法 关键词&#xff1a;按照单位重量价值大优先&#xff0c;那就是1、2、3即430&#xff1b;之后的根据排除法又可以得到630&#xff1b;故C。 2 UML 序列图 上图已经基本上有解析&#xff1b;重点在于在四个选项中选正确的。根据概念排除&#xff1a;异步和同步是不一样的&…

uniapp的底部弹出层实现保姆式教程

实现照片: 此过程先进入uniapp官网,找到扩展组件 打开找到里面的uni-popup和uni-icons 点击进入,下载&安装 点击下载并导入HBuilderX 导入到你使用的目录,如test目录

高效、精准:皮秒激光切割机在陶瓷基板加工中的应用

皮秒激光切割机&#xff08;激光划片机&#xff09;在陶瓷基板切割领域具有显著的优势和潜力&#xff0c;主要体现在以下几个方面&#xff1a; 1. 高精度&#xff1a;皮秒激光切割机能够实现极高的切割精度&#xff0c;对于陶瓷基板这种需要精细加工的材料尤为重要。它能够在不…

五一 作业

#include <iostream>using namespace std; class Num { private:int a; public:Num() {}Num(int a):a(a){}//设置a的值void set(int a){this->aa;}//1-a的和void Sum(){if(a<1){cout<<"a<1"<<endl;return;}int sum0;for(int i1;i<a;i)…

Excel文件解析---超大Excel文件读写

1.使用POI写入 当我们想在Excel文件中写入100w条数据时&#xff0c;使用XSSFWorkbook进行写入时会发现&#xff0c;只有将100w条数据全部加载到内存后才会用write()方法统一写入&#xff0c;效率很低&#xff0c;所以我们引入了SXXFWorkbook进行超大Excel文件读写。 通过设置 …

图像降噪算法 BM3D 介绍

介绍 BM3D 是 “Block-Matching and 3D Filtering” 的缩写&#xff0c;即三维块匹配滤波&#xff0c;它是一种用于图像去噪的算法。该算法来源于 一篇“Image and video denoising by sparse 3D transform-domain collaborative filtering”的高质量文章&#xff0c;文章的作…

软件测试面试问题汇总

一般软件测试的面试分为三轮&#xff1a;笔试&#xff0c;HR面试&#xff0c;技术面试。 前两轮&#xff0c;根据不同企业&#xff0c;或有或无&#xff0c;但最后一个技术面试是企业了解你“行不行”的关键环节&#xff0c;每个企业都会有的。 在平时的学习、工作中一定要善于…

为什么要学Python?学Python有什么用?

为什么要学Python&#xff1f;学Python有什么用&#xff1f; 在当今的数字化时代&#xff0c;编程已成为一项宝贵的技能。Python&#xff0c;作为一种流行的编程语言&#xff0c;因其易于学习和强大的功能而受到全球开发者的青睐。本文将探讨学习Python的原因和它的实际应用&am…

MLP实现fashion_mnist数据集分类(1)-模型构建、训练、保存与加载(tensorflow)

1、查看tensorflow版本 import tensorflow as tfprint(Tensorflow Version:{}.format(tf.__version__)) print(tf.config.list_physical_devices())2、fashion_mnist数据集下载与展示 (train_image,train_label),(test_image,test_label) tf.keras.datasets.fashion_mnist.l…

如何使git提交的时候忽略一些特殊文件?

认识.gitignore文件 在生成远程仓库的时候我们会看到这样一个选项&#xff1a; 这个.gitignore文件有啥用呢&#xff1f; .gotignore文件是Git版本控制系统中的一个特殊文件。用来指定哪些文件或者目录不被Git追踪或者提交到版本库中。也就意味着&#xff0c;如果我们有一些文…

怎么通过Java语言实现远程控制无人售货柜

怎么通过Java语言实现远程控制无人售货柜呢&#xff1f; 本文描述了使用Java语言调用HTTP接口&#xff0c;实现控制无人售货柜&#xff0c;独立控制售货柜、格子柜的柜门。 可选用产品&#xff1a;可根据实际场景需求&#xff0c;选择对应的规格 序号设备名称厂商1智能WiFi控…

使用 Postman 实现 API 自动化测试

背景介绍 相信大部分开发人员和测试人员对 postman 都十分熟悉&#xff0c;对于开发人员和测试人员而言&#xff0c;使用 postman 来编写和保存测试用例会是一种比较方便和熟悉的方式。但 postman 本身是一个图形化软件&#xff0c;相对较难或较麻烦&#xff08;如使用 RPA&am…