7.23

本文详细介绍了C语言中的字符串基础知识,包括字符串的定义、存储形式、输入输出方法及缓冲区机制。此外,还列举了一些常用的字符串操作函数及其用法。

复习:
字符串: 
    由字符组成的串行结构,'\0'是它结束的标志
    存在形态:
        字符数组:栈内存 可以修改 要为'\0'预留数据
        字符串字面值:代码段 只读 修改就回产生段错误 末尾隐藏一个'\0'地址
        const char* str="hehe";
        sizeof("hehe") 结果是5  末尾有'\0'
        sizeof(str)    结果是4  str是指针

        一般使用字符串字面值给字符数组初始化
        char str[4] ="hehe";
        建议不设置数组长度
    输入:
        char str[256] ={};
        scanf("%s",str);    不能输入带空格的字符串
        gets(str)   可接空格,但不限制长度,有隐患
        fgets(str,size,stdin);  可设置最多接收size-1个字符(为\0预留位置),如果输入的字符不足size-1
        会把'\n'一起接收,如果超出就丢弃超出部分
    输出:
        printf("%s",str);
        puts(str);  会自动添加换行符

输出缓冲区:
    程序并不会立即把输出的数据显示到屏幕上,而是线存储在输出缓冲区中,当满足
    一定条件是才显示出来。
        1、遇到\n会被一起接收了
        2、程序结束
        3、遇到输入语句
        4、当缓冲区满4k时
        5、fflush(stdout)手动刷新

    缓冲区机制可以提高数据的读写速度,并且可以让低俗的输入输出设备与告诉的CPU之间协调工作

输入缓冲区:
    程序并不会立即获取屏幕上输入的数据,而是按下回车键后程序才从输入缓冲区读取数据

    1、当需要读取的是整型或者浮点型时,而输入缓冲区中的数据是字符或符号时,
    此时读取会失败,数据会残留在输入缓冲区中,就会影响接下来所有数据的读取

    2、fgets可以指定读取size-1个字符,如果有多余的会残留在输入缓冲区中,影响下一次输入

    3、当先输入整型、浮点型数据,再紧接着输入字符、字符串时,前一次残留的'\n'或空格,会影响字符、
    字符串的输入

    方法3: %c前面加空格
            scanf(" %c,&ch")

    解决2
        必须缺人输入缓冲区有垃圾数据时,才能去读取丢弃输入缓冲区的垃圾数据,否则程序会停下来等待
        缓冲区中有一个\n
            scanf("%*[^\n]");
                表示从缓冲区中接收任意字符并丢弃,只要不是\n就一直进行,遇到\n才停下
            scanf("%*c");
                丢弃任意字符,把\n丢掉
        方法二:
            借助缓冲区的欸之指针移动到缓冲区末尾,实现清理缓冲区的效果
            只能在Linux系统下使用
            stdin->_


字符串相关的常用操作:
    #include <string.h>
    size_t strlen(const char *s)
    功能:计算字符串长度,不包括'\0'
    注意:sizeof 和 strlen的区别

    int strcmp(const char *s1, const char *s2);
    功能:比较两个字符串大小

    char *strcpy(char *dest,const char *src,size_t n);
    功能:把src前n个字符拷贝给dest
    char *strcat(char *dest,const char *src,size_t n);
    功能:把src前n个字符追加到dest后面
     char *strcmp(char *dest,const char *src,size_t n);
    功能:比较前n个字符的大小
    

自己重写实现strlen\strcpy\strcat\strcmp

int atoi(const char *nptr);
功能:字符串转ing类型

char *strchr(const char *s,int c);
功能:查找s中是否有字符c
返回值:c在s中首次出现的位置,不存在返回NULL

int sprintf()


返回值:成功读取到的变量的个数

通讯录:
    姓名、性别、电话,最多存储50个联系人

Redis Cluster 7.23 是一个假设的版本号,因为截至2024年,Redis 官方尚未发布 7.x 系列的版本。当前稳定版本为 Redis 7.0 系列,因此 7.23 并不存在于官方发布记录中。以下信息基于 Redis Cluster 的现有版本(如 7.0 及其补丁版本)的功能、改进和已知问题进行推测和总结。 ### Redis Cluster 版本特性与改进(基于现有版本) 1. **哈希槽机制** Redis Cluster 采用哈希槽(hash slot)的方式分配数据,总共有 16384 个槽位。每个 key 通过 CRC16 算法计算出一个 16 位的哈希值,再对 16384 取模,确定其所属的槽位,从而决定该 key 应该存储在哪个节点上。这种方式相比哈希求余更均匀,减少了节点增减时数据迁移的范围[^1]。 2. **集群创建命令** Redis 5 及以上版本支持使用 `redis-cli --cluster create` 命令创建集群,简化了集群部署流程。例如: ```bash redis-cli -a 1234 --cluster create 47.101.158.4:6379 47.101.158.4:6380 47.101.158.4:6381 47.101.158.4:6382 47.101.158.4:6383 47.101.158.4:6384 --cluster-replicas 1 ``` 该命令会自动分配槽位并建立主从复制关系,其中 `--cluster-replicas 1` 表示每个主节点有一个从节点[^2]。 3. **集群管理命令** Redis Cluster 提供了丰富的管理命令,用于维护和监控集群状态。例如: - `CLUSTER NODES`:查看集群中所有节点的信息。 - `CLUSTER INFO`:获取集群的整体状态信息。 - `CLUSTER KEYSLOT <key>`:计算某个 key 所属的槽位。 - `CLUSTER SLOTS`:查看所有槽位的分配情况。 - `CLUSTER ADDSLOTS` 和 `CLUSTER DELSLOTS`:手动分配或移除槽位。 - `CLUSTER FAILOVER`:手动触发故障转移[^4]。 4. **故障转移机制** Redis Cluster 支持自动故障转移。当主节点不可用时,集群会从其从节点中选举一个新的主节点继续提供服务。选举过程依赖于 `cluster-node-timeout` 和 `cluster-slave-validity-factor` 两个参数,只有在从节点与主节点断开连接的时间未超过 `cluster-node-timeout * cluster-slave-validity-factor` 的情况下,该从节点才有资格晋升为主节点[^5]。 5. **性能与稳定性改进** 在 Redis 7.0 中引入了多项性能优化,包括: - 改进了集群心跳机制,减少网络开销。 - 增强了集群拓扑同步的效率,提升了节点加入和退出的速度。 - 优化了数据迁移过程,降低了迁移对性能的影响。 6. **安全性增强** Redis 7.0 引入了更强的身份验证机制和访问控制功能,支持 ACL(Access Control List),允许对用户进行精细化权限管理,增强了集群的安全性。 7. **已知问题与限制** - Redis Cluster 不支持多 key 操作(如 `MGET`、`MSET`)跨节点执行,除非这些 key 位于同一个哈希槽中。 - 集群模式下无法使用 Redis 的某些高级功能,如 Lua 脚本跨槽执行。 - 在大规模集群中,节点间的心跳通信可能带来一定的网络压力。 ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值