(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.一般应用 (1)%c的应用 (2)%s的应用 字符指针没有权限通过解引用去改变指针指向的值 2.笔试题 题目:判断输出结果 int main() { const char* p1 "abcdef"; const char* p2 "…...
用路由器远程维护三菱PLC操作指南
用路由器远程维护三菱PLC操作指南...
FPGA面试题(7)
一.解释一下SPI的四种模式 01时钟极性CPOL空闲状态为低电平空闲状态为高电平时钟相位CPHA在第一个跳变沿采样在第二个跳变沿采样 模式CPOLCPHA描述模式000sclk上升沿采样,sclk下降沿发送模式101sclk上升沿发送,sclk下降沿采样模式210sclk上升沿发送&…...
Python接口自动化测试之【测试函数、测试类/测试方法的封装】
前言 在pythonpytest 接口自动化系列中,我之前的文章基本都没有将代码进行封装,但实际编写自动化测试脚本中,我们都需要将测试代码进行封装,才能被测试框架识别执行。 例如单个接口的请求代码如下: import requests…...
ROS仿真软件Turtlebot-Gazebo的安装使用以及错误处理[机器人避障]
很多时候由于机器人价格比较贵,而且会因为环境因素、操作失误或者摔坏等,所以我们可以先在仿真软件上做测试,也可以避免这些问题,虽然没有那么真实感,可毕竟是免费的嘛。我们可以在这些仿真的机器人身上去学习如何控制…...
把excel文件内容转化为json文件
js如何把excel文件转化为json文件呢?可以通过xlsx还有循环遍历来做 第一步:安装xlsx包 npm install xlsx这里我需要转化为这种类型 {key:value,key:value,key:value, }如果需要转化为其他格式,到时候需要在循环遍历的时候灵活运用 上代码…...
前端 - 将非 jpeg 格式图片转为 jpeg 格式、压缩图片
目录 将非 jpeg 格式图片转为 jpeg 格式压缩图片使用 将非 jpeg 格式图片转为 jpeg 格式 /common/compressImage/convertImage // 思路是创建一个图片,将file等于这个图片,然后创建一个canvas图层 ,将canvas等比例缩放, //然后用…...
随着 ChatGPT 凭借 GPT-4V(ision) 获得关注,多模态 AI 不断发展
原创 | 文 BFT机器人 在不断努力让人工智能更像人类的过程中,OpenAI的GPT模型不断突破界限GPT-4现在能够接受文本和图像的提示。 生成式人工智能中的多模态表示模型根据输入生成文本、图像或音频等各种输出的能力。这些模型经过特定数据的训练,学习底层模…...
Zookeeper-JavaApI操作
JavaApI操作 JavaApI操作1) Curator 介绍2) Curator API 常用操作a) 建立连接与CRUD基本操作b) Watch事件监听c) 分布式锁c.1) 介绍c.2) Zookeeper分布式锁原理c.3) 案例:模拟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指定路由前缀: const router new VueRouter({mode: history,base: /concert, //指定路由前缀// base: process.env.BASE_…...
[vxe-table] 合并行后滚动错位
使用vxe-table的属性:span-method合并行,之后下拉后会错位 原因:缺少配置 scroll-y"{enabled: false}"参考: vxe-table合并行后错位...
动态规划:05不同路径
动态规划:05不同路径 62. 不同路径 五部曲 确定dp数组含义:到达第i,j位置的路径条数为d[i][j] 确定递归公式:d[i][j]d[i-1][j]d[i][j-1] 我们发现,想要到d[i][j],只能从d[i-1][j]或者d[i][j-1]达到 dp数…...
html与css知识点
html 元素分类 块级元素 1.独占一行,宽度为父元素宽度的100% 2.可以设置宽高 常见块级元素 h1~h6 div ul ol li dl dt dd table form header footer section nav article aside 行内元素 1.一行显示多个 2.不能设置宽高,宽高由元素内容撑开 常见行内…...
spring boot simple类型cache使用
注意:这里用的不是 redis 的缓存,simple 的缓存默认用的是 java 的 ConcurrentHashMap, 单纯的 simple 缓存,只需要引入下面的 pom 依赖即可: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() 函数释放的内存。如果新大小为零,则返回的值取决于库的实现。它可能会也可能…...
【Go】gin框架生成压缩包与下载文件
在没有加入下面这串代码之前,下载的压缩包一直为空。遂debug了两个小时。。。 可以在服务端本地创建压缩包。单独将服务端本地的压缩包发送给客户端也是没问题的。但是两个合起来,客户端接收到的压缩包内容就为空了。 期间也尝试了 zipFile.Close() zipW…...
iOS 面试题以及自我理解答案
1、简述push原理,push的证书和其他的有什么不一样? 第 一阶段:BeejiveIM服务器把要发送的消息、目的iPhone的标识打包,发给APNS。 第二阶段:APNS在自身的已注册Push服务 的iPhone列表中,查找有相应标识的iP…...
vue实现自定义滚动条
vue实现自定义滚动条 具体效果如下,这边我用的rem单位,比例是1:40, 先写下页面布局,把原生的滚动条给隐藏掉,给自定义的滑块增加transition: marginLeft 1s linear;可以使左边距过度的更顺滑 .top-box-2::-webkit-scr…...
基于Qt C++的工具箱项目源码,含命令行工具、桌面宠物、文献翻译、文件处理工具、医学图像浏览器、插件市场、设置扩展等工具
一、介绍 1. 基本信息 完整代码下载地址:基于Qt C的工具箱项目源码 TBox是一款基于Qt C的工具箱。用户可以自行选择安装所需的工具(以插件的形式),将TBox打造成专属于自己的效率软件。TBox基本界面展示如下: 2. 使用…...
云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...
在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能
下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能,包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...
多场景 OkHttpClient 管理器 - Android 网络通信解决方案
下面是一个完整的 Android 实现,展示如何创建和管理多个 OkHttpClient 实例,分别用于长连接、普通 HTTP 请求和文件下载场景。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas…...
Cesium1.95中高性能加载1500个点
一、基本方式: 图标使用.png比.svg性能要好 <template><div id"cesiumContainer"></div><div class"toolbar"><button id"resetButton">重新生成点</button><span id"countDisplay&qu…...
Linux-07 ubuntu 的 chrome 启动不了
文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了,报错如下四、启动不了,解决如下 总结 问题原因 在应用中可以看到chrome,但是打不开(说明:原来的ubuntu系统出问题了,这个是备用的硬盘&a…...
CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云
目前已有本地上传、阿里云OSS上传、腾讯云COS上传、七牛云上传扩展 扩展入口文件 文件目录 crmeb\services\upload\Upload.php namespace crmeb\services\upload;use crmeb\basic\BaseManager; use think\facade\Config;/*** Class Upload* package crmeb\services\upload* …...
汇编常见指令
汇编常见指令 一、数据传送指令 指令功能示例说明MOV数据传送MOV EAX, 10将立即数 10 送入 EAXMOV [EBX], EAX将 EAX 值存入 EBX 指向的内存LEA加载有效地址LEA EAX, [EBX4]将 EBX4 的地址存入 EAX(不访问内存)XCHG交换数据XCHG EAX, EBX交换 EAX 和 EB…...
管理学院权限管理系统开发总结
文章目录 🎓 管理学院权限管理系统开发总结 - 现代化Web应用实践之路📝 项目概述🏗️ 技术架构设计后端技术栈前端技术栈 💡 核心功能特性1. 用户管理模块2. 权限管理系统3. 统计报表功能4. 用户体验优化 🗄️ 数据库设…...
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要: 近期,在使用较新版本的OpenSSH客户端连接老旧SSH服务器时,会遇到 "no matching key exchange method found", "n…...
基于Springboot+Vue的办公管理系统
角色: 管理员、员工 技术: 后端: SpringBoot, Vue2, MySQL, Mybatis-Plus 前端: Vue2, Element-UI, Axios, Echarts, Vue-Router 核心功能: 该办公管理系统是一个综合性的企业内部管理平台,旨在提升企业运营效率和员工管理水…...
