当前位置: 首页 > news >正文

const char* 、char*和char[]的区别

一、char* (字符指针)

定义:指向字符数据的指针

特点:

  •  可以指向字符串字面量或字符数组
  • 指针本身可修改(可以指向不同地址)
  • 指向的内容可能可修改(取决于指向的内存类型)

内存分配:

  • 通常指向堆、栈或静态存储区的内存
char* str1 = "Hello";       // 指向字符串字面量(只读区)
char buffer[] = "World";
char* str2 = buffer;        // 指向可修改的数组str2[0] = 'w';              // 允许:修改指向的内容
str1 = str2;                // 允许:修改指针本身
// str1[0] = 'h';          // 危险:尝试修改只读内存(未定义行为)

二、const char* (指向常量字符的指针)

定义:指向不可修改字符数据的指针

特点:

  • 指针本身可修改(可以指向不同地址)
  • 指向的内容不可修改
  • 提高代码安全性和表达意图

典型用途:

  • 字符串字面量
  • 函数参数(表示函数不会修改传入的字符串)
const char* str = "Immutable";  // 推荐的安全声明// str[0] = 'i';               // 编译错误:内容不可修改
char buffer[] = "Mutable";
str = buffer;                  // 允许:指针可重新赋值

三、char[] (字符数组)

定义:固定大小的字符数组

特点:

  • 数组名是常量指针(不可重新赋值)
  • 内容可修改
  • 大小在声明时确定(静态或自动储存期)

内存分配:

  • 通常分配在栈或全局数据区
char arr1[] = "Stack";       // 栈上分配(可修改)
char arr2[10] = "Array";     // 显式指定大小arr1[0] = 's';               // 允许:修改内容
// arr1 = "New";             // 错误:数组名不可重新赋值// 正确的内容修改方式
strcpy(arr1, "NewString");   // 需要确保目标空间足够

关键区别总结

     特性                     char*const char*char[]
指针是否可修改✓ (可指向新地址✓ (可指向新地址)✗ (固定地址)
内容是否可修改取决于指向的内存✗ (永远不可修改)✓ (总是可修改)
内存管理需要手动管理自动/静态自动/静态
典型用途动态字符串字符串字面量固定大小缓冲区
sizeof 返回值指针大小(4/8字节)指针大小数组实际大小

使用场景建议:

1、const char*

  • 处理字符串字面量(如"Hello")
  • 函数参数(表示输入字符串不会修改)
void printString(const char* str) {printf("%s", str);// 保证不会修改str的内容
}

2、char *:

  • 动态内存分配的字符串
  • 需要重新指向不同的字符串的场景
char* dynamicStr = malloc(20);
strcpy(dynamicStr, "Dynamic");
// ...使用...
free(dynamicStr);

3、char[]:

  • 固定大小的缓冲区
  • 需要局部修改的字符串

重要注意事项:

1、字符串字面量的危险

char* str = "Literal";  // 指向只读内存
str[0] = 'l';           // 未定义行为(可能崩溃)

2、正确的初始化

// 正确
const char* safe = "Hello";
char mutable[] = "World";// 危险(可能指向无效内存)
char* danger;
// strcpy(danger, "Risky"); // 未初始化指针!

3、数组与指针的sizeof差异

char arr[100];
char* ptr = arr;printf("%zu\n", sizeof(arr));  // 100(数组总大小)
printf("%zu\n", sizeof(ptr));  // 4或8(指针大小)

4、函数参数等价性

void func(char str[]);   // 实际等价于...
void func(char* str);    // ...这个声明

最佳实践:

  1. 优先使用const char*处理只读字符串

  2. 对可修改的缓冲区使用char[]

  3. char*配合malloc/free处理动态字符串

  4. 避免修改字符串字面量

  5. 使用strncpy代替strcpy防止缓冲区溢出

http://www.dtcms.com/a/269585.html

相关文章:

  • MySQL数据库访问(C/C++)
  • 恒创科技:香港站群服务器做seo站群优化效果如何
  • 2025年数据挖掘与计算机科学国际会议 (DMCS 2025)
  • 基于Docker Compose部署Traccar容器与主机MySQL的完整指南
  • 专题:2025数据资产AI价值化:安全、战略与应用报告|附400+份报告PDF、原数据表汇总下载
  • uniapp 监听物理返回按钮
  • 分水岭算法:图像分割的浸水原理
  • 视频号账号矩阵运营中定制开发开源 AI 智能名片 S2B2C 商城小程序的赋能研究
  • 【王树森推荐系统】召回11:地理位置召回、作者召回、缓存召回
  • 【Rust base64库】Rust bas64编码解码详细解析与应用实战
  • ​​​​​​​营销费用管理,如何驱动快消企业营销投资战略升级
  • 萌新赛第(一)场
  • IEEE Fellowe助力 2025年物联网、数据科学与先进计算国际学术会议(IDSAC2025)
  • C++——string的了解和使用
  • 将oracle表字段json字符串分解提取并返回单列表
  • Redis基础数据结构
  • 深度学习与图像处理 | 基于传统图像处理的自动驾驶车道线检测
  • XSLT注入与安全修复方法
  • 【快手】数据挖掘面试题0002:求某地铁站每日客流量,乘地铁经过、进出站人都包括在内
  • C#随机数生成全面详解:从基础到高级应用
  • 【ROS2 自动驾驶学习】03-ROS2常用命令
  • 网络安全护网实战:攻击手段解析与防御策略
  • 基于odoo17的设计模式详解---工厂模式
  • 阿里云mysql数据丢失,如何通过服务器备份在其他服务器上恢复数据,并获取mysql丢失数据,完成mysql数据恢复
  • Prompt Injection Attack to Tool Selection in LLM Agents
  • 深度剖析:向70岁老系统植入通信芯片——MCP注入构建未来级分布式通信
  • IP 能ping通,服务器是否开机?
  • Go语言反射机制详解
  • 基于ZYNQ7000的AD9226采集卡实现(3、PS LINUX DMA驱动实现)
  • vue3 el-table 行数据沾满格自动换行