03_Redis

news2025/1/13 19:49:28

文章目录

  • Redis
    • 介绍
    • 安装及使用
    • redis的核心配置
    • 数据结构
      • 常用命令
      • string
      • list
      • set
      • hash
      • zset(sortedset)
    • 内存淘汰策略
    • Redis的Java客户端
      • Jedis
      • Redisson

Redis

介绍

  • Redis是一个NoSQL数据库。
    • NoSQL: not only SQL。表示非关系型数据库(不支持SQL标准语法)。
  • 特点
    • C语言编写的
    • 开源的(https://github.com/redis)
    • 可基于内存:是把数据存在到内存上的
    • 可持久化:可以把内存里面的数据持久化到磁盘(为了实现数据恢复)
    • key-value:数据在内存中是以键值对的方式来存储的
    • 支持网络:客户端是通过网络连接服务端的
    • 支持多种语言:可以在各种语言的代码中操作Redis

安装及使用

  • 核心文件
    在这里插入图片描述
  • 启动
    • 启动服务器
      在这里插入图片描述
    • 启动客户端
      在这里插入图片描述
  • 在Linux系统中使用及安装
    在这里插入图片描述

redis的核心配置

  1. 常规配置
# 表示redis服务端是不是以守护进程(后台进程)的方式运行
daemonize no

# 客户端和服务端之间建立连接,假如超过多长时间没有进行通信那么就断开连接
# 0表示不关闭连接
timeout 0

# 端口号(一般不用去改)
port 6379

# 绑定的主机地址
bind 127.0.0.1
# 所有人都可以连接
# bind 0.0.0.0

# 日志级别
loglevel notice

# 数据库的数量设置
databases 16

# 密码设置
requirepass 123456
  1. 持久化配置
    • RDB
      • RDB是指Redis通过内存快照的形式来持久化内存中的数据到磁盘中。
        • 快照:其实就是一种内存技术,就可以像对内存进行拍照一样,保存内存当时的状态。
          • 快照的速度很快
          • 快照保存的一种数据的状态,占用的磁盘空间比较小
          • 快照会保存完整的数据
      • RDB是Redis默认的持久化策略,没有提供开关关闭。
    # 内存快照保存文件的位置
    dir D:\tmp
    
    # 内存快照保存文件的名字
    dbfilename dump.rdb
    
    
    # 快照触发的策略
    save <seconds> <changes>
    # 在多少秒之后,检查有多少次改变,如果达到设置的条件,那么就触发持久化
    save 900 1
    save 300 10
    save 60 10000
    
    • 总结:
      1. RDB每次保存的是触发RDB时刻的完整的数据
      2. RDB可能丢失数据,可能会丢失上一次持久化之后所有写入的数据
      3. RDB保存数据的速度很快,还原数据也很快
    • AOF
      • Append only file。AOF这种持久化的机制是通过追加(写操作命令)日志文件的方式来保存数据的
        • AOF会把用户输入的每一个写入命令保存到文件中,后续恢复数据的时候可以通过执行这个文件中的所有的命令来恢复数据。
      # 总开关
      # AOF默认是关闭的
      appendonly no
      
      # 保存文件的路径
      # 配置和RDB是同一个配置
      dir D:\tmp
      
      # 保存文件的名字
      appendfilename "appendonly.aof"
      
      # 保存的策略
      
      # 每收到一条写入的命令,就把命令保存到文件中
      # appendfsync always
      
      # 每秒保存一次(推荐使用的)
      appendfsync everysec
      
      # 依赖于操作系统的策略
      # appendfsync no
      
    • AOF持久化机制的总结:
      1. AOF可以做到不丢失数据(仅限于appendfsync always
      2. AOF保存数据生成的文件会越来越大,占用磁盘空间比较大
      3. AOF还原数据要通过 执行文件中的所有的命令来还原数据,还原数据比较慢
  • AOF和RDB是可以同时运行的。
    • 当两种机制都开启的时候,恢复数据的时候,优先从AOF生成的文件来恢复数据

数据结构

  • redis存储数据,支持五种数据结构
    • stringlisthashsetzset(sortedset)

常用命令

# 切换数据库(index从0开始)
select index

# 认证密码
auth password

# 搜索key (pattern 是一个正则表达式)
keys pattern
# 常用的是:keys * (查看所有的key)

# 清空数据库(删库)
# 清空所有的数据库(16个)
flushall

# 清空当前的数据库
flushdb

string

  • string数据结构是Redis中最基本的数据结构,包含 (String + 数字类型)
    在这里插入图片描述
# 设置一个键值对(如果key存在,会覆盖)
set key value

# 获取一个键值对的值
get key

# 批量的设置键值对
mset key1 value1 key2 value2 ...

# 批量的获取键值对
mget key1 key2 key3 ...

# 给指定的key的value +1 value必须得是一个数值
incr key

# 给指定的key增加指定的步长
incrby key increment

# 给指定的key的value -1
decr key

# 给指定的key减去指定的步长
decrby key decrement

# 设置一个key-value,并且指定过期时间
setex key seconds value

# set not exists,设置一个键值对,不会覆盖原来的值
# 当key不存在的时候,再去设值,不会覆盖原来的值
setnx key value

list

  • list的本质是一个双向链表。Redis支持用户从list的两端推入或者是弹出元素。
    • 可重复
    • 有序
      在这里插入图片描述
# 从队列的左端推入元素(当list不存在的时候,会自动创建一个新的list,然后来推入)
lpush key value1 value2 ...

# 从队列的左端弹出一个元素
lpop key

# 从队列的右端推入元素
rpush key value1 value2 ...

# 从队列的右端弹出一个元素
rpop key

# 查看链表的元素数量
llen key

# 查看某一个范围内的元素(start、stop指元素的下标,最左边的元素下标为0)
lrange key start stop

# 求指定下标的元素值
lindex key index

# 插入一个元素(在指定的元素pivot 前面或者是后面插入一个指定的元素 value )
# 如果指定的元素pivot有重复,那么就会在第一个值前面或者是后面插入
linsert key before|after pivot value

# 正常的从左端推入,当list存在的时候才会生效
lpushx key value

# 修改指定位置元素的值
lset key index value

# 删除前几个指定的元素
lrem key count value
  • 应用场景:
    • 消息队列
    • 最新动态(消息)排行榜

set

  • set是无序的集合
    1. 无序
    2. 不可重复
      在这里插入图片描述
# 往无序集合中添加元素
sadd key member1 member2 ...

# 查看无序集合中元素的个数
scard key

# 查看无序集合中所有的元素
smembers

# 判断某个元素在不在指定的集合中
sismember key member

# 随机弹出一个元素(取出并删除)
spop key [count]

# 随机从集合中取出一个元素的值(取出不删除)
srandmember key [count]

# 求交集
sinter key1 key2 ...

# 求出交集并保存
sinterstore destination key1 key2 ...

# 求并集
sunion key1 key2 ...

# 求出并集并保存
sunionstore destination key1 key2 ...

# 求差集
sdiff key1 key2 ...

# 求出差集并保存
sdiffstore destination key1 key2 ...

# 移动元素
smove source destination  member

# 删除元素
srem key member1 member2 ...
  • 应用场景:
    1. 求共同好友
    2. 好友推荐

hash

  • hash叫做二维表,类似于map。
  • hash这种数据结构可以看作是一个map,可以存储多个键值对。
    在这里插入图片描述
# 设置一个键值对
hset key field value

# 获取指定二维表中field的值
hget key field

# 设置多个键值对
hmset key field1 value1 field2 value2 ...

# 获取多个键值对的值
hmget key field1 field2 ...

# 判断二维表中有没有指定的field
hexists key field

# 获取二维表中所有的键值对
hgetall key

# 获取二维表中所有的键
hkeys key

# 获取二维表中所有的值
hvals key

# 求出二维表中 键值对的个数
hlen key

# 给键值对的值 增加指定的长度
hincrby key field increment

# 设置值,不覆盖
hsetnx key field value
  • 应用场景:
    • hash这种数据结构天然的适合存储对象,field存对象的成员变量名,value存成员变量对应的值
    • 存储商城中的购物车

zset(sortedset)

  • 有序的集合
    在这里插入图片描述
    • 有序集合的最大特点是:可以任意的取出有序集合中指定排名区间内的成员、以及指定分数区间内的成员
# 往有序集合中添加成员一级他的分数(注意:分数在前,名字在后)
zadd key score1 member1 score2 member2 ...

# 计算集合中元素的总个数
zcard key

# 求指定分数区间内成员的个数(分数是闭区间)
zcount key min max

# 求出指定成员的分数
zscore key member

# 给指定的成员增加分数
zincrby key score member

# 求出指定排名区间内的成员(排名从0开始,默认按照分数的升序排列)
zrange key start stop [withscores]

# 求出指定排名区间内的成员(排名从0开始,默认按照分数降序排列)
zrevrange key start stop [withscores]

# 求指定分数区间内的成员-按照分数的升序排列
zrangebyscore key min max [withscores]

# 求指定分数区间内的成员-按照分数的降序排列
zrevrangebyscore key max min [withscores]

# 求出指定成员的排名(按照分数的升序排名)
zrank key member

# 求出指定成员的排名(按照分数的降序排名)
zrevrank key member

# 删除指定的成员
zrem key member1 member2 ...

# 删除指定排名区间内的所有成员
zremrangebyrank key start stop [withscores]

# 删除指定分数区间内的所有成员
zremrangebyscore key min max [withscores]
  • 应用场景:
    1. 游戏中积分"排行榜"

内存淘汰策略

  • Redis是一个基于内存来存储的数据库,而内存资源是十分宝贵且有限的。那么当内存满了之后,Redis又需要存储新的数据的时候,Redis会触发内存淘汰策略,来淘汰老的数据,保证写入的成功。
  • 分类:
    • volatile-lru(least recent used)
      • 从已经设置了过期时间的数据集中,选择最近最少使用的数据进行淘汰
      • 比较合理的,但是比较慢
    • volatile-lfu
      • 从已经设置了过期时间的数据集中,选择一段时间内使用最少的key进行淘汰
    • volatile-random
      • 从已经设置了过期时间的数据集中,随机选择数据进行淘汰
      • 效率最高的
    • volatile-ttl
      • 从已经设置了过期时间的数据集中,选择最近将要过期的数据进行淘汰
    • allkeys-lru
      • 从所有的数据集中,选择最近最少使用的数据进行淘汰
    • alleys-random
      • 从所有的数据集中,随机选择数据进行淘汰
    • allkeys-lfu
      • 从所有的数据集中,选择一段时间内使用最少的key进行淘汰
    • no-evication
      • 禁止淘汰数据,如果有新的数据需要写入,那么就直接报错
  • 效率的角度出发:allkeys-random
    • 优先保证淘汰的效率
  • 合理性的角度从出发:volatile-lru

MySQL:

  1. 用户敏感的
  2. 访问量没那么大的

Redis:

  1. 用户不敏感的
  2. 访问量大的

Redis的Java客户端

Jedis

  • 全称叫做Java for Redis,使用非常简单,因为Jedis的每一个方法都和Redis的相关的命令名字是一致的。
  • 步骤
    • 导包
    <dependency>
    	<groupId>redis.clients</groupId>
    	<artifactId>jedis</artifactId>
    	<version>2.9.0</version>
    </dependency>
    
    • 配置
      • Jedis不需要任何配置
    • 使用
     // 1. 创建一个Jedis对象
        	Jedis jedis = new Jedis("localhost",6379);
    
     // 2. 认证密码
     		jedis.auth("123456");
    
     // 3. 操作
    		jedis.set("nickname", ls);
    		String nickname = jedis.get("nickname");
    		System.out.println(nickname);
    
    //        jedis.hset()
    //        jedis.rpush()
    //        jedis.sismember()
    //        jedis.zrank()
    //        jedis.zrevrank()
    

Redisson

  • 和Jedis不同,Redisson不仅仅实现了我们前面所学习过得所有的Redis命令对应的功能,它自己对Redis的功能做了很多的封装,提供了很多更为好用,更为强大的功能,比如基于Redis实现的分布式锁等等。
  • 步骤
    • 导包
    <dependencies>
        <dependency>
                <groupId>org.redisson</groupId>
                <artifactId>redisson</artifactId>
                <version>3.11.1</version>
        </dependency>
    </dependencies>
    
    • 首先构造出一个RedssonClient对象
    // 1. new 出一个config对象
         Config config = new Config();
         
    // 2. 配置Config对象
        SingleServerConfig serverConfig = config.useSingleServer()
                // 这里设置访问Redis的地址
                .setAddress("redis://localhost:6379")
                .setPassword("123456");
    
        // 设置序列化方式,使用jackson实现序列化和反序列化
        config.setCodec(new JsonJacksonCodec());
    
    // 3. 创建redis客户端 该对象在创建的时候,就会像redis-server发起连接请求
        RedissonClient redissonClient = Redisson.create(config);
    
    • 创建好RedissonClient对象之后,我们就可以基于ReidssonClient对象实现对Redis中5种基本数据类型的访问

eg:

/*
       该方法主要演示对于Redis,string类型数据的访问
   
   */ 
   private static void string(RedissonClient redissonClient) {
		/* 
		     1. number表示String类型的值对应的Redis中的key
		     2. 通过redissonClient获取存放key对应值的Bucket桶
		     3. 桶中放的就是key对应的Redis中的string类型的值
		     4. 对于桶的基本操作就是get/set,获取桶中的值/设置桶中的值
		     5. 对桶中值的操作都相当于是对Redis中key对应的string类型的值的操作
		 
         */
        RBucket<Integer> bucket = redissonClient.getBucket("number");
        bucket.set(0);

        // 获取对应的String数据类型的值
       Integer result = bucket.get();
        System.out.println(result);
       
        // 获取obj对应的存放String类型值的Bucket桶(这里其实对象被转化成了json字符串)
        RBucket<Person> personBucket = redissonClient.getBucket("obj");
        Person person = new Person();
        person.setName("ls");
        // 向桶中放入对象
        personBucket.set(person);
        
        // 从桶中获取对象
        Person newPerson = personBucket.get();
        System.out.println(newPerson.getName());
       
       
       
    }
    private static void list(RedissonClient redissonClient) {
        
        /*
            1. 调用redissonClient的getList方法,根据指定的key获取List类型的值
            2. 对于我们而言List类型的值就相当于内存中的一个List,所以之前怎么访问List,现在完全一样
            3. List中可以放基本数据类型及其包装类的值,也可以放对象
            4. 如果要修改Redis中List数据类型中的元素的值,还得把修改后的元素重新调用add方法
               添加到List才行
        */
        List<Person> list = redissonClient.getList("listKey");
        
        // ...

    }
    private static void set(RedissonClient redissonClient) {
        /*
            1. 调用redissonClient的getList方法,根据指定的key获取Set类型的值
            2. 对于我们而言List类型的值就相当于内存中的一个Set,所以之前怎么访问Set,现在完全一样
            3. Set中可以放基本数据类型及其包装类的值,也可以放对象
            4. 因为Set无序,所以仍然和之前一样,可以用迭代器或者stream流来访问
        */
        Set<String> set = redissonClient.getSet("setKey");
        set.add("setValue");

        Iterator<String> iterator = set.iterator();
        while (iterator.hasNext()) {
            String next = iterator.next();
            System.out.println(next);
        }
    }
     private static void sortedSet(RedissonClient redissonClient) {
        /*
           1. 调用RedissonClient的getScoredSortedSet获取指定key对应的一个SortedSet
           2. Redisson用RScoredSortedSet对象表示一个SortedSet,该类所持有的泛型表示SortSet中元素对
              应的Java类型
           
           3. RScoredSortedSet中的每一个元素都绑定分数,所以添加的时候既要添加元素还要添加元素的score
           4. 可以获取元素的分数,排名...
           5. RScoredSortedSet中也可以放Java对象
           
        */
        RScoredSortedSet<String> sortedSet
                = redissonClient.getScoredSortedSet("sortedKey");
​
        sortedSet.add(1.0, "zs");
        sortedSet.add(2.0, "lisi");Double score = sortedSet.getScore("zs");
        System.out.println(score);
        Integer rank = sortedSet.rank("zs");
        System.out.println(rank);
    }
   private static void map(RedissonClient redissonClient) {

        /*
            1. 在redis中获取名为mapKey的名称的hash数据结构的值
            2. 获取到的是一个Map,就可以把它当做内存中的一个Map,所以之前怎么用Map现在还是一样
            3. Map中的key为String类型,Value可以是基本数据类型及其包装类的值,也可以是对象
            4. 如果要修改Redis中hash数据类型中的元素的值,还得把修改后的元素重新调用Map的put方法
               添加到Map中才行
        
        */ 
        Map<String, String> map = redissonClient.getMap("mapKey");

        //         "field"      "value"
        // 添加
        map.put("mapField", "mapValue");
        // 修改
        map.put("mapField", "v1");

       //获取
        String mapField = map.get("mapField");
        System.out.println(mapField);
       //删除
       map.remove("mapField");

    }

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

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

相关文章

大模型_DISC-MedLLM基于Baichuan-13B-Base医疗健康对话

文章目录 DISC-MedLLM介绍概述数据集部署推理流程 DISC-MedLLM 介绍 DISC-MedLLM 是一个专门针对医疗健康对话式场景而设计的医疗领域大模型&#xff0c;由复旦大学数据智能与社会计算实验室 (Fudan-DISC) 开发并开源。 该项目包含下列开源资源: DISC-Med-SFT 数据集 (不包…

视频降噪算法 Meshflow 介绍

介绍 Meshflow 视频降噪算法来自于 2017 年电子科技大学一篇高质量论文。 该论文提出了一个新的运动模型MeshFlow&#xff0c;它是一个空间平滑的稀疏运动场 (spatially smooth sparse motion field)&#xff0c;其运动矢量 (motion vectors) 仅在网格顶点 (mesh vertexes) 处…

创造未来知识管理新篇章:Ollama与AnythingLLM联手打造个人与企业的安全知识库!

一 Ollama 1.1 简介 Ollama是一个开源的大型语言模型服务工具,它帮助用户快速在本地运行大模型。通过简单的安装指令,用户可以执行一条命令就在本地运行开源大型语言模型,如Llama 2。Ollama极大地简化了在Docker容器内部署和管理LLM的过程,使得用户能够快速地在本地运行大…

(论文阅读-多目标优化器)Multi-Objective Parametric Query Optimization

目录 摘要 一、简介 1.1 State-of-the-Art 1.2 贡献和大纲 二、定义 三、相关工作 四、问题分析 4.1 分析 4.2 算法设计影响 五、通用算法 5.1 算法概述 5.2 完备性证明 六、分段线性代价函数算法 6.1 数据结构 6.2 基本运算实现 6.3 复杂度分析 七、实验评估 …

02 Activiti 7:环境

02 Activiti 7&#xff1a;环境 1. 开发环境2. 流程设计器2.1. 在线安装2.2. 离线安装2.3. 中文乱码 3. 数据库 1. 开发环境 这是我本地开发环境 软件版本Jdk17Mysql8.0.36tomcat10.1.23IDEA2024.1Activiti7.0 2. 流程设计器 2.1. 在线安装 在 Plugins 搜索 activiti &…

【stm32笔记】DSP库调用

参考&#xff1a;DSP库调用 , __CC_ARM,__TARGET_FPU_VFP, __FPU_PRESENT1U, ARM_MATH_CM4把需要的库复制出来单独用&#xff0c;方便移植

基于java的CRM客户关系管理系统的设计与实现(论文 + 源码 )

【免费】基于Java的CRM客户关系管理系统的设计和实现.zip资源-CSDN文库https://download.csdn.net/download/JW_559/89273409 基于Java的CRM客户关系管理系统的设计与实现 摘 要 随着互联网的高速发展&#xff0c;市场经济的信息化&#xff0c;让企业之间的竞争变得&#xff0…

ssh远程免密登录

ssh远程连接分为五个阶段 版本号协商阶段密钥和算法协商阶段认证阶段会话请求阶段交互会话阶段而上图的SessionKey即是在阶段2:密钥和算法协商阶段,服务器端和客户端利用DH交换(Diffie-Hellman Exchange)算法、主机密钥对等参数,生成的会话密钥 远程免密登录需要在客户端生…

VTK —— 二、教程七 - 对点云进行操作(按下r键切换选取或观察模式)(附完整源码)

代码效果 本代码编译运行均在如下链接文章生成的库执行成功&#xff0c;若无VTK库则请先参考如下链接编译vtk源码&#xff1a; VTK —— 一、Windows10下编译VTK源码&#xff0c;并用Vs2017代码测试&#xff08;附编译流程、附编译好的库、vtk测试源码&#xff09; 教程描述 本…

数组练习题

1.打印X图案 if ((i j) ||( i j n - 1)) 循环打印了一个行和列相同的数组 当ij的时候 打印正斜线 ijn-1的时候打印反斜线 int main() {int n 0;while (scanf("%d", &n) ! EOF){for (int i 0; i < n; i) //外循环为行{for (int j 0; j < n; j) …

ROS机器人入门:机器人系统仿真【学习记录】——2

承接上一篇博客&#xff1a; ROS机器人入门&#xff1a;机器人系统仿真【学习记录】——1-CSDN博客 我们先前结束了&#xff08;上一篇博客中&#xff09;&#xff1a; 1. 概述 2. URDF集成Rviz基本流程 3. URDF语法详解 4. URDF优化_xacro 下面让我们继续学习ROS机器人…

Sentinel流量防卫兵

1、分布式服务遇到的问题 服务可用性问题 服务可用性场景 服务雪崩效应 因服务提供者的不可用导致服务调用者的不可用,并将不可用逐渐放大的过程&#xff0c;就叫服务雪崩效应导致服务不可用的原因&#xff1a; 在服务提供者不可用的时候&#xff0c;会出现大量重试的情况&…

LeetCode 226.翻转二叉树(全网最多的解法)

LeetCode 226.翻转二叉树 1、题目 题目链接&#xff1a;226. 翻转二叉树 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 示例 1&#xff1a; 输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xff1a;[4,7,2,9,6,3,1]示例 2&#…

有什么好用的思维导图软件?6个软件教你快速进行思维导图的制作

有什么好用的思维导图软件&#xff1f;6个软件教你快速进行思维导图的制作 以下是六款常用且功能强大的思维导图软件&#xff0c;它们可以帮助您快速制作思维导图&#xff1a; 迅捷画图: 迅捷画图是一款在线思维导图工具&#xff0c;具有直观易用的界面和丰富的功能。用户可…

无人机反制:雷达探测+信号干扰器技术详解

固定翼无人机、旋翼无人机等&#xff0c;可折叠式无机、DIY无人机等。黑飞&#xff0c;监管困难给航空业带来了诸多隐患&#xff1b;给恐怖袭击及间谍侦察带来新的方式、引发了各国地区政府的忧虑&#xff0c;在中国存在的问题更加严峻。 反无人飞行器防御系统(AUDS)&#xff0…

ElasticSearch 与 OpenSearch:拉开性能差距

Elasticsearch 与 OpenSearch&#xff1a;扩大性能差距 对于任何依赖快速、准确搜索数据的组织来说&#xff0c;强大、快速且高效的搜索引擎是至关重要的元素。对于开发人员和架构师来说&#xff0c;选择正确的搜索平台可以极大地影响您的组织提供快速且相关结果的能力。在我们…

小红书图片文案编辑生成图文工具

在小红书上&#xff0c;种草图文的变现通常涉及以下几个步骤&#xff1a; 1. **建立影响力**&#xff1a;首先&#xff0c;你需要通过持续发布高质量的内容&#xff0c;积累粉丝和影响力。你的内容应该围绕特定的领域或主题&#xff0c;比如时尚、美妆、美食或旅行&#xff0c…

JavaScript中的事件模型

JavaScript中的事件模型分为&#xff1a;事件和事件流、原始事件、标准事件和IE事件。 事件与事件流 JavaScript中的事件&#xff0c;可以理解为HTML文档或者浏览器中发生的一种交互操作&#xff0c;让网页有互动的功能。常见的事件就是加载事件、鼠标事件和自定义事件。 因…

一键安装Halo DB

说明 这里说的一键其实分了好几步&#xff0c;是我将安装步骤分解。你可以把它们放在一个shell中或者串起来就是一键了。 易景科技的数据库 羲和 &#xff08;Halo DB&#xff09; 我之前的一位朋友&#xff08;章晨曦&#xff09;创立的数据库公司。以前看他朋友圈说他做数…

【C语言刷题系列】移除元素

目录 一、问题描述 二、解题思路 三、源代码 个人主页&#xff1a; 倔强的石头的博客 系列专栏 &#xff1a;C语言指南 C语言刷题系列 一、问题描述 二、解题思路 在C语言中&#xff0c;原地移除数组中所有等于特定值的元素并返回新长度的问题可以通过双指针法…