[C++][Test]函数名 数组名 &

1 函数名与&

TestCode
#include <stdio.h>

static void test_deleter(void){
	printf("%s\n", __FUNCTION__);
}

void main(void){
	auto f1 = test_deleter;
	auto f2 = &test_deleter;
	printf("%s ; %s\n", typeid(f1).name(), typeid(f2).name());
	f1();
	f2();
	(*f1)();
	(*f2)();
}
Test Result
void (__cdecl*)(void) ; void (__cdecl*)(void)
test_deleter
test_deleter
test_deleter
test_deleter
Summary

推测对于函数名进行&操作的方法可能属于遗留的问题,非常见的用法;
对于函数名理解为函数类型,对于&函数名理解为函数指针,至于使用还是尽量以正常的思维去思考,函数类型就直接使用,函数指针类型就使用*操作符进行使用。

2 数组名与&

TestCode
#include <stdio.h>

void test_array(void){
	int arr[10][10];

	printf("arr         : {%-10s}\t[%x]\n", typeid(arr).name(), arr);
	printf("&arr        : {%-10s}\t[%x]\n", typeid(&arr).name(), &arr);
	printf("arr[0]      : {%-10s}\t[%x]\n", typeid(arr[0]).name(), arr[0]);
	printf("&arr[0]     : {%-10s}\t[%x]\n", typeid(&arr[0]).name(), &arr[0]);
	printf("arr[0][0]   : {%-10s}\t[%x]\n", typeid(arr[0][0]).name(), arr[0][0]);
	printf("&arr[0][0]  : {%-10s}\t[%x]\n", typeid(&arr[0][0]).name(), &arr[0][0]);
}

void main(void){
	test_array();
}
Test Result
arr         : {int [10][10]}     [15fa40]
&arr        : {int (*)[10][10]}  [15fa40]
arr[0]      : {int [10]  }       [15fa40]
&arr[0]     : {int (*)[10]}      [15fa40]
arr[0][0]   : {int       }       [cccccccc]
&arr[0][0]  : {int *     }       [15fa40]
Summary

Point 1 首先关于 “数据类型 + 数据名”这种定义,数据名可以理解为某段内存的映射,当通过数据名进行各项操作时其实就是通过名字确定数据的起始地址,通过数据类型确定需要取多少内容

Point 2 对于 int b;这种写法,发现line 1的结果打印的是某段地址,而直接打印b的话是b的内容,这里就需要进行区分数组名和一般变量名。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 读取文件到数组是一种常见的操作,主要用于将一个文件中的数据读取到一个数组中进行进一步的处理和分析。这种操作可以通过使用文件流来实现。 首先需要打开文件,使用fopen函数可以打开一个文件,在打开的时候需要指定文件和打开方式。例如,可以通过以下代码打开一个test.txt的文本文件: FILE *fp; fp = fopen("test.txt", "r"); 然后,可以使用fgets函数从文件中一次读取一行数据,将读取的数据存储在一个字符数组中,并通过循环将所有行读取到一个二维字符数组中,如下所示: char buffer[100]; char data[100][100]; int row = 0; while(fgets(buffer, 100, fp) != NULL) { strcpy(data[row], buffer); row++; } 最后,可以使用fclose函数关闭文件,并将读取到的数据进行进一步处理。这样就完成了将文件读取到数组中的操作。 ### 回答2: C语言提供了多种方法来读取文件内容并存储到数组中。常用的方法有: 1. 使用fscanf函数逐行读取文件内容,将读到的数据存储到数组中。需要事先确定文件中每一行的数据类型和格式,然后逐行读取、转换并存储到数组中。 2. 使用fgets函数一行一行地读取文件内容,然后将读到的每一行存储到数组中。需要预估文本行数,并为数组预留足够的空间。 3. 使用fread函数从文件中读取二进制数据到指定的数组中。需要预估文件大小,并为数组预留足够的空间。 4. 使用getline函数读取文件内容到动态分配的字符串中,然后将字符串存储到数组中。需要在文件读取完毕后释放动态分配的字符串空间。 5. 使用mmap函数将文件映射到内存中,然后直接访问内存中的数据。这种方法对于大文件效率较高,但需要保证内存足够大。 无论使用哪种方法,都需要在读取文件前打开文件,读取完毕后关闭文件,并对读取的数据进行必要的检查和处理。同时也需要注意数组边界的处理,避免出现越界访问的错误。 ### 回答3: 读取文件到数组是一种常见的数据处理方法,可以快速有效地对文件内容进行分析和处理。在实际应用中,读取文件到数组通常需要以下几个步骤: 1. 打开文件。首先需要使用文件操作函数打开目标文件,并指定文件打开模式,如只读、只写、追加等。 2. 读取文件内容。使用文件操作函数读取文件内容,并将其存储到数组中,可以根据需要指定读取的字节数或行数。 3. 处理文件内容。读取到文件内容后,可以根据需要对其进行处理,如进行数据分析、处理特定字符串或数字等操作。 4. 关闭文件。处理完文件后,必须使用文件操作函数关闭文件,释放相关资源。 在Python中,可以使用内置的open()和read()函数来读取文件到数组。示例代码如下: ``` with open('file.txt', 'r') as f: content = f.read().splitlines() print(content) ``` 其中,open()函数接收文件和打开模式作为参数,即可打开文件。read()函数用于读取文件内容,splitlines()函数用于将文件内容按行分割存储到数组中。 读取文件到数组是一种简单而实用的数据处理方法,可以帮助我们快速处理文件内容,提高数据处理效率。在实际应用中,需要根据具体的数据需求和处理方式选择不同的读取和处理方法,以达到更好的数据处理效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值