【C语言】详解计算机二级c语言程序题

news2025/1/20 12:06:16

文章目录

  • 前言
  • 资料相关
  • 程序题 一(字符串)
  • 程序题 二(数组)
  • 程序题 三(基础)
  • 程序题 四(结构体)
  • 程序题 五(结构体)
  • 程序题 六(基础)

前言

最近计算机二级的c语言快要考试了,我从网上摘抄了一些c语言二级的原题,并利用gpt做了一些解析来理解这些问题,以便大家能够更好的学习。

同时,我将问题答案设置为白色(只需要选中就可以查看),大家可以在理解问题的同时进行练习。

资料相关

  1. Dotcpp——里面有C语言原题以及众多高校试卷,可以用来练习
  2. 计算机二级考试官网——没有报名的同学千万别忘了
    各省份报考时间
  3. 资源绑定里面有c语言计算机二级的考纲(2023版)

程序题 一(字符串)

给定程序中,函数fun的功能是:在形参s所指字符串中寻找与参数c相同的字符,并在其后插入一个与之相同的字符,若找不到相同的字符则函数不做任何处理。

例如,s所指字符串为:baacda,c中的字符为:a,执行后s所指字符串为:baaaacdaa。

请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。

注意:源程序存放在考生文件夹下的BLANK1.C中。

不得增行或删行,也不得更改程序的结构!

#include<stdio.h>
void fun(char *s, char c)
{
    int i, j, n;
    for(i=0; s[i]!=___1___ ; i++)
    if(s[i]==c)
    {
        n=___2___ ;
        while(s[i+1+n]!='\0') n++;
        for(j=i+n+1; j>i; j--) s[j+1]=s[j];
        s[j+1]=___3___ ;
        i=i+1;
    }
}
int main()
{
    char s[80]="baacda", c;
    printf("\nThe string: %s\n",s);
    printf("\nInput a character: ");
    scanf("%c",&c);
    fun(s,c);
    printf("\nThe result is: %s\n",s);
	return 0;
}
  1. 正确答案: ‘\0’
  2. 正确答案: 0
  3. 正确答案: c
  • fun 函数接受一个字符串 s 和一个字符 c 作为参数。

  • for 循环遍历字符串 s 直到遇到字符串结束符 \0

  • 在循环中,如果当前字符与目标字符 c相等,就执行以下操作:

    • 初始化变量 n 为 0。
    • 使用 while 循环找到目标字符后的子串的长度,即 n
    • 从字符串末尾开始,将原字符串中的字符向后移动一个位置,为插入字符 c 空出位置。
    • 在原字符位置插入字符 c
      更新循环变量 i,以跳过刚刚插入的字符,避免重复处理。
  • main 函数中声明一个字符串 s 并初始化为 "baacda",然后接受用户输入的字符 c

    • 调用 fun 函数对字符串进行处理。最后打印处理后的字符串。

所以,如果用户输入字符 a,程序将在字符串中找到每个 a,并在其后插入一个额外的 a,最终输出结果为 “baaaacdaa”。

程序题 二(数组)

在主函数中从键盘输入若干个数放入数组中,用0结束输入并放在最后一个元素中。给定程序MODI1.C中函数fun的功能是:计算数组元素中值为正数的平均值(不包括0)。

例如:数组中元素中的值依次为:39,-47,21,2,-8,15,0,则程序的运行结果为:19.250000。

请改正程序中的错误,使它能得出正确的结果。

注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!

