在调用函数时实参为什么只需给出数组名?
时间: 2024-11-17 09:30:42 浏览: 6
在调用函数时,传递数组名而不是数组的元素值,主要是因为在函数内部,数组名实际上是一个指向数组首元素的指针。当我们提供数组名作为实参时,编译器会在栈上保存的是这个指针,而不是整个数组的内容。
这种做法有以下几个优点:
1. **效率**:通过指针传递,函数可以直接访问数组元素,无需复制整个数组,节省了时间和空间。
2. **灵活性**:函数可以修改数组内的元素,因为它是按引用传递的。这在需要对数组进行某种处理的情况下非常有用。
3. **通用性**:同一数组名可以代表不同大小和类型的数组,只要它们的首地址相同,函数可以接受并处理各种类型的数组。
例如:
```cpp
void printArray(int arr[]) {
for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++) {
std::cout << arr[i] << " ";
}
}
int main() {
int numbers[] = {1, 2, 3, 4, 5};
printArray(numbers);
return 0;
}
```
在这里,`printArray`函数只接收一个整型数组的名称`arr`,而不需要知道具体的长度。
相关问题
6-17 分词并输出排序后的单词 分数 10 作者 叶斌 单位 成都信息工程大学 本题实现,输入一个包含空格的多单词字符串,单词与单词之间用1个或多个空格分隔。请将字符串中用空格分隔的单词排序后在屏幕上输出来。 要求用指针完成函数中各参数的传递与访问,自定义函数头和函数体中不得出现数组下标形式的表示法。 函数接口定义: int split_sort(char *str,char **pStr); 函数对字符串中的单词进行分割,并按字典顺序输出排序后的单词,函数返回字符串中单词的数目。str用于接收实参字符串,pStr用于存放分割后的各单词对应字符串的首地址。下面函数的定义部分框架与花括号部分已经给出了,只需给出函数{...}之中的部分。 裁判测试程序样例: 在这里给出函数被调用进行测试的例子。例如: #include<stdio.h> int split_sort(char *str,char **pStr); int main(void) { char arr[101]={0},*pX[50]; char **p=pX; int wordNum; gets(arr); wordNum=split_sort(arr,p); for(;p<pX+wordNum;p++) printf("%s ",*p); return 0; } int split_sort(char *str, char **pStr) { /* 请在这里填写答案 */ }
以下是函数的实现:
```c
int split_sort(char *str, char **pStr) {
int wordNum = 0;
char *p = str;
while (*p != '\0') {
// 跳过空格
while (*p == ' ') {
p++;
}
// 记录单词起始位置
char *start = p;
// 跳过单词
while (*p != ' ' && *p != '\0') {
p++;
}
// 记录单词结束位置
char *end = p;
// 单词复制到pStr数组中
if (end != start) {
char *word = (char *)malloc(end - start + 1);
memcpy(word, start, end - start);
word[end - start] = '\0';
*pStr++ = word;
wordNum++;
}
}
// 对pStr数组中的单词进行字典序排序
for (int i = 0; i < wordNum - 1; i++) {
for (int j = i + 1; j < wordNum; j++) {
if (strcmp(pStr[i], pStr[j]) > 0) {
char *temp = pStr[i];
pStr[i] = pStr[j];
pStr[j] = temp;
}
}
}
return wordNum;
}
```
该函数首先会遍历字符串,找到每个单词的起始位置和结束位置,并将单词保存到pStr数组中。然后对pStr数组中的单词进行字典序排序。最后返回pStr数组中的单词数目。由于函数中使用了动态内存分配,需要在调用完该函数后手动释放pStr数组中的每个单词的内存。
阅读全文