当前位置: 首页 > news >正文

(c语言进阶)指针的进阶

一.字符指针

 1.一般应用

(1)%c的应用

(2)%s的应用

                                字符指针没有权限通过解引用去改变指针指向的值 

  

2.笔试题 

 题目:判断输出结果

int main()
{
    const char* p1 = "abcdef";
    const char* p2 = "abcdef";

    char arr1[] = "abcdef";
    char arr2[] = "abcdef";

    if (p1 == p2)
    {
        printf("p1==p2\n");
    }
    else
    {
        printf("p1!=p2\n");
    }

    if (arr1 == arr2)
    {
        printf("arr1==arr2\n");
    }
    else
    {
        printf("arr1!=arr2\n");
    }
    return 0;
}

解析: 

#include<stdio.h>
int main()
{
    const char* p1 = "abcdef";
    const char* p2 = "abcdef";
//常量字符串"zbcdef"被存储在只读区,指针p1、p2存储了这个字符串的首元素地址
    char arr1[] = "abcdef";
    char arr2[] = "abcdef";
//数组arr1、arr2各开辟了一块内存空间,将字符串"zbcdef"存储在开辟的内存中
    if (p1 == p2)
    {
        printf("p1==p2\n");
    }
    else
    {
        printf("p1!=p2\n");
    }
//因为p1和p2都是字符串"abcdef"的地址,是相同的
    if (arr1 == arr2)
    {
        printf("arr1==arr2\n");
    }
    else
    {
        printf("arr1!=arr2\n");
    }
//arr1和arr2为各自开辟的内存空间中,字符串"abcdef"首元素的地址
//两个内存空间不同,所以这两个地址是不同的

    return 0;
}

二.指针数组——元素为指针的数组

1.指针数组的类型 

2.指针数组的应用 

 

三.数组指针——指向数组的指针

1.数组指针的定义

  

2.数组指针与指针数组的区别 

#include<stdio.h>
int main()
{
    //数组的创建
    int arr1[5] = {1,2,3,4,5};
    int arr2[5] = {2,3,4,5,6};
    int arr3[5]= {3,4,5,6,7};
    //指针数组
    //parr是一个空间为3的数组,其中存储的元素为int*类型的
    //parr的类型为int*[3]

    int* parr[3] = {arr1,arr2,arr3};
    //数组指针
    //p为一个指针,其指向的元素为int[5]类型的
    //为了体现p是一个指针,故将*与p用()圈起来
    //p的类型为int(*)[5]

    int(*p)[5] = &arr1;
    int(*p)[5] = &arr2;
    int(*p)[5] = &arr3;
//——————————————————————————————————————————————————
    //练习
    int* (*pp)[3] = &parr;
    //pp为一个指针,其指向的元素为int*[3]类型的
    //为了体现pp是一个指针,故将*与pp用()圈起来
    //p的类型为int*(*)[3]

    return 0;
}

3.数组名的相关应用 

4.数组指针的应用 

例题:

#include<stdio.h>
void printf1(int arr[3][5],int h,int l)    //*(*(arr+H)+L)==arr[H][L],故用数组传参和指针传参本质相同
{
    int H,L;
    for (H = 0; H < h; H++)
    {
        for (L = 0; L < l; L++)
        {
            printf("%d ",arr[H][L]);
        }
        printf("\n");
    }
}
void printf2(int(*p)[5],int h,int l)    //二重指针首元素的地址为第一行元素
{
    int H,L;
    for (H = 0; H < h; H++)
    {
        for (L = 0; L < l; L++)
        {
            printf("%d ",*(*(p+H)+L));
          //printf("%d ",p[H][L]);      相同
        }
        printf("\n");
    }
}
//若设arr数组的第一行元素为一维数组brr,数组指针p解引用后为整个数组brr,brr为数组名,相当于首元素地址。
//所以数组指针p解引用后为brr的首个元素,故*(p+H)会依次获取每一行一维数组的首元素地址
//*(p+H)+L会依次获取每一行中的每一个元素的地址,故*(*(p+H)+L)会获取每一行中的每一个元素

int main()
{
    int arr[3][5] = {1,2,3,4,5,2,3,4,5,6,3,4,5,6,7};
    int h = 3;    //行
    int l = 5;    //列
    //数组传参输出
    printf1(arr,h,l);
    printf("\n");
    //指针传参输出
    printf2(arr,h,l);
    return 0;
}