#include<stdio.h>
double fun ( int x[])
{
    ____1____
    int c=0, i=0;
    while (x[i] != 0)
    {
        if (x[i] > 0)
        {
            sum += x[i]; c++;
        }
        i++;
    }
    ____2____
    return sum;
}
int main()
{
    int x[1000];
    int i=0;
    printf( "\nPlease enter some data (end with 0): " );
    do
    {
        scanf("%d", &x[i]);
    }
    while (x[i++] != 0);
    printf("%f\n", fun ( x ));
    return 0;
}
  1. 正确答案: double sum=0;
  2. 正确答案: sum /= c;
  • 函数 fun:

    • double fun(int x[]): 这是一个函数原型,接受一个整数数组 x 作为参数,返回一个双精度浮点数(double)表示正数的平均值。
    • double sum = 0.0;: 在函数内部声明一个 sum 变量并初始化为0.0,用于存储正数的总和。
    • int c = 0, i = 0;: 声明两个整数变量 ci,其中 c 用于计数正数的个数,i 用于迭代数组元素。
    • while (x[i] != 0): 进入一个 while 循环,循环条件是数组元素不等于0。这是因为输入的数组以0作为结束标志。
    • if (x[i] > 0) { sum += x[i]; c++; }: 如果当前数组元素为正数,则将其加到 sum 中,并增加正数计数器 c
    • i++;: 增加迭代器 i,移动到下一个数组元素。
    • sum /= c;: 计算正数的平均值,将总和 sum 除以正数的个数 c
    • return sum;: 返回计算得到的正数平均值。
  • 主函数 main

    • int x[1000];: 在主函数中声明一个大小为1000的整数数组 x
    • int i = 0;: 声明整数变量 i,用于迭代数组元素的索引。
    • printf("\nPlease enter some data (end with 0): ");: 打印提示信息,要求用户输入数据,直到输入0为止。
    • do { scanf("%d", &x[i]); } while (x[i++] != 0);: 使用 do-while 循环从键盘读取整数,将它们存储到数组中,直到输入0为止。注意,这里使用 i++ 来实现读取下一个数组元素,并检查该元素是否为0来决定是否继续循环。
    • printf("%f\n", fun(x));: 调用 fun 函数计算数组中正数的平均值,并使用 printf 打印结果。

程序题 三(基础)

编写函数fun,函数的功能是:根据以下公式计算s,计算结果作为函数值返回;n通过形参传入。

S = 1 + 1 1 + 2 + 1 1 + 2 + 3 + … + 1 1 + 2 + 3 + … + n S = 1 + \frac{1}{1+2} + \frac{1}{1+2+3} + \ldots + \frac{1}{1+2+3+ \ldots + n} S=1+1+21+1+2+31++1+2+3++n1

例如:若n的值为11时,函数的值为:1.833333

注意:部分源程序在文件PROG1.C中。

请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。

给定源程序:

#include<stdio.h>
float fun(int n)
{
    ____1____
    ____2____
    for(____3____)
    {
        ____4____
        for(____5____)
        t+=j;
        ____6____
    }
    return s;
}
main()
{
    int n;
    float s;
    printf("\nPlease enter N:");
    scanf("%d", &n);
    s = fun(n);
    printf("the result is: %f\n", s);
}
  1. 正确答案: int i, j, t;
  2. 正确答案: float s=0;
  3. 正确答案: i=1;i<=n;i++
  4. 正确答案: t=0;
  5. 正确答案: j=1;j<=i;j++
  6. 正确答案: s=s+1./t;
  • 变量声明:int i, j, t; float s = 0; 在fun函数开始处,声明了三个整型变量 ijt,以及一个浮点型变量 s。这些变量用于循环和计算。

  • 循环

    • 外部循环:for (i = 1; i <= n; i++),使用 for 循环,变量 i 从1开始递增,直到达到传入的 n 的值。

    • 内部循环:for (j = 1; j <= i; j++);在外部循环中,使用 for 循环,变量 j 从1开始递增,直到达到 i 的值。这个内部循环用于计算公式中的分母部分的和。

      • 内部循环中的累加:t += j; 在内部循环中,变量 t 用于累加 j 的值,即计算公式中的分母部分的和。
    • 计算公式中的分数部分:s += 1.0 / t; 在每次外部循环结束时,通过将1除以 t 的值,得到公式中的分数部分,然后将其累加到变量 s 中。

  • 返回最终结果:return s; 函数 fun 返回计算得到的 s 的值。

  • 用户输入和输出:

    int main()
    {
        // ...
    
        printf("\nPlease enter N:");
        scanf("%d", &n);
    
        s = fun(n);
    
        printf("The result is: %f\n", s);
    
        // ...
    }
    

    主函数负责接收用户输入的 n,调用 fun 函数计算结果,并输出最终的计算结果。

程序题 四(结构体)

给定程序BLANK1.C中,函数fun的功能是在数组中找出两科成绩之和最高的学生并返回其在数组中的下标。对所给函数int fun(STU*d,int n),主函数传给形参d的是学生数组名,而传给形参n的是该数组中学生的个数。

例如,若学生数组数据为:
2016500301李清水83 92
2016500336 刘世才85 94
2016500371王子晨88 88

