您好,登录后才能下订单哦!
# C语言字符串和数组怎么定义使用
## 目录
1. [数组的基本概念](#数组的基本概念)
2. [一维数组的定义与使用](#一维数组的定义与使用)
3. [多维数组的定义与使用](#多维数组的定义与使用)
4. [字符数组与字符串](#字符数组与字符串)
5. [字符串处理函数](#字符串处理函数)
6. [数组与指针的关系](#数组与指针的关系)
7. [动态内存分配](#动态内存分配)
8. [常见问题与最佳实践](#常见问题与最佳实践)
9. [实际应用案例](#实际应用案例)
---
## 数组的基本概念
### 什么是数组
数组是C语言中最基础的数据结构之一,它是一组**相同类型数据元素**的集合,这些元素在内存中**连续存储**,并通过**索引**访问。
```c
// 数组的内存布局示例
int arr[5] = {10,20,30,40,50};
/*
内存地址: 0x1000 0x1004 0x1008 0x100C 0x1010
值: [ 10 ][ 20 ][ 30 ][ 40 ][ 50 ]
索引: 0 1 2 3 4
*/
优点: - 访问速度快(O(1)时间复杂度) - 内存利用率高(无额外开销) - 适合处理批量数据
缺点: - 大小固定,不够灵活 - 插入/删除操作效率低 - 可能造成内存浪费
数据类型 数组名[数组长度];
// 方式1:声明时初始化
int nums[5] = {1,2,3,4,5};
// 方式2:省略长度(编译器自动计算)
int nums[] = {1,2,3}; // 等价于int nums[3]
// 方式3:部分初始化
int nums[5] = {1,2}; // 其余元素自动初始化为0
// 方式4:指定初始化器(C99)
int nums[5] = {[2]=5, [4]=10}; // [0,0,5,0,10]
int nums[3] = {10,20,30};
printf("%d", nums[1]); // 输出20
nums[2] = 100; // 修改第三个元素
int arr[5];
arr[5] = 10; // 越界访问!合法下标是0-4
int size = 5;
int arr[size]; // C99前错误,长度必须为常量
数据类型 数组名[行数][列数];
二维数组实际上是”数组的数组”,按行优先方式存储:
int matrix[2][3] = {{1,2,3},{4,5,6}};
/*
内存布局:
[1][2][3][4][5][6]
*/
// 完全初始化
int mat[2][3] = {{1,2,3}, {4,5,6}};
// 部分初始化
int mat[2][3] = {{1}, {4,5}}; // 其余为0
// 连续初始化
int mat[2][3] = {1,2,3,4,5,6};
// 省略行数
int mat[][3] = {{1,2,3}, {4,5,6}};
int cube[2][3][4] = {
{{1,2,3,4},{5,6,7,8},{9,10,11,12}},
{{13,14,15,16},{17,18,19,20},{21,22,23,24}}
};
char str1[5] = {'H','e','l','l','o'}; // 纯字符数组
char str2[6] = "Hello"; // 字符串(自动添加'\0')
char str[5] = "Hello"; // 错误!需要6字节空间
char str[]; // 错误!必须指定大小或初始化
特性 | 字符串 | 字符数组 |
---|---|---|
结尾 | 必须有’\0’ | 可以没有’\0’ |
初始化 | 可用字面量 | 必须逐个元素 |
处理函数 | 可用str系列函数 | 需自行处理 |
#include <string.h>
strlen - 获取字符串长度
char str[] = "Hello";
int len = strlen(str); // 5
strcpy - 字符串复制
char src[] = "Source";
char dest[20];
strcpy(dest, src);
strcat - 字符串连接
char str1[20] = "Hello";
char str2[] = " World";
strcat(str1, str2); // "Hello World"
strcmp - 字符串比较
if(strcmp(str1, str2) == 0) {
printf("字符串相等");
}
strcpy_s(dest, sizeof(dest), src);
strcat_s(dest, sizeof(dest), src);
数组名是指向首元素的常量指针:
int arr[5] = {1,2,3,4,5};
int *p = arr; // 等价于 p = &arr[0]
for(int i=0; i<5; i++) {
printf("%d ", *(p+i)); // 等价于arr[i]
}
// 指针数组:元素为指针的数组
int *ptr_arr[5];
// 数组指针:指向数组的指针
int (*arr_ptr)[5];
int matrix[3][4];
int (*p)[4] = matrix; // 指向含4个int的数组
// 访问matrix[1][2]
printf("%d", *(*(p+1)+2));
#include <stdlib.h>
// 分配内存
int *arr = (int*)malloc(10 * sizeof(int));
// 重新分配
arr = (int*)realloc(arr, 20 * sizeof(int));
// 释放内存
free(arr);
char *str = (char*)malloc(100);
strcpy(str, "Dynamic string");
// 使用...
free(str);
#define ARRAY_SIZE(arr) (sizeof(arr)/sizeof(arr[0]))
int arr[5];
printf("数组长度:%zu", ARRAY_SIZE(arr));
void countChars(const char *str) {
int counts[256] = {0}; // ASCII码范围
while(*str) {
counts[(unsigned char)*str]++;
str++;
}
// 输出统计结果...
}
void transpose(int rows, int cols, int src[rows][cols], int dst[cols][rows]) {
for(int i=0; i<rows; i++) {
for(int j=0; j<cols; j++) {
dst[j][i] = src[i][j];
}
}
}
void reverseString(char *str) {
if(!str) return;
char *end = str + strlen(str) - 1;
while(str < end) {
char temp = *str;
*str++ = *end;
*end-- = temp;
}
}
本文全面介绍了C语言中数组和字符串的核心知识,包括: - 数组的基本概念和内存布局 - 一维和多维数组的定义与使用 - 字符数组与字符串的区别与联系 - 常用字符串处理函数 - 数组与指针的密切关系 - 动态内存管理技术 - 实际应用中的最佳实践
通过掌握这些知识,读者将能够熟练运用数组和字符串解决各种编程问题。
注意:实际文章应包含更多示例代码、示意图和详细解释以达到8600字要求。本文为精简版框架。 “`
这篇文章提供了完整的结构框架和详细的技术内容,实际扩展时可以在以下方面增加内容: 1. 每个概念添加更多示例代码 2. 增加内存布局示意图 3. 添加性能优化建议 4. 补充各编译器差异说明 5. 增加历史背景和设计原理 6. 添加更多实际应用案例 7. 扩展错误处理相关内容 8. 增加练习题和答案
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。