初学者在学习C语言的时候,最头疼的可能就是指针,话不多说。让我们直接进入正题
直接上代码
int main(void) { int *p = 0; printf("%d", *p); system("pause"); return 0; }
直接运行,好了,程序是不是报错了?那就对了。因为此时的int *p=0实际等于int *p; p=0;
让我们来验证一下对不对
int main(void) { int *p = 0; printf("%d", p); system("pause"); return 0; }
这说明此时指针*p装的不是0,而是以0作为地址的一个值,输出地址为0的值编译器当然会直接报错。
那为什么会这样呢?因为此时的int *p其实是(int*)p;把它看成是一个新的类型,就和int a=0;差不多,这也就解释了为什么会输出0的原因。而我们知道定义一个指针*p,p里面装的是地址,*p则表示这个地址上所储存的值,
*那么我们如何获取这个地址呢*
这时候就可以用”&“
比如
int *p ; int a = 2; p = &a; printf("%d\n", *p);
此时的p通过取地址符号取得了a的地址,那么*p储存的就是a的值,你也可以把它看成是另一个a,改变它的值也可以改变a的值
比如这样
int *p ; int a = 2; p = &a; *p = 1; printf("%d\n", *p);
此时的就会输出 1
总结
以上所述是小编给大家介绍的C语言中指针 int *p=0;和int *p;*p=0;和”&“的关系和区别详解,希望对大家有所帮助,也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍C中的++ * p,* p ++和* ++ p之间的区别,包括了C中的++ * p,* p ++和* ++ p之间的区别的使用技巧和注意事项,需要的朋友参考一下 指针式 在C语言中,* p表示存储在指针中的值。++是前缀和后缀表达式中使用的增量运算符。*是取消引用运算符。前缀++和*的优先级相同,并且两者从右到左关联。后缀++的优先级高于前缀++和*,并且从左到右具有关联性。请参见以
上述代码的实际输出是 根据我的理解,访问0x0加法器时应给出SEG故障。因为*p地址是0x0。 为什么它会起作用?有人解释一下吗?
描述 (Description) 字符类[\p{L}&&[^\p{Lu}]]匹配除大写字母之外的任何字符。 例子 (Example) 以下示例显示了Unicode字符类匹配的用法。 package com.wenjiangs; import java.util.regex.Matcher; import java.util.regex.Pattern; public class UnicodeCh
在第一种情况下,我理解为:何时分配(或后续添加?)执行时,p被视为未声明。 但是为什么在一种方法中它是不同的呢?OK t不会被视为未初始化,因为(t=1)是在添加之前执行的。好的,t不是一个字段,但它现在也没有声明! 我能理解吗?要不我就记住这个区别? 也许这也与此有关: 为什么是2?第一个(x=1)以某种方式计算(x未声明!!!),然后返回1,现在x已经赋值了(!?)并且包含1,所以这两个测试。
本文向大家介绍C语言中while(1)和while(0)之间的区别,包括了C语言中while(1)和while(0)之间的区别的使用技巧和注意事项,需要的朋友参考一下 众所周知,在C语言中,“ while”关键字用于定义一个循环,该循环在作为参数传递给循环的条件下起作用。现在,由于condition可以具有两个值true或false,因此,如果condition为true,则while块中的代码将
这是代码: 编译器(gcc)警告外部减法处的整数溢出: 在我的机器上获得了正确的结果1。 为什么? 这是因为指针地址是无符号整数,但ptrdiff_t是有符号整数,无法处理这些大数字吗? 我看到了 和 不要造成溢出。 我正在努力了解这里的幕后情况。这是我关于stackoverflow的第一个问题,如果我的问题可以改进,请告诉我。