则调用该函数后,程序输出为:2016500336刘世才85 94

请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。

注意:不得增行或删行,也不得更改程序的结构!

#include<stdio.h>
typedef struct stu
{
    char ID[30];
    char name[20];
    int score[2];
} STU;
int fun(STU *d,int n)
{
    int i,m;
    /******found******/
    ______(1)______;
    for(i=1;i<n;i++)
    /******found******/
        if(d[i].score[0]+d[i].score[1]>________(2)________)
            m=i;
    /******found******/
    ______(3)______;
}
 
void main()
{
    STU a[10]={ "2016500301","李清水",83,92,"2016500336","刘世才",85,94,"2016500371","王子晨",88,88};
    int i,n=3;
    i=fun(a,n);
    printf("%30s%20s%4d%4d",a[i].ID,a[i].name,a[i].score[0],a[i].score[1]);
    printf("\n");
}
  1. 正确答案: m=0
  2. 正确答案: d[m].score[0]+d[m].score[1]
  3. 正确答案: return m
  • 结构体定义:

    typedef struct stu
    {
        char ID[30];
        char name[20];
        int score[2];
    } STU;
    

    定义了一个结构体 stu,用于存储学生的信息,包括学号(ID)、姓名(name)和两科成绩(score)。

  • 函数定义:

    int fun(STU *d, int n)
    {
        int i, m;
        /******found******/
        m = 0; // 初始化 m 为数组的第一个学生的下标
        for (i = 1; i < n; i++)
        /******found******/
            if (d[i].score[0] + d[i].score[1] > d[m].score[0]+d[m].score[1])
                m = i; // 更新 m 为当前学生的下标,如果其成绩之和更高
        /******found******/
        return m; // 返回最终找到的学生的下标
    }
    

    函数 fun 接收一个指向学生数组的指针 d 和数组中学生的个数 n。函数通过遍历数组找到两科成绩之和最高的学生,并返回其在数组中的下标。

  • 主函数中的调用和输出:

    void main()
    {
        STU a[10] = { "2016500301", "李清水", 83, 92, "2016500336", "刘世才", 85, 94, "2016500371", "王子晨", 88, 88 };
        int i, n = 3;
        i = fun(a, n);
        printf("%30s%20s%4d%4d", a[i].ID, a[i].name, a[i].score[0], a[i].score[1]);
        printf("\n");
    }
    

    在主函数中,定义了一个包含三个学生信息的数组 a,然后调用了 fun 函数,得到两科成绩之和最高的学生的下标,最后输出该学生的信息。

程序题 五(结构体)

给定程序MODI1.C中,函数void list(MYDATA *h)的功能是:列出带头结点单链表中所有没有删除标记的数据。调用这个函数时,传给形参h的是指向单链表头结点的指针。

例如,当10个结点的数据为1,2,3,4,5,6,7,8,9,10时,输出将是:3 4 6 7 8 9 10

其中,各个数据所对应的删除标记是由随机数产生的。

请改正函数list中指定部位的错误,使它能得出正确的结果。

注意:不要改动main函数和creat函数,不得增行或删行

#include<stdio.h>
#include<stdlib.h>
typedef struct dat
{
    char deleted;  //是否删除:0-未删除,1-删除
    int data;
    struct dat* next;
} MYDATA;
void list(MYDATA *h)
{
/******found******/
    MYDATA  p;
    p=h->next;
    while(p!=NULL)
    {
    /******found******/
        if(p->data==0)
        {
            printf("%d  ",p->data);
        }
/******found******/
        p=next;
    }
}
 