输出结果: 

5.存放数组指针的数组 

 #include<stdio.h>
int main()
{
    int arr1[] = {1,2,3,4};
    int arr2[] = {2,3,4,5};
    int arr3[] = {3,4,5,6};
    int(*p1)[4] = &arr1;
    int(*p2)[4] = &arr2;
    int(*p3)[4] = &arr3;
    //数组指针不能没有元素个数,定义数组的时候可以没有
    int(*p[3])[4] = {&arr1,&arr2,&arr3};
    //存放数组指针的数组,其中元素指向的元素类型为int[4]
    //其类型为int(*[3])[4]

    return 0;
}

四.数组传参和指针传参

1.一维数组传参

#include<stdio.h>

void test1(int arr1[])
{}
void test1(int arr1[10])    //形参数组的元素可有可无
{}
void test1(int* arr1)    //接收首元素地址
{}

void test2(int* arr2[])
{}
void test2(int* arr2[20])    //形参数组的元素可有可无
{}
void test2(int** arr2)    //接收首元素地址
{}
int main()
{
    int arr1[10] = {0};
    int* arr2[20] = {0};

    test1(arr1);
    test2(arr2);
    return 0;
}

2.二维数组传参

#include<stdio.h>
void test(int arr[][5])    //二维数组的行可以省略,列不能省略
{}
void test(int arr[3][5])    
{}
void test(int(*arr)[5])    //接收首元素地址-->一个一维数组的地址
{}
int main()
{
    int arr[3][5] = {0};
    test(arr);
    return 0;

3、一级指针传参

#include<stdio.h>
void print(int* p)    //若实参的本质是一个一级整形指针就可以传参
{}
int main()
{
    int a = 10;
    int* ptr = &a;
    int arr[10];

    print(&a);
    print(ptr);
    print(arr);
    return 0;
}

4.二级指针传参

#include<stdio.h>
void test(int** p)    //若实参的本质是一个二级整形指针就可以传参
{}
int main()
{
    int* p1;
    int** p2;
    int* arr[10];  //指针数组

    test(&p1);
    test(p2);
    test(arr);
    return 0;
}

五.函数指针

1.函数指针的定义

#include<stdio.h>
int Add(int x, int y)
{
    return x + y;
}
int main()
{
    printf("%p\n",&Add);  //00007FF6991B13E8
    printf("%p\n",Add);  //00007FF6991B13E8
    //&函数名—>取出的是函数的地址
    //对于函数来说,&函数名和函数名都是函数的地址

    int (*p)(int, int) = &Add;
  //int p (int,int) = Add;
    int ret = (*p)(2, 3);
  //int ret = p (2,3);
    //对p解引用后得到函数Add,故(*p)(2, 3)==Add(2,3)

    printf("%d ",ret);
    return 0;

2.函数指针的应用 

 #include<stdio.h>
int Add(int x, int y)
{
    return x + y;
}
void calc(int(*p)(int, int))
{
    int a = 3;
    int b = 5;
    int ret = p(a, b);
    printf("%d\n",ret);
}
int main()
{
    calc(Add);    
    //将函数Add传递给函数calc,使其在函数内用指针调用Add函数
    return 0;
}

3.特殊的用法——来自《c的陷阱与缺陷》 

(1)例一 

int main()
{
    //求解如下代码的含义
    (*(void(*)())0)();
  //    void(*)()         返回值为void类型,无参的函数指针
  //  (             )0       将0强制类型转换为函数指针类型
  //(*                 )()    将函数指针类型的0解引用,调用指向地址为0处的函数

 //综上可知:这段代码的含义为一次函数调用
    return 0;
}

(2)例二 

 int main()
{
    //求解如下代码的含义
    void(*signal(int,void(*)(int)))(int);
//           signal(int,void(*)(int))        接收以整形和数组指针为参数的函数的函数指针
//  void(*                                 )(int)  解引用得到函数signal
// 最后得到:void signal (int)——为一次函数声明

    return 0;
}

4.函数指针的应用

 #include<stdio.h>    //简易计算器
void menu()
{
    //add—>加       sub—>减       mul—>乘        div—>除
    printf("*********************************************\n");
    printf("*********     1.add      2.sub    ***********\n");
    printf("*********     3.mul      4.div    ***********\n");
    printf("*********          0.exit         ***********\n");
    printf("*********************************************\n");
}
int add(int x, int y)
{
    return x + y;
}
int sub(int x, int y)
{
    return x - y;
}
int mul(int x, int y)
{
    return x * y;
}
int div(int x, int y)
{
    return x / y;
}
void DiaoYong(int (*p)(int,int))    //使用函数指针 ,减少代码冗余度
{
    int x = 0;
    int y = 0;
    printf("请输入两个整数\n");
    scanf("%d %d",&x,&y);
    int n=p(x,y);
    printf("%d\n",n);
}
int main()
{
    int input = 0;
    do
    {
        menu();
        printf("请输入选项\n");
        scanf("%d",&input);
        switch (input)
        {
        case 1:
            DiaoYong(add);
            break;
        case 2:
            DiaoYong(sub);
            break;
        case 3:
            DiaoYong(mul);
            break;
        case 4:
            DiaoYong(div);
            break;
        case 0:
            printf("退出程序\n");
            break;
        default:
            printf("数值错误,请重新输入\n");
                break;
        }
    } while (input);
    return 0;
}

5.typedef对函数指针的用法 

 #include<stdio.h>
typedef void(*pt)(int);
//将void(*)(int)改名为pt
int main()
{
    void(*signal(int,void(*)(int)))(int);
    void(*signal(int, pt))(int);
    return 0;
}

六.函数指针数组

1.函数指针的形式

 #include<stdio.h>   //输出两个整数加减乘除的结果
int add(int x, int y)
{
    return x + y;
}
int sub(int x, int y)
{
    return x - y;
}
int mul(int x, int y)
{
    return x * y;
}
int div(int x, int y)
{
    return x / y;
}
int main()
{
    int input = 0;
//    int(*p)(int, int) = add;   //函数指针
    int(*p[4])(int, int) = {add,sub,mul,div};   //函数指针数组
    for (int i=0;i<4;i++)
    {
        printf("%d\n",p[i](8,4));
    }
    return 0;
}

2.函数指针的应用 

#include<stdio.h>    //简易计算器
void menu()
{
    //add—>加       sub—>减       mul—>乘        div—>除
    printf("*********************************************\n");
    printf("*********     1.add      2.sub    ***********\n");
    printf("*********     3.mul      4.div    ***********\n");
    printf("*********          0.exit         ***********\n");
    printf("*********************************************\n");
}
int add(int x, int y)
{
    return x + y;
}
int sub(int x, int y)
{
    return x - y;
}
int mul(int x, int y)
{
    return x * y;
}
int div(int x, int y)
{
    return x / y;
}
int main()
{
    int input = 0;
    int x = 0;
    int y = 0;
    int ret = 0;
    int (*p[5])(int, int) = {0,add,sub,mul,div};
    do
    {
        menu();
        printf("请输入选项\n");
        scanf("%d", &input);
        if (input == 0)
        {
            printf("退出计算器\n");
        }
        else if(input >= 1 && input <= 4)
        {
            printf("请输入两个整数\n");
            scanf("%d %d", &x,&y);
            printf("%d\n", p[input](x,y));
        }
    }while (input);
    return 0;

七.指向函数指针数组的指针

 int main()
{
    //函数指针数组
    int (*p[5])(int, int) = {0,add,sub,mul,div};
    //指向[函数指针数组]的指针
    int(*(*pr)[5])(int, int) = &p;
    return 0;
}

八.回调函数

 1.回调函数的定义

2. 回调函数的应用

(1)例一:简易计算器

 #include<stdio.h>    //简易计算器
void menu()
{
    //add—>加       sub—>减       mul—>乘        div—>除
    printf("*********************************************\n");
    printf("*********     1.add      2.sub    ***********\n");
    printf("*********     3.mul      4.div    ***********\n");
    printf("*********          0.exit         ***********\n");
    printf("*********************************************\n");
}
int add(int x, int y)
{
    return x + y;
}
int sub(int x, int y)
{
    return x - y;
}
int mul(int x, int y)
{
    return x * y;
}
int div(int x, int y)
{
    return x / y;
}
void DiaoYong(int (*p)(int,int))    //使用函数指针 ,减少代码冗余度——回调函数
{
    int x = 0;
    int y = 0;
    printf("请输入两个整数\n");
    scanf("%d %d",&x,&y);
    int n=p(x,y);
    printf("%d\n",n);
}
int main()
{
    int input = 0;
    do
    {
        menu();
        printf("请输入选项\n");
        scanf("%d",&input);
        switch (input)
        {
        case 1:
            DiaoYong(add);
            break;
        case 2:
            DiaoYong(sub);
            break;
        case 3:
            DiaoYong(mul);
            break;
        case 4:
            DiaoYong(div);
            break;
        case 0:
            printf("退出程序\n");
            break;
        default:
            printf("数值错误,请重新输入\n");
                break;
        }
    } while (input);
    return 0;
}

(2)例二 :qsort()函数的应用——整数排序

#include<stdio.h>
#include<stdlib.h>
//void qsort          qsort()函数初始是递增排序
// (void* base,       要排序的初始位置
// size_t num,        待排序的元素个数
// size_t width,      待排序的数据元素的大小(字节)
// int(*cmp)(const void* e1,const void* e2))    函数指针—比较函数
//_cdecl——函数调用约定,约定函数由c语言的语法调用

//设置比较函数
int cmp1(const void* x1, const void* x2)
{
    return *(int*)x1 - *(int*)x2;
}
int cmp2(const void* x1, const void* x2)
{
    return *(int*)x2 - *(int*)x1;
}
//函数定义要求e1-e2>0时输出整数,e1-e2=0时输出1=0,e1-e2<0时输出负数
//qsort()函数初始是递增排序,若要变为递减排序,则要交换e1和e2

int main()
{
    //定义数组
    int i = 0;
    int arr[10] = {9,8,7,6,5,4,3,2,1,0};
    int brr[10] = {0,1,2,3,4,5,6,7,8,9};
    //求排序数组的大小
    int sz1 = sizeof(arr) / sizeof(arr[0]);
    int sz2 = sizeof(brr) / sizeof(brr[0]);
    //调用qsort()函数
    qsort(arr,sz1,sizeof(int),cmp1);
    qsort(brr,sz2,sizeof(int),cmp2);
    //输出排序后的数组
    for (i = 0; i < sz1; i++)
    {
        printf("%d ",arr[i]);
    }
    printf("\n");
    for (i = 0; i < sz2; i++)
    {
        printf("%d ", brr[i]);
    }
    return 0;
}

(3)qsort()函数的应用——结构体排序 

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
//void qsort          qsort()函数初始是递增排序
// (void* base,       要排序的初始位置
// size_t num,        待排序的元素个数
// size_t width,      待排序的数据元素的大小(字节)
// int(*cmp)(const void* e1,const void* e2))    函数指针—比较函数
//_cdecl——函数调用约定,约定函数由c语言的语法调用

//函数定义要求e1-e2>0时输出整数,e1-e2=0时输出1=0,e1-e2<0时输出负数
//qsort()函数初始是递增排序,若要变为递减排序,则要交换e1和e2
struct Stu
{
    char name[20];
    int age;
};
//设置比较函数
int cmp1(const void* x1, const void* x2)
{
    return strcmp(((struct Stu*)x1)->name,((struct Stu*)x2)->name);
}
int cmp2(const void* x1, const void* x2)
{
    return ((struct Stu*)x1)->age - ((struct Stu*)x2)->age;
}


void test1()        //排序结构体的name元素
{
    struct Stu s[3] = { {"zhangsan",15},{"lisi",30},{"wangwu",25} };
    int sz = sizeof(s) / sizeof(s[0]);
    qsort(s, sz, sizeof(s[0]),cmp1);
    for (int i = 0; i < 3; i++)
    {
        printf("%s ", s[i].name);
    }
}
void test2()    //排序结构体的age元素
{
    struct Stu s[3] = { {"zhangsan",15},{"lisi",30},{"wangwu",25} };
    int sz = sizeof(s) / sizeof(s[0]);
    qsort(s, sz, sizeof(s[0]), cmp2);
    for (int i = 0; i < 3; i++)
    {
        printf("%d ", s[i].age);
    }
}
int main()
{
    test1();
    printf("\n");
    test2();
    return 0;
}

 

(4)用冒泡排序模拟实现qsort()函数

 #include<stdio.h>    
int cmp(const void* x1, const void* x2)
{
    return (*(int*)x1 - *(int*)x2);
}
void Swap(char* x, char* y, int width)  //将两个数改为char*类型,每次只交换一个字节,直到将int*的四个字节全部交换一遍
{
    int i = 0;
    for (i = 0; i < width; i++)
    {
        char tmp = *x;
        *x = *y;
        *y = tmp;
        x++;
        y++;
    }
}
sqort_moni(int* arr,int sz,int width, int (*cmp)(const void*, const void*))
{
    int i,j;
    for (i = 0; i < sz - 1; i++)
    {
        int flag = 1;
        for (j = 0; j < sz - 1 - i; j++)
        {
            if (cmp((char*)arr + j * width, (char*)arr + (j + 1) * width )> 0) //返回值大于0,则说明x1>x2,需要顺序排列则要交换两个数
            {
                Swap((char*)arr + j * width, (char*)arr + (j + 1) * width, width);
                flag = 0;
            }
        }
        if (flag == 1)  //如果循环一整遍之后都符合条件,则直接跳出循环
        {
            break;
        }
    }
}
int main()
{
    int arr[10] = {9,8,7,6,5,4,3,2,1,0};
    int sz = sizeof(arr) / sizeof(arr[0]);
    sqort_moni(arr,sz,sizeof(arr[0]), cmp);
    for (int i = 0; i < sz; i++)
    {
        printf("%d ",arr[i]);
    }
    return 0;
}

相关文章:

(c语言进阶)指针的进阶

一.字符指针 1.一般应用 &#xff08;1&#xff09;%c的应用 &#xff08;2&#xff09;%s的应用 字符指针没有权限通过解引用去改变指针指向的值 2.笔试题 题目&#xff1a;判断输出结果 int main() { const char* p1 "abcdef"; const char* p2 "…...

用路由器远程维护三菱PLC操作指南

用路由器远程维护三菱PLC操作指南...

FPGA面试题(7)

一.解释一下SPI的四种模式 01时钟极性CPOL空闲状态为低电平空闲状态为高电平时钟相位CPHA在第一个跳变沿采样在第二个跳变沿采样 模式CPOLCPHA描述模式000sclk上升沿采样&#xff0c;sclk下降沿发送模式101sclk上升沿发送&#xff0c;sclk下降沿采样模式210sclk上升沿发送&…...

Python接口自动化测试之【测试函数、测试类/测试方法的封装】

前言 在pythonpytest 接口自动化系列中&#xff0c;我之前的文章基本都没有将代码进行封装&#xff0c;但实际编写自动化测试脚本中&#xff0c;我们都需要将测试代码进行封装&#xff0c;才能被测试框架识别执行。 例如单个接口的请求代码如下&#xff1a; import requests…...

ROS仿真软件Turtlebot-Gazebo的安装使用以及错误处理[机器人避障]

很多时候由于机器人价格比较贵&#xff0c;而且会因为环境因素、操作失误或者摔坏等&#xff0c;所以我们可以先在仿真软件上做测试&#xff0c;也可以避免这些问题&#xff0c;虽然没有那么真实感&#xff0c;可毕竟是免费的嘛。我们可以在这些仿真的机器人身上去学习如何控制…...

把excel文件内容转化为json文件

js如何把excel文件转化为json文件呢&#xff1f;可以通过xlsx还有循环遍历来做 第一步&#xff1a;安装xlsx包 npm install xlsx这里我需要转化为这种类型 {key:value,key:value,key:value, }如果需要转化为其他格式&#xff0c;到时候需要在循环遍历的时候灵活运用 上代码…...

前端 - 将非 jpeg 格式图片转为 jpeg 格式、压缩图片

目录 将非 jpeg 格式图片转为 jpeg 格式压缩图片使用 将非 jpeg 格式图片转为 jpeg 格式 /common/compressImage/convertImage // 思路是创建一个图片&#xff0c;将file等于这个图片&#xff0c;然后创建一个canvas图层 &#xff0c;将canvas等比例缩放&#xff0c; //然后用…...

随着 ChatGPT 凭借 GPT-4V(ision) 获得关注,多模态 AI 不断发展

原创 | 文 BFT机器人 在不断努力让人工智能更像人类的过程中&#xff0c;OpenAI的GPT模型不断突破界限GPT-4现在能够接受文本和图像的提示。 生成式人工智能中的多模态表示模型根据输入生成文本、图像或音频等各种输出的能力。这些模型经过特定数据的训练&#xff0c;学习底层模…...

Zookeeper-JavaApI操作

JavaApI操作 JavaApI操作1) Curator 介绍2) Curator API 常用操作a) 建立连接与CRUD基本操作b) Watch事件监听c) 分布式锁c.1) 介绍c.2) Zookeeper分布式锁原理c.3) 案例&#xff1a;模拟12306售票 JavaApI操作 1) Curator 介绍 Curator 是 Apache ZooKeeper 的Java客户端库。…...

