字符串函数与内存函数讲解
文章目录
- 前言
- 一、字符串函数
- 1.求字符串长度
- strlen
- 2.长度不受限制的字符串函数
- (1)strcpy
- (2)strcat
- (3)strcmp
- 3.长度受限制的字符串函数
- (1)strncpy
- (2)strncat
- (3)strncmp
- 4.字符串查找
- (1)strstr
- (2)strtok
- 5.错误信息报告
- (1)strerror
- (2)perror
- 二、内存函数
- 1.memcpy
- 2.memmove
- 3.memset
- 4.memcmp
前言
一、字符串函数
1.求字符串长度
strlen
1、功能:求字符串长度
2、使用:
(1)介绍:
说明:
a.返回类型是size_t,也就是无符号整形(只有正数没有负数)
b.参数是char* 类型;加入const修饰是为了防止对str中存放的内容进行修改
c.字符串已经 ‘\0’ 作为结束标志,strlen函数返回的是在字符串中 ‘\0’ 前面出现的字符个数(不包含 ‘\0’ )
(2)头文件:<string.h>
(3)举例:
a.
int main() {char arr1[] = "abcdefg";size_t len1 = strlen(arr1);return 0;
}
解析:
(1)strlen函数做需要的参数是char* 类型,所以创建了一个char类型的数组
(2在不是sizeof(数组名)与 &数组名 的情况下,数组名代表数组首元素的地址,首元素地址的类型是char*
(3)strlen 函数的返回值是size_t类型,也就是无符号的整形,所以我们设置一个相应类型的值来接收它
b.
int main() {char* arr2 = "abcdef";size_t len2 = strlen(arr2);size_t len3 = strlen("abcdef");printf("%d %d\n",len2,len3);return 0;
}
结果:
解析:
这里的len2和len3的最后结果其实是一致的,因为len3中的字符串其实传输的也是首元素的地址,属于char*类型,与len2中的传输的值是一样的
c.
int main() {char* arr3 = "abc\0def";char* arr4 = "abcde\0f";size_t len3 = strlen(arr3);size_t len4 = strlen(arr4);printf("%d %d\n", len3, len4);return 0;
}
结果:
解析:
strlen函数返回的是在字符串中 ‘\0’ 前面出现的字符个数(不包含 ‘\0’ )
(4)注意事项:
a.参数指向的字符串必须要以 ‘\0’ 结束。
b.注意函数的返回值为size_t,是无符号的
3、模拟实现:
方法一:
size_t my_strlen(const char* str) {//计录字符串长度size_t count = 0;//当*str='\0'是停止while (*str) {count++;str++;}return count;
}int main() {char arr1[] = "abcdefg";size_t len1 = my_strlen(arr1);printf("%d\n",len1);return 0;
}
#emsp;方法二
//递归实现
size_t my_strlen(const char* str) {if (*str == '\0') {return 0;}//这里不能使用后置++,因为它是先使用后++return 1 + my_strlen(str+1);
}int main() {char arr1[] = "abcdefg";size_t len1 = my_strlen(arr1);printf("%d\n", len1);return 0;
}
方法三:
//指针实现
size_t my_strlen(const char* str) {//创建一个临时变量来接收strchar* p = str;//对临时变量进行操作更加安全while (*p != '\0') {p++;}//字符串中有几个字符,p就会往后移动几位return p - str;
}int main() {char arr1[] = "abcdefg";size_t len1 = my_strlen(arr1);printf("%d\n", len1);return 0;
}
2.长度不受限制的字符串函数
(1)strcpy
1、功能:字符串拷贝
2、使用:
(1)介绍:
说明:
a.参数有两个,都是char* 类型:拷贝源与目的地
b.返回值是char* 类型,返回目的地的地址
c.头文件:<string.h>
(2)注意:
a.源字符串必须以 ‘\0’ 结束,,因为它是拷贝结束的标志,没有的话会一直拷贝,会越界访问
b.会将源字符串中的 ‘\0’ 拷贝到目标空间。
c.目标空间必须足够大,以确保能存放源字符串。
d.目标空间必须可变。
(3)举例:
a.
int main() {char arr1[20];char arr2[] = "abcdef";printf("%s\n",arr1);strcpy(arr1,arr2);printf("%s\n",arr1);return 0;
}
结果:
解析:
未对arr1进行初始化化,所以刚开始赋予的是随机值;在strcpy函数后,为其拷贝了值
3、模拟实现
char* my_strcpy(char* dest,const char* src) {//设置一个指针来存储目的地的起始地址char* ret = dest;//设置断言,防止对空指针解引用assert(src && dest);//对dst赋值,当赋值'\0'后不满足条件,退出循环while (*dest++ = *src++) {;}return ret;
}int main() {char arr1[20];char arr2[] = "abcdef";my_strcpy(arr1,arr2);printf("%s\n",arr1);return 0;
}
(2)strcat
1、功能:字符串追加
2、使用:
(1)介绍:
说明:
a.参数有两个,char*类型:源和目的地
b.返回的是目的地的起始地址
c.本函数是寻找目的地中的’\0’,从’\0’处开始追加源中的字符,并将原来的’\0’替换,将自己的’\0’拷贝过去
(2)注意:
a.必须保证目标空间要足够大
b.目标空间中必须有\0(保证能找到目标空间的末尾)
c.原字符串也得有\0,在拷贝时将\0也拷过去
d.目标空间必须可以修改
(3)举例:
int main() {char arr1[20] = "abcd";char arr2[] = "efgh";strcat(arr1,arr2);printf("%s\n",arr1);return 0;
}
结果:
3、模拟实现
char* my_strcat(char* dest,const char* src) {char* ret = dest;assert(dest && src);while (*dest) {dest++;}while ((*dest++ = *src++)) {;}return ret;
}int main() {char arr1[20] = "abcd";char arr2[] = "efgh";my_strcat(arr1,arr2);printf("%s\n",arr1);return 0;
}
(3)strcmp
1、功能:字符串比较
2、使用:
(1)介绍:
说明:
a.参数有两个,是比较的两个数组
b.当字符串1>字符串2时,返回一个>0的数
当字符串1=字符串2,返回一个<0的数
当字符串1<字符串2时,返回一个<0的数
c.两字符串比较的其实是每个字符的ASCII码值
(2)注意:
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字
(3)举例:
int main() {char arr1[] = "abbc";char arr2[] = "abcd";int ret = strcmp(arr1,arr2);printf("%d\n",ret);return 0;
}
3、模拟实现
int my_strcmp(const char* arr1,const char* arr2) {assert(arr1 && arr2);while (*arr1 == *arr2) {arr1++;arr2++;if (*arr1 == '\0') {return 0;}}if (*arr1 > *arr2)return 1;if (*arr1 < *arr2)return -1;
}int main() {char arr1[] = "abbc";char arr2[] = "abcd";int ret = my_strcmp(arr1,arr2);printf("%d\n",ret);return 0;
}
3.长度受限制的字符串函数
(1)strncpy
1、功能:限制数量的字符串拷贝
2、使用:
(1)介绍:
说明:多了一个数量限制,其余的与函数strcpy一致
(2)注意:
a.当源字符串中的字符数没有达到参数的数量时,会在目的地中自动补’\0’,直到达到限定数量
b.目的地的大小应该比限定数量大,否则就会非法访问
(3)举例:
a.
int main() {char arr1[10];char arr2[] = "abcdefg";strncpy(arr1,arr2,10);printf("%s\n",arr1);return 0;
}
结果:
(2)strncat
1、功能:限制数量的字符串追加
2、使用:
(1)介绍:
说明:多了一个数量限制,其余与函数strcat一致
(2)注意:
与函数strcat一致
(3)举例:
a.
int main() {char arr1[20] = "bcc";char arr2[] = "abcdefg";strncat(arr1, arr2, 10);printf("%s\n", arr1);return 0;
}
结果:
(3)strncmp
1、功能:限制数量的字符串比较
2、使用:
(1)介绍:
(3)举例:
a.
int main() {char arr1[] = "abc";char arr2[] = "abcdefg";int ret = strncmp(arr1, arr2, 4);printf("%d\n", ret);return 0;
}
结果:
4.字符串查找
(1)strstr
1、功能:字符串查找
2、使用:
(1)介绍:
说明:
a.有两个参数都是char类型,在str1中查找是否有str2中的字符串
b.返回值是char 类型,返回的是str1中查找的字符串的首地址
(2)注意:
a.如果字符串中有两个查找的字符串,会默认返回第一个找到的字符串的首地址
b.查找不到时会返回Null值
c.查找过程中碰到’\0’就会停止
(3)举例:
a.
int main() {char arr1[] = "abccbcccf";char arr2[] = "bccc";char * ret = strstr(arr1, arr2);printf("%s\n", ret);return 0;
}
结果:
b.
int main() {char arr1[] = "abccbcccf";char arr2[] = "g";char * ret = strstr(arr1, arr2);printf("%s\n", ret);return 0;
}
结果:
c.
int main() {char arr1[] = "abc\0bcccf";char arr2[] = "bccc";char * ret = strstr(arr1, arr2);printf("%s\n", ret);return 0;
}
结果:
3、模拟实现
const char* my_strstr(const char* str1,const char* str2) {//创建一个临时变量作为查找元素时的定位符const char* p = str1;const char* s1;const char* s2;assert(str1 && str2);while (*p) {//每次都从p处开始比较s1 = p;//如果没有完全找到,就要重头开始找s2 = str2;//不相等或者任意一方为'\0'时停止while ((*s1 && *s2 && *s1 == *s2)) {s1++;s2++;}//判断是否全部找到if (*s2 == '\0') {return p;}p++;}return NULL;
}int main() {char arr1[] = "abccbcccf";char arr2[] = "bc";char * ret = my_strstr(arr1, arr2);printf("%s\n", ret);return 0;
}
(2)strtok
1、功能:字符串分隔
2、使用:
(1)介绍:
说明:
a.有两个参数,都是char类型,第一个是等待分割的字符串,第二个是分隔符
b.返回值是charl类型,返回分隔后的字符串的首地址
(2)注意:
a.每次调用只会对字符串进行一次分隔
b.函数strtok会记住上一次分隔的结束位置,从那个位置开始进行下一次分割,但此次不能为它传输新的字符串指针,只能传输分隔符
(3)举例:
a.
int main() {char arr1[] = "abc@de.fg@h";char* d = "@.";char* ret = strtok(arr1, d);printf("%s\n", ret);return 0;
}
结果:
b.
int main() {char arr1[] = "abc@de.fg@h";char* d = "@.";for (char* ret = strtok(arr1, d); ret != NULL; ret = strtok(NULL, d)) {printf("%s\n",ret);}return 0;
}
结果:
5.错误信息报告
(1)strerror
1、功能:错误信息反馈
2、使用:
(1)介绍:
a.头文件<errno.h>
b.参数是int类型,是错误所对应的错误码
c.返回值是char* 类型,返回错误码,所对应的错误信息
(2)注意:
a.当程序产生错误时,会自动将错误码放入错误信息errno中
(3)例子:
a.
int main() {for (int i = 0; i <= 10; i++) {printf("%d %s\n",i,strerror(i));}return 0;
}
结果:
b.
//打开文件
int main() {//打开成功返回一个FILE* 类型的指针,打开失败返回一个NULL指针FILE* pfile = fopen("add.txt","r");//产生错误的时候,会自动的将错误码放入错误信息errno中if (pfile == NULL) {printf("打开失败的原因是:%s\n",strerror(errno));}return 0;
}
结果:
(2)perror
1、功能:错误信息打印
2、使用:
(1)介绍:
说明:此处参数可传可不传,属于你的自定义信息,类似与printf中你输入的文字,它会默认将程序中的错误信息打印出来,你可以自由加一些自定义信息
(2)注意:
a.打印规则,先打印自定义信息,然后 “ :空格”,再打印错误信息
(3)实例:
int main() {FILE* pfile = fopen("add.txt", "r");if (pfile == NULL) {perror("打开失败的原因是");}return 0;
}
结果:
二、内存函数
内存函数与字符串函数最重要的区别是:内存函数适用于所有类型
1.memcpy
1、功能:内存拷贝
2、使用:
(1)介绍:
说明:
a.头文件:<string.h>
b.参数有三个,前两个是void* 类型的,是拷贝源于目的地;最后一个是拷贝的字节数
(2)注意:
a.传输的数字是字节数,而不是元素个数
b.函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
c.这个函数在遇到 ‘\0’ 的时候并不会停下来。
d.如果source和destination有任何的重叠,复制的结果都是未定义的。
(3)示例:
a.
int main() {int arr1[10] = {0};int arr2[] = { 1,2,3,4,5 };memcpy(arr1,arr2,20);return 0;
}
结果:
3、模拟实现
void* my_memcpy(void* dest,const void* src,size_t num) {void* ret = dest;assert(dest && src);while (num--) {*(char*)dest = *(char*)src;dest = (char*)dest + 1;src = (char*)src + 1;}return ret;
}int main() {int arr1[10] = { 0 };int arr2[] = { 1,2,3,4,5 };my_memcpy(arr1,arr2,20);return 0;
}
2.memmove
1、功能:内存移动
2、使用:
(1)介绍:
说明:
和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
如果源空间和目标空间出现重叠,就得使用memmove函数处理。
(2)注意:
a.在模拟实现中,起码要有两种情况
(3)示例:
a.
int main() {char arr1[] = "abcdefgh";memmove(arr1+2,arr1+3,4);printf("%s\n",arr1);return 0;
}
结果:
3、模拟实现:
void* my_memmove(void* dest,const void* src,size_t num) {void* ret = dest;assert(dest && src);//小于时,从后往前拷贝if (src < dest) {while (num--) {*((char*)dest+ num) = *((char*)src+num);}}//其他情况,从前往后拷贝else{while (num--) {*(char*)dest = *(char*)src;src = (char*)src + 1;dest = (char*)dest + 1;}}return ret;
}
3.memset
1、功能:内存设置
2、使用:
(1)介绍:
说明:以字节为单位设置值
(2)注意:
a.因为单位是字节,所以最适用于字符类型的数组
(3)示例:
a.
int main() {
char arr1[] = “hello world”;
memset(arr1+6, ‘a’, 5);
printf(“%s\n”,arr1);
}
结果:
4.memcmp
1、功能:内存比较
2、使用:
(1)介绍:
说明:比较两内存空间的前num个字节的内容
(2)注意:
第一个内存块大于第二个内存块,则返回大于0的数字
第一个内存块等于第二个内存块,则返回0
第一个内存块小于第二个内存块,则返回小于0的数字
(3)示例:
a.
int main() {int arr1[] = { 1,2,3,4,5 };int arr2[] = { 1,3,3,4,5 };int ret1 = memcmp(arr1,arr2,4);//小端存储int ret2 = memcmp(arr1,arr2,5);printf("%d %d\n",ret1,ret2);
}
结果:
相关文章:
字符串函数与内存函数讲解
文章目录 前言一、字符串函数1.求字符串长度strlen 2.长度不受限制的字符串函数(1)strcpy(2)strcat(3)strcmp 3.长度受限制的字符串函数(1)strncpy(2)strncat(3)strncmp 4.字符串查找(1)strstr(2)strtok 5.错误信息报告(1)strerror(2)perror 二、内存函数1.memcpy2.memmove3.me…...
c语言系统编程之多进程
程序与进程的区别? 程序是静态的未运行的二进制文件,存储在磁盘中 进程是已经运行的二进制文件,存储在内存中 进程的内存划分图有哪几部分? 堆(存储malloc和calloc出来的空间)、栈(局部变量…...
前端还是后端:探讨Web开发的两大街区
前端还是后端:探讨Web开发的两大街区 一、引言二、两者的对比分析技能要求和专业知识职责和工作内容项目类型和应用领域就业前景和市场需求 三、技能转换和跨领域工作四、全栈开发结语 一、引言 Web开发领域涉及到前端开发和后端开发这两个不同而又互为补充的领域。…...
JavaScript中如何确定this的值?如何指定this的值?
🎀JavaScript中的this 在绝大多数情况下,函数的调用方法决定了this的值(运行时绑定)。this不能在执行期间被赋值,并且在每次函数呗调用时this的值也可能会不同。 🍿如何确定this的值: 在非严格…...
ubuntu下源码编译方式安装opencv
基础条件 ubuntu 20.04 opencv 3.4.3 opencv 源码编译的安装步骤 第一步, 首先clone源码 git clone https://github.com/opencv/opencv.git第二步,依赖包,执行下面的命令 sudo apt-get install build-essential sudo apt-get install cmak…...
spring boot整合常用redis客户端(Jedis、Lettuce、RedisTemplate、Redisson)常见场景解决方案
Java操作redis有三种客户端供选择:Jedis、Lettuce、Redisson。 在实际项目中运用最多的客户端还是Redisson、RedisTemplate;其中RedisTemplate并非是一个新的redis客户端实现,RedisTemplate是Spring Data Redis中提供的封装好的redis操作模板…...
HarmonyOS之运行Hello World
目录 下载与安装DevEco Studio 配置环境 创建项目 认识DevEco Studio界面 运行Hello World 了解基本工程目录 工程级目录 模块级目录...
postgresql数据库|wal日志的开启以及如何管理
一, wal的基本概念 WAL即Write Ahead Log预写式日志,简称wal日志,相当于oracle中的redo日志。只是oracle中redo是固定几个redo日志文件,然后轮着切换去写入。pg中wal日志是动态切换,单个wal日志写满继续写下一个wal日志,连续不断生成wal日志。…...
小波变换学习笔记【1】
【声明】本博客为学习B站视频小波分解与重构所做笔记,供自己和大家查阅学习,想查看 up 原视频请移步 B 站,侵删。 1.1 小波变换的由来 傅里叶变换基本思想:将信号分解成一系列不同频率的连续正弦波的叠加。 其缺点是,…...
雷柏mv20鼠标使用体验
用了1年多,第一次用竖着的鼠标,现在已经很习惯了,感觉还不错。说说使用感受: 1、 仍然是长时间使用鼠标,但是很少出现手腕痛的情况,确实是有一定效果的。 2、使用场景是有限制的,我是配合笔记…...
【分布式云储存】Springboot微服务接入MinIO实现文件服务
文章目录 前言技术回顾准备工作申请accessKey\secretKey创建数据存储桶公共资源直接访问测试 接入springboot实现文件服务依赖引入配置文件MinIO配置MinIO工具类 OkHttpSSLSocketClient兼容ssl静态资源预览解决方案资源上传预览测试测试结果 前言 上篇博客我们介绍了分布式云存…...
机器人中的数值优化|【四】L-BFGS理论推导与延伸
机器人中的数值优化|【四】L-BFGS理论推导与延伸 往期内容回顾 机器人中的数值优化|【一】数值优化基础 机器人中的数值优化|【二】最速下降法,可行牛顿法的python实现,以Rosenbrock function为例 机器人中的数值优化|【三】无约束优化,拟牛…...
ThemeForest – Canvas 7.2.0 – 多用途 HTML5 模板
ThemeForest 上的 HTML 网站模板受到全球数百万客户的喜爱。与包含网站所有页面并允许您在 WP 仪表板中自定义字体和样式的 WordPress 主题不同,这些设计模板是用 HTML 构建的。您可以在 HTML 编辑器中编辑模板,但不能在 WordPress 上编辑模板࿰…...
本地部署 川虎 Chat
本地部署 川虎 Chat 1. 川虎 Chat 项目概述2. Github 地址3. 部署 川虎 Chat4. 配置 config.json5. 启动 川虎 Chat 1. 川虎 Chat 项目概述 为ChatGPT等多种LLM提供了一个轻快好用的Web图形界面和众多附加功能。 支持 GPT-4 基于文件问答 LLM本地部署 联网搜索 Agent 助理…...
IntelliJ IDEA 控制台中文乱码的四种解决方法
前言 IntelliJ IDEA 如果不进行配置的话,运行程序时控制台有时候会遇到中文乱码,中文乱码问题非常严重,甚至影响我们对信息的获取和程序的跟踪。开发体验非常不好。 本文中我总结出四点用于解决控制台中文乱码问题的方法,希望有助…...
23岁准备转行嵌入式
前端难找工作,而且感觉没有前景,我觉得我就算入行也不会干多久,软件开发让我感觉不到实在的东西。小时候喜欢去动手制作一些玩具,我对实在一些的东西感兴趣一些例如手表,小机器人等等一些。我有保持坚持学习下去的动力…...
http请求报错:406 Not Acceptable的解决办法
目录 应用场景 基本概念 解决方法 方法一: 方法二: 方法三: 应用场景 接口在返回结果集的时候出现了406的报错,但是返回String类型不会报错,正常返回。 基本概念 406 Not Acceptable是一个HTTP响应状态码&…...
信息化发展75
数字化治理 数字化治理通常指依托互联网、大数据、人工智能等技术和应用,创新社会治理方法与手段,优化社会治理模式,推进社会治理的科学化、精细化、高效化,助力社会治理现代化。数字化治理是数字经济的组成部分之一,…...
C++八股
1、简述一下C中的多态 在面向对象中,多态是指通过基类的指针或引用,在运行时动态调用实际绑定对象函数的行为,与之相对应的编译时绑定函数称为静态绑定。 静态多态 静态多态是编译器在编译期间完成的,编译器会根据实参类型来选择…...
Nat. Commun. | 大规模高分辨单光子成像
本文由论文作者团队(课题组)投稿 单光子雪崩二极管(Single Photon Avalanche Diode,简称SPAD)阵列因其极佳的单光子灵敏度而受到广泛关注,已广泛应用于量子通信与计算、荧光寿命成像、时间飞行成像等各个领域。与同样具有较高灵敏度的EMCCD和sCMOS相比,SPAD阵列能够在极…...
Android开源库
见:GitHub - eHackyd/Android_OpenSourceLibrary: Android开源库的学习笔记...
【小程序 - 基础】页面导航、页面事件、生命周期、WXS脚本_04
目录 一、页面导航 1. 什么是页面导航 2. 小程序中实现页面导航的两种方式 2.1 声明式导航 2.1.1 导航到 tabBar 页面 2.1.2 导航到非 tabBar 页面 2.1.3 后退导航 2.2 编程式导航 2.2.1 导航到 tabBar 页面 2.2.2 导航到非 tabBar 页面 2.2.3 后退导航 2.3. 导航…...
矩阵求导数
矩阵 A ∣ 1 2 1 2 − 1 3 ∣ , 计算 f ( x ) ∣ ∣ A x ∣ ∣ 2 ∣ ∣ x ∣ ∣ 2 的最大值。 矩阵A \begin {vmatrix} 1 & 2 & 1\\2 & -1 & 3 \end {vmatrix},计算f(x) \frac{||Ax||_2}{||x||_2}的最大值。 矩阵A 122−113 ,计算f(x)∣∣x∣∣2…...
竞赛 大数据疫情分析及可视化系统
文章目录 0 前言2 开发简介3 数据集4 实现技术4.1 系统架构4.2 开发环境4.3 疫情地图4.3.1 填充图(Choropleth maps)4.3.2 气泡图 4.4 全国疫情实时追踪4.6 其他页面 5 关键代码最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 大数据疫…...
数据结构--栈
线性表的定义 前面文章有讲过,线性表就是一次保存单个同类型元素,多个元素之间逻辑上连续 例子:数组,栈,队列,字符串 栈 1.1 栈和队列的特点 栈和队列都是操作受限的线性表。 前面学过的数组,…...
期权定价模型系列【7】:Barone-Adesi-Whaley定价模型
期权定价模型系列第7篇文章 1.前言 目前大连商品交易所、郑州商品交易所、以及上海期货交易所的所有商品期权都为美式期权,并且大商所的所有期权合约会根据BAW(Barone-Adesi-Whaley)美式期权定价模型计算新上市期权合约的挂牌基准价。 BAW模型(Barone-Adesi and W…...
【Axure高保真原型】3D圆柱图_中继器版
今天和大家分享3D圆柱图_中继器版的原型模板,图表在中继器表格里填写具体的数据,调整坐标系后,就可以根据表格数据自动生成对应高度的圆柱图,鼠标移入时,可以查看对应圆柱体的数据……具体效果可以打开下方原型地址体验…...
多个线程启动 ,等待全部执行完毕再搜集数据
前几天在公司的项目上有个同事使用了多线程统计数据,当时出现了一个用户一直使用服务器首次登录信息作为查询信息。找了半天才发现,线程池资源同步了。后面手动将数据set进去的。 等待线程全部执行完毕,这里使用的是减法计数器,也…...
【VIM】VIm-plug插件
如何查找需要的插件 https://github.com/mhinz/vim-startify https://github.com/vim-airline/vim-airline https://github.com/Yggdroot/indentLine github.com/w0ng/vim-hybrid github.com/altercationi/vim-colors-solarized guithub.com/morhetz/gruvbox github.com/sc…...
ssl证书 阿里的域名,腾讯云的证书
目录 1.腾讯云申请ssl免费证书 2.去阿里云进行解析 3.回到腾讯云 4.nginx的配置 说明:阿里云的免费证书用完了(每年可以申请20个),还有个项目要用证书,第三方的证书免费的都是90天的。看了下腾讯云业可以申请免费的…...
旅游网站ppt应做的内容/手机怎么建立网站
一、表的关系分析:用户和订单:一个用户可以有多个订单,但每个订单只能属于一个用户,所以是一对多的关系。商品和分类:一个产品只能有一种分类,而一个分类可以有多种产品,所以是多对一的关系。订…...
企业网站建站技术/谷歌浏览器下载手机版
加载是类加载过程的第一个阶段(需要区分类加载与加载).在加载阶段,虚拟机主要完成3件事 ——通过一个类的全限定名获取此类的二进制字节流——将这个字节流所代表的静态存储结构转化为方法区的运行时数据结构——在内存中生成一个代表这个类…...
武汉小程序开发制作/站长工具seo综合查询工具
场景: 我们现在有一个树状结构的数据,如下图: 大概的数据结构如下: const tree {value: 根节点,children: [{value: 学校,children: [{value: 学生,children: [{value: 年龄,children: [{value: 身高}]}]}......]}]}现在我们要…...
衢州建设职业学校网站/北京官网优化公司
今天早上在写一个.scala文件时,控制台一直出现这个错误。 原本以为这个错误是找不到URL地址,不能使用local[*]这种模式,后来发现这个错误的根本是在上一行,也就是: SparkContext: Error initializing SparkContext 原…...
wordpress只显示到菜单/如何查看一个网站的访问量
2019独角兽企业重金招聘Python工程师标准>>> #include <iostream> #include <cv.h> #include <highgui.h> using namespace std;/************************************* *目的:亮度变换(亮度增强或者亮度减弱)…...
成都微网站开发/策划推广活动方案
今天,刚好要写开源项目的后台数据了,所以学习了一下php的命名空间,收获多多,所以总结了一下这篇文章,好了,废话不多说,上代码吧我们该如何命名空间呢?<?php // 使用命名空间的关…...