void creat(MYDATA *h,int *d,int n)
{
    MYDATA *p, *q;
    int i=0,del;
    q=h;
    while(n>0)
    {
        p=( MYDATA *)malloc(sizeof(MYDATA));
        del=rand()%2;
        p->data=d[i];
        p->deleted=del;
        p->next=q->next;
        q->next=p;
        q=p;
        n--;i++;
    }
}
void main()
{
    MYDATA *head;
    int n=10,dd[]={1,2,3,4,5,6,7,8,9,10};
    head=(MYDATA *)malloc(sizeof(MYDATA));
    head->next=NULL;
    creat(head,dd,n);
    list(head);
}
  1. 正确答案: MYDATA *p;
  2. 正确答案: if(p->deleted==0)
  3. 正确答案: p=p->next;
  • 函数定义:void list(MYDATA *h){ /* ... */} 函数 list 的目标是列出带头结点单链表中没有删除标记的数据。

  • 局部变量声明:MYDATA *p; p=h->next; 在函数内部声明了一个 MYDATA 类型的结构指针变量 p,并将其初始化为链表的第一个结点。

  • 遍历链表:while(p!=NULL){ /* ... */ } 使用 while 循环遍历链表,访问每个结点的数据。

  • 判断删除标记:if(p->deleted==0) { printf("%d ",p->data); } 在循环中,如果当前结点的数据没有删除标记,就输出该数据。

  • 移动到下一个结点:p=p->next;移动到链表中的下一个结点。这里应该使用 p=p->next; 来正确更新 p。

  • 主函数中的调用和输出:list(head);在主函数中调用 list 函数,输出链表中没有删除标记的数据。

程序题 六(基础)

请编写函数void fun(int *dp,int n,int upordown),其功能是,找出dp所指数组中的最小或最大值,并与其第1个元素交换。形参n为元素的个数,形参upordown为查找标志:值为0时找最小值;值为1时找最大值。

注意:部分源程序在文件PROG1.C中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。

#include <stdio.h>
#include <stdlib.h>
#define N 10
#pragma warning (disable:4996)
void NONO(FILE *fp, int pd[], int n);
 
void fun (int *dp,int n,int upordown)
{
    int temp=0;
    int i=0;
    temp=*dp;
    if(upordown==0)
   {
    for(i=1;i<n;i++)
    {
        if(dp[i]<temp)
        {
            dp[0]=dp[i];
            dp[i]=temp;
            temp=dp[0];
        }
      }
    }
    else if(/******found******/)
   {
    for(/******found******/)
    {
        if(/******found******/)
        {
            /******found******/
            /******found******/
            /******found******/
        }
    }
}
*dp=temp;
 
}
 
void display(int pd[],int n)
{
    int i;
    for(i=0;i<n;i++)
        printf("%4d",pd[i]);
    printf("\n");
}
void main()
{
    int data[N],i,n=N;
    FILE *out ;
 
    out = fopen("out.dat","w") ;
    for(i=0;i<N;i++)
        data[i]=rand()%90+10;
    for(i=0;i<N-1;i++)
        fun(data+i,n-i,0);
    display(data,n);
    NONO(out, data, n);
    for(i=0;i<N;i++)
        data[i]=rand()%90+10;
    for(i=0;i<N-1;i++)
        fun(data+i,n-i,1);
    display(data,n);
    NONO(out, data, n);
    fclose(out);
}
void NONO(FILE *fp, int pd[], int n)
{
    int i;
    for(i=0;i<n;i++)
        fprintf(fp, "%4d", pd[i]);
    fprintf(fp, "\n");
 
}
  1. 正确答案: upordown==1
  2. 正确答案: i=1;i<n;i++
  3. 正确答案: dp[i]>temp
  4. 正确答案: dp[0]=dp[i];
  5. 正确答案: dp[i]=temp;
  6. 正确答案: temp=dp[0];
  • 函数定义:void fun(int *dp, int n, int upordown) { /* ... */ } 函数 fun 接收一个整型指针 dp,表示数组的首地址,整数 n 表示数组元素的个数,整数 upordown 表示查找标志,值为0时找最小值,值为1时找最大值。

  • 局部变量声明:int temp = 0; int i = 0; 在函数内部声明了两个整型变量 tempitemp 用于保存当前数组元素的值,i 用于循环计数。

  • 初始化 temp:temp = *dp;temp 初始化为数组的第一个元素的值。

  • 查找最小值的逻辑:

    if (upordown == 0)
    {
        for (i = 1; i < n; i++)
        {
            if (dp[i] < temp)
            {
                dp[0] = dp[i];
                dp[i] = temp;
                temp = dp[0];
            }
        }
    }
    
    • 如果upordown 为0,表示查找最小值。在循环中,如果当前元素小于 temp,则交换它们,并更新 temp 的值。
  • 查找最大值的逻辑:

    else if (upordown == 1)
    {
        for (i = 1; i < n; i++)
        {
            if (dp[i] > temp)
            {
                dp[0] = dp[i];
                dp[i] = temp;
                temp = dp[0];
            }
        }
    }
    
    • 如果 upordown 为1,表示查找最大值。在循环中,如果当前元素大于 temp,则交换它们,并更新 temp 的值。
  • 将最小或最大值赋给第一个元素:*dp = temp;最终,将最小或最大值赋给数组的第一个元素。

  • 主函数中的调用和输出:

    for (i = 0; i < N - 1; i++)
        fun(data + i, n - i, 0);
    
    display(data, n);
    
    for (i = 0; i < N; i++)
        data[i] = rand() % 90 + 10;
    
    for (i = 0; i < N - 1; i++)
        fun(data + i, n - i, 1);
    
    display(data, n);
    
    • 主函数通过调用 fun 函数两次,一次查找最小值,一次查找最大值,然后输出结果。这样可以看到数组中最小值和最大值的位置发生了交换。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【广度优先搜索】【网格】【割点】1263. 推箱子