Vue2.0打包指定路由前缀

【1】修改vue.config.js 如下修改publicPath: module.exports {publicPath:/concert,lintOnSave: false }【2】修改router/index.js base指定路由前缀&#xff1a; const router new VueRouter({mode: history,base: /concert, //指定路由前缀// base: process.env.BASE_…...

[vxe-table] 合并行后滚动错位

使用vxe-table的属性:span-method合并行&#xff0c;之后下拉后会错位 原因&#xff1a;缺少配置 scroll-y"{enabled: false}"参考&#xff1a; vxe-table合并行后错位...

动态规划:05不同路径

动态规划&#xff1a;05不同路径 62. 不同路径 五部曲 确定dp数组含义&#xff1a;到达第i&#xff0c;j位置的路径条数为d[i][j] 确定递归公式&#xff1a;d[i][j]d[i-1][j]d[i][j-1] 我们发现&#xff0c;想要到d[i][j]&#xff0c;只能从d[i-1][j]或者d[i][j-1]达到 dp数…...

html与css知识点

html 元素分类 块级元素 1.独占一行&#xff0c;宽度为父元素宽度的100% 2.可以设置宽高 常见块级元素 h1~h6 div ul ol li dl dt dd table form header footer section nav article aside 行内元素 1.一行显示多个 2.不能设置宽高&#xff0c;宽高由元素内容撑开 常见行内…...

