c语言把地址给指针,c语言指针 地址

dfnjsfkhak 18 0

大家好,今天小编关注到一个比较意思的话题,就是关于c语言地址指针问题,于是小编就整理了3个相关介绍c语言把地址给指针的解答,让我们一起看看吧。

  1. C语言将地址赋值给指针变量?
  2. C语言为什么要引入指针?

C语言将地址赋值给指针变量

取决于p的类型。struct stu_type *p=&stu1;这里的*是和类型一起的,用来定义,而非初始化。 等效于struct stu_type *p;p=&stu1;至于去掉, 写成struct stu_type p=&stu1;绝对会报错。 不存在你说的去掉和加上结果不变。

c语言为什么能把数组的地址赋值给指针?

c语言可以将数组的地址赋值给指针,主要是因为数组名本身就是一个指针常量代表了数组的首地址。
具体解释如下:1. 在C语言中,数组名相当于指向数组首元素的指针。
当我们使用数组名进行赋值操作时,实际上是将数组首元素的地址赋给了指针变量。
这是因为数组在内存中是连续存储的,数组名指向的是数组的首地址。
2. 指针变量可以存储任何地址。
由于数组名本质上就是一个指针常量,因此可以将数组名赋值给其他指针变量,将数组的首地址传递给这些指针变量。
这样可以通过指针变量来操作数组的元素。
3. 通过将数组地址赋值给指针,我们可以通过指针对数组进行遍历、访问和修改操作,实现对数组的灵活处理
综上所述,c语言可以将数组的地址赋值给指针是因为数组名本身就是指针常量,代表了数组的首地址,这样可以通过指针来操作和处理数组。

c语言把地址给指针,c语言指针 地址-第1张图片-芜湖力博教育咨询公司
图片来源网络,侵删)

C语言为什么要引入指针?

C语言本身是为编写操作系统设计的,对操作系统而言,内存管理进程管理、设备管理都需要直接对内存按地址读写操作,有了指针,操作系统才能把一个程序调进指定的内存空间中去,才能把硬盘的数据读进指定的内存中去,等等,所以C语言中指针是一个非常重要的工具

首先,指针就是内存地址。而内存地址计算机中自然存在的东西,所以不存在c语言引进指针这种说法。

那其它语言中没有指针呢?那是因为在这些语言中指针被抽象了、屏蔽了计算硬件相关的概念,比如JavaC#。这使得这些语言更安全、更容易使用。但同时也使得这些语言丢失了直接操作硬件的便利。

c语言把地址给指针,c语言指针 地址-第2张图片-芜湖力博教育咨询公司
(图片来源网络,侵删)

C语言之所以保留指针,是为了它满足它的设计需求:重写unix操作系统。而操作系统是需要直接操作硬件的,同时也需要程序直接反映内存或寄存器中的数据。这使得c语言直观并且高效,非常适合编写底层的、高效的程序。

几乎所有的编程语言都需要对内存地址进行操作,只不过C语言是显式,其他语言是隐式的。可以从机械运算原理和实际的应用方法两个方面来理解这个问题。

机械运算需要地址操作

c语言把地址给指针,c语言指针 地址-第3张图片-芜湖力博教育咨询公司
(图片来源网络,侵删)

打个比方,给你一排计算器。每个计算器上都有一个内存,用M,MR,MC进行内存的读写擦除。在不同的计算器上进行分步计算,利用内存传递中间结果,就可以完成复杂的计算任务。不停地切换计算器的动作就相当于地址操作了。一台计算机相当于由大量的计算器组成的,而程序则规定了在计算器之间切换的步骤。从图灵机到冯氏架构,都可以理解为这样的方式。计算机程序必须得有地址操作,编程语言中出现代表地址的指针也就不足为奇了。但是,地址操作不符合我们的思考习惯,人们还是希望能够隐藏地址操作,赋予地址操作比较接近自然语言的意义。

被隐藏了的指针

在C#中,用ByRef关键字定义指针,而用ByVal关键字定义值。而J***a则刻意隐藏了指针的概念。但下面这个例子中还是漏出了马脚:

String str=“Hello”;

String ptr=new String(“Hello”);

一行中的变量是值,用它传参相当于复制自己也就是值传递。而第二行的参数是一个指针,用它传参虽然也会***自己,但是由于它是字符串的首地址,相当于引用传递。如果你留意一下几乎每种语言里都能找到指针的影子。能完全无视指针的语言大概只有SQL吧。这种语言是迄今为止最高级的语言,有人把它称为第五代语言。

到此,以上就是小编对于c语言把地址给指针的问题就介绍到这了,希望介绍关于c语言把地址给指针的3点解答对大家有用

标签: 指针 数组 地址