作者推荐 视频算法专题 涉及知识点 广度优先搜索 网格 割点 并集查找 LeetCode:1263. 推箱子 「推箱子」是一款风靡全球的益智小游戏&#xff0c;玩家需要将箱子推到仓库中的目标位置。 游戏地图用大小为 m x n 的网格 grid 表示&#xff0c;其中每个元素可以是墙、地板或…

C# 使用onnxruntime部署夜间雾霾图像的可见度增强

目录 介绍 模型信息 效果 项目 代码 下载 C# Onnx 使用onnxruntime部署夜间雾霾图像的可见度增强 介绍 github地址&#xff1a;GitHub - jinyeying/nighttime_dehaze: [ACMMM2023] "Enhancing Visibility in Nighttime Haze Images Using Guided APSF and Gradien…

如何实现负载均衡呢?

如何实现负载均衡呢&#xff1f; 一、问题解析 常见的实现方案有三种&#xff01;  基于 DNS 实现负载均衡  基于硬件实现负载均衡  基于软件实现负载均衡 先来说一下基于 DNS 实现负载均衡的方式&#xff0c;它的实现方式比较简单&#xff0c;只需要在 DNS 服务器上…

apidoc接口文档的自动更新与发布

文章目录 一、概述二、环境准备三、接口文档生成1. 下载源码2. 初始化3.执行 四、文档发布五&#xff0c;配置定时运行六&#xff0c;docker运行七&#xff0c;优化方向 一、概述 最近忙于某开源项目的接口文档整理&#xff0c;采用了apidoc来整理生成接口文档。 apidoc是一个…

Java基于SpringBoot的口腔医院管理平台,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

仿12306校招项目业务三(用户注册)

用户表结构 原本的表结构如下 由于用户量大&#xff0c;采用分库分表&#xff1a; 分库分表设计 根据系统设计的假设&#xff0c;12306 的注册用户规模约为 10 亿&#xff0c;每年新增用户约 1000 万。在用户数据分库或分表之前&#xff0c;我们需要先考虑拆分成多少个库或表…

我们和openAi的差距,只差向神祈祷了?

这两天看到了两张挺有意思的图片&#xff0c;关于openAi研究人员和qianWen的研究人员的日常生活作息表。蛮有意思&#xff0c;看到后有很多感想&#xff0c;特地分享出来。&#xff08;声明&#xff1a;对比没有恶意&#xff0c;也没有好坏之分。他们本都是站在金字塔最顶尖的人…

StarRocks——滴滴OLAP的技术实践与发展方向

原文大佬的这篇StarRocks实践文章整体写的很深入&#xff0c;介绍了StarRocks数仓架构设计、物化视图加速实时看板、全局字典精确去重等内容&#xff0c;这里直接摘抄下来用作学习和知识沉淀。 目录 一、背景介绍 1.1 滴滴OLAP的发展历程 1.2 OLAP引擎存在的痛点 1.2.1 运维…

AI人工智能芯片制作研究与开发技术资料(三百多份文档)【机×密】

收藏多年的精品&#xff0c;不可多得的东西。对芯片开发研究有兴趣同学&#xff0c;赶快下载看看吧。文件大小3G多。 AI人工智能芯片制作研究与开发技术资料&#xff08;三百多份文档&#xff09;【机密】 下载地址&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/14Duh…

【网络安全】SQL注入_sql注入攻击实例(网安人必学系列)

1.1 .Sql注入攻击原理 SQL注入漏洞可以说是在企业运营中会遇到的最具破坏性的漏洞之一&#xff0c;它也是目前被利用得最多的漏洞。要学会如何防御SQL注入&#xff0c;首先我们要学习它的原理。 针对SQL注入的攻击行为可描述为通过在用户可控参数中注入SQL语法&#xff0c;破…

容器镜像详解

1. 镜像组成 一个标准的OCI容器镜像由index, manifest, config, image layers这几个部分组成。 以docker镜像为例&#xff0c;下载的镜像文件保存在/var/lib/docker/目录下面 image/overlay2子目录下面保存着镜像相关的一些元数据 在下面的介绍主要以nginx:latest镜像为例子…

Django定时任务之django_apscheduler使用

Django定时任务之django_apscheduler使用 今天在写一个任务需求时需要用到定时任务来做一部分数据处理与优化&#xff0c;于是在了解完现有方法&#xff0c;结合自己需求决定使用django_apscheduler&#xff0c;记录一下过程&#xff0c;有几篇值得参考的文章放在结尾&#xf…

超详细!彻底说明白Redis持久化

本文已收录至Github&#xff0c;推荐阅读 &#x1f449; Java随想录 微信公众号&#xff1a;Java随想录 文章目录 Redis持久化方式RDBfork 函数与写时复制RDB 相关配置 AOFAOF 文件解读AOF 的写入与同步AOF 重写AOF重写的实现AOF 重写面临的问题AOF重写缓存区 AOF相关配置AOF …

【深入了解设计模式】适配器设计模式

适配器设计模式 适配器设计模式是一种结构型设计模式&#xff0c;用于将一个类的接口转换成客户端所期望的另一个接口&#xff0c;从而使得原本由于接口不兼容而不能一起工作的类能够一起工作。适配器模式通常用于以下场景&#xff1a; 现有接口与需求不匹配&#xff1a;当需要…

Escalate_Linux(4)-利用SUDO实现提权

利用SUDO实现提权 利用用户的sudo授权获得root的shell cat /etc/passwd cat /etc/sudoers 命令没有权限 echo "cat /etc/sudoers" >/tmp/ls chmod 755 /tmp/ls export PATH/tmp:$PATH /home/user5/script 想办法更改user1的口令 echo echo "user1:xiao…

【C语言基础】:操作符详解(一)

文章目录 操作符详解1. 操作符的分类2. 二进制和进制转换2.1 什么是二进制、八进制、十进制、十六进制2.1.1 二进制和进制转换2.1.2 二进制转十进制2.2.3 二进制转八进制2.2.4 二进制转十六进制 3. 源码、反码、补码4. 移位操作符4.1 左移操作符4.2 右移操作符 5. 位操作符&…

协议的概念+本质+作用+最终表现形式,网络问题(技术+应用+解决的协议+存在原因),主机的对称性

目录 协议 概念 示例 -- 摩斯密码 本质 作用 网络问题 引入 技术问题 应用问题 主机的对称性 问题对应的协议 问题出现的原因 理解协议(代码层面) 举例 -- 快递单 协议的最终表现形式 协议被双方主机认知的基础 协议 概念 协议是在计算机通信和数据传输中规定通…

Seata Server 服务搭建

概述 Seata 分布式事务需要 Seata Seaver 支持&#xff0c;Seata Server在 架构中扮演着 事务管理器的角色。Seata 服务需要往 Nacos 注册中心注册、以及读取配置文件&#xff0c;因此 Seata 启动前需要部署 Nacos 环境。 安装包下载 下载地址: https://download.csdn.net/dow…

【Redis学习笔记03】Java客户端

1. 初识Jedis Jedis的官网地址&#xff1a;https://github.com/redis/jedis 1.1 快速入门 使用步骤&#xff1a; 注意&#xff1a;如果是云服务器用户使用redis需要先配置防火墙&#xff01; 引入maven依赖 <dependencies><!-- 引入Jedis依赖 --><dependency&g…

CSS 的圆角矩形

CSS 的圆角矩形 通过 border-radius 属性使矩形边框带圆角效果成为圆角矩形 语法&#xff1a;border-radius: length; length 是内切圆的半径&#xff0c;其数值越大, 弧线越明显 border-radius 属性值描述length定义圆角的形状%以百分比定义圆角的形状 生成圆形 让 border-…