spring boot simple类型cache使用

注意&#xff1a;这里用的不是 redis 的缓存&#xff0c;simple 的缓存默认用的是 java 的 ConcurrentHashMap&#xff0c; 单纯的 simple 缓存&#xff0c;只需要引入下面的 pom 依赖即可&#xff1a;spring-boot-starter-cache <dependency><groupId>org.springf…...

springboot-aop-redis-lua 实现的分布式限流方案

1.自定义限流注解 Target({ElementType.METHOD, ElementType.TYPE}) Retention(RetentionPolicy.RUNTIME) Inherited Documented public interface Limit {/*** 名字*/String name() default "";/*** key*/String key() default "";/*** Key的前缀*/String…...

C++ realloc()用法及代码示例

C realloc()用法及代码示例 C 中的realloc() 函数重新分配先前分配但尚未释放的内存块。realloc() 函数重新分配先前使用 malloc() 、 calloc() 或 realloc() 函数分配但尚未使用 free() 函数释放的内存。如果新大小为零&#xff0c;则返回的值取决于库的实现。它可能会也可能…...

【Go】gin框架生成压缩包与下载文件

在没有加入下面这串代码之前&#xff0c;下载的压缩包一直为空。遂debug了两个小时。。。 可以在服务端本地创建压缩包。单独将服务端本地的压缩包发送给客户端也是没问题的。但是两个合起来&#xff0c;客户端接收到的压缩包内容就为空了。 期间也尝试了 zipFile.Close() zipW…...

iOS 面试题以及自我理解答案

1、简述push原理&#xff0c;push的证书和其他的有什么不一样&#xff1f; 第 一阶段&#xff1a;BeejiveIM服务器把要发送的消息、目的iPhone的标识打包&#xff0c;发给APNS。 第二阶段&#xff1a;APNS在自身的已注册Push服务 的iPhone列表中&#xff0c;查找有相应标识的iP…...

vue实现自定义滚动条

vue实现自定义滚动条 具体效果如下&#xff0c;这边我用的rem单位&#xff0c;比例是1:40&#xff0c; 先写下页面布局&#xff0c;把原生的滚动条给隐藏掉&#xff0c;给自定义的滑块增加transition: marginLeft 1s linear;可以使左边距过度的更顺滑 .top-box-2::-webkit-scr…...

基于Qt C++的工具箱项目源码,含命令行工具、桌面宠物、文献翻译、文件处理工具、医学图像浏览器、插件市场、设置扩展等工具

一、介绍 1. 基本信息 完整代码下载地址&#xff1a;基于Qt C的工具箱项目源码 TBox是一款基于Qt C的工具箱。用户可以自行选择安装所需的工具&#xff08;以插件的形式&#xff09;&#xff0c;将TBox打造成专属于自己的效率软件。TBox基本界面展示如下&#xff1a; 2. 使用…...

51c自动驾驶~合集58

我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留&#xff0c;CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制&#xff08;CCA-Attention&#xff09;&#xff0c;…...

云启出海,智联未来|阿里云网络「企业出海」系列客户沙龙上海站圆满落地

借阿里云中企出海大会的东风&#xff0c;以**「云启出海&#xff0c;智联未来&#xff5c;打造安全可靠的出海云网络引擎」为主题的阿里云企业出海客户沙龙云网络&安全专场于5.28日下午在上海顺利举办&#xff0c;现场吸引了来自携程、小红书、米哈游、哔哩哔哩、波克城市、…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院挂号小程序

一、开发准备 ​​环境搭建​​&#xff1a; 安装DevEco Studio 3.0或更高版本配置HarmonyOS SDK申请开发者账号 ​​项目创建​​&#xff1a; File > New > Create Project > Application (选择"Empty Ability") 二、核心功能实现 1. 医院科室展示 /…...

Vue2 第一节_Vue2上手_插值表达式{{}}_访问数据和修改数据_Vue开发者工具

文章目录 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染2. 插值表达式{{}}3. 访问数据和修改数据4. vue响应式5. Vue开发者工具--方便调试 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染 准备容器引包创建Vue实例 new Vue()指定配置项 ->渲染数据 准备一个容器,例如: …...

c#开发AI模型对话

AI模型 前面已经介绍了一般AI模型本地部署&#xff0c;直接调用现成的模型数据。这里主要讲述讲接口集成到我们自己的程序中使用方式。 微软提供了ML.NET来开发和使用AI模型&#xff0c;但是目前国内可能使用不多&#xff0c;至少实践例子很少看见。开发训练模型就不介绍了&am…...

OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别

OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别 直接训练提示词嵌入向量的核心区别 您提到的代码: prompt_embedding = initial_embedding.clone().requires_grad_(True) optimizer = torch.optim.Adam([prompt_embedding...

OPenCV CUDA模块图像处理-----对图像执行 均值漂移滤波(Mean Shift Filtering)函数meanShiftFiltering()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 在 GPU 上对图像执行 均值漂移滤波&#xff08;Mean Shift Filtering&#xff09;&#xff0c;用于图像分割或平滑处理。 该函数将输入图像中的…...

高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数

高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数 在软件开发中,单例模式(Singleton Pattern)是一种常见的设计模式,确保一个类仅有一个实例,并提供一个全局访问点。在多线程环境下,实现单例模式时需要注意线程安全问题,以防止多个线程同时创建实例,导致…...

论文笔记——相干体技术在裂缝预测中的应用研究

目录 相关地震知识补充地震数据的认识地震几何属性 相干体算法定义基本原理第一代相干体技术&#xff1a;基于互相关的相干体技术&#xff08;Correlation&#xff09;第二代相干体技术&#xff1a;基于相似的相干体技术&#xff08;Semblance&#xff09;基于多道相似的相干体…...

WPF八大法则:告别模态窗口卡顿

⚙️ 核心问题&#xff1a;阻塞式模态窗口的缺陷 原始代码中ShowDialog()会阻塞UI线程&#xff0c;导致后续逻辑无法执行&#xff1a; var result modalWindow.ShowDialog(); // 线程阻塞 ProcessResult(result); // 必须等待窗口关闭根本问题&#xff1a…...