7.23 学习日报

一维数组:格式 int  a[10] ;注意初始化数组之后机器会给数组分配地址空间,比如a[0]地址为 0x100,则a[1]为0x104 a[2]为0x108以此类推,其实里面的0x100,0x104与我们平时理解的还不一样他不是简单的‘位’,而是以字节为单位的,因为是用int来声明的所以元素之间相差4字节,并且低位的一定是a[0]。另外定义一个变量时 比如 int  b = 10;也是四个字节,只不过根据存放顺序与机器有关,分为大端模式与小端模式。

大端字节序:是高字节放在低地址,低字节放高地址;

小端模式:是高字节放高地址,低字节刚地地址;

 

int a[5];

sizeof[a]=20(B);sizeof(a[0])=4(B);这是因为a代表一整个数组;

未初始化的全局变量是0,未初始化的局部变量是一堆乱序数;如果对一个数组进行初始化,只初始化其中几个值,那么其他数值会默认为0;

int  a[20];       &a[0] + 1 =a[1]; 

  a + 1地址会增加这个一维数组的总长度个字节 ,比如这一题会增加 20 *4=80,若是二维数组也是增加一维的长度即行长度;

&a是取的全部空间;*(a+x)=[x];

strcat(s1,s2);把s2加到s1的后面;

strcpy(s1,s2);把s2复制到s1中包括\0;strcpy(s1,s2 ,3)这是指定了复制s2的前三个元素;这种方法可以给字符串赋值;

strcmp(s1,s2);比较两个字符串的大小;

函数声明时可以先在上面main函数的上面先声明,在main函数的下面定义,函数遇到return和exit()这两个函数会自动结进程;

extern 关键字是声明一个全局变量或者函数;声明不占用空间,定义则需要分配空间,static用来修饰全局变量,目的是其他文件不得调用。

 

内容概要:本文介绍了多种开发者工具及其对开发效率的提升作用。首先,介绍了两款集成开发环境(IDE):IntelliJ IDEA 以其智能代码补全、强大的调试工具和项目管理功能适用于Java开发者;VS Code 则凭借轻量级和多种编程语言的插件支持成为前端开发者的常用工具。其次,提到了基于 GPT-4 的智能代码生成工具 Cursor,它通过对话式编程显著提高了开发效率。接着,阐述了版本控制系统 Git 的重要性,包括记录代码修改、分支管理和协作功能。然后,介绍了 Postman 作为 API 全生命周期管理工具,可创建、测试和文档化 API,缩短前后端联调时间。再者,提到 SonarQube 这款代码质量管理工具,能自动扫描代码并检测潜在的质量问题。还介绍了 Docker 容器化工具,通过定义应用的运行环境和依赖,确保环境一致性。最后,提及了线上诊断工具 Arthas 和性能调优工具 JProfiler,分别用于生产环境排障和性能优化。 适合人群:所有希望提高开发效率的程序员,尤其是有一定开发经验的软件工程师和技术团队。 使用场景及目标:①选择合适的 IDE 提升编码速度和代码质量;②利用 AI 编程助手加快开发进程;③通过 Git 实现高效的版本控制和团队协作;④使用 Postman 管理 API 的全生命周期;⑤借助 SonarQube 提高代码质量;⑥采用 Docker 实现环境一致性;⑦运用 Arthas 和 JProfiler 进行线上诊断和性能调优。 阅读建议:根据个人或团队的需求选择适合的工具,深入理解每种工具的功能特点,并在实际开发中不断实践和优化。
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 脚本跨槽执行。 - 在大规模集群中,节点间的心跳通信可能带来一定的网络压力。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值