![]() | 1 wizardoz 2016-01-13 13:18:10 +08:00 首先你要理解指针是一种类型(或多种类型),常量就是不能改变的变量。 对于 int 来说 int 是一种类型 int* 是一种类型,只不过这两种类型略微有一点关系而已。 const int 就是整型常量 const int* 就是指向整型常量的指针 int* const 是指向整型的指针常量 !! 注意其中的区别,一个是指针本身是常量,就是指针变量不能改,一个是指针不是常量可以改,但是指针指向的内存不能改。 当然还可以 const int * const 指向整型常量的指针长量。 指针的值也不能改,指针指向的地址的内容也不能改。 |
![]() | 2 congeec 2016-01-13 13:27:47 +08:00 你打开的方式不对 来,告诉我什么是指针数组,什么是数组指针? 我不知道,但是一看我就知道下面两行代码是什么意思 int *p[2]; int (*p)[2]; 同样地,指针++ = 指针++ 这是什么鬼? while (*s++ = *t++); // 不过这行复制字符串的代码你肯定能理解 概念是抽象过的,一般比原来的东西难理解。写几行代码,抓住本质就行了 |
![]() | 3 k9982874 2016-01-13 13:32:48 +08:00 理解不了我才表示费解,实在不行就去做前端啥的吧,没有指针。 |
![]() | 5 b244183 OP |
6 f7ee9404 2016-01-13 13:51:43 +08:00 就是语法糖, c 设计的时候内存和硬盘单位价格非常高,对应现在的电脑没什么大用 代码怎么容易读怎么搞就行。 i++ 等价于 i=i+1 |
![]() | 7 congeec 2016-01-13 13:57:02 +08:00 @b244183 为嘛要设计成这样?看 spec 吧: ISO/IEC 9899 多扯两句,据我所知 C 语言基本上是可移植的汇编,为汇编程序员设计的。 i++有直接对应的汇编指令 incr i 在汇编里操作数据只能用地址+偏移,自然而然 C 语言里就有指针这个概念了 |
![]() | 8 kobe1941 2016-01-13 14:14:56 +08:00 指针和结构体在一起才坑爹%>_<% |
![]() | 9 maomaomao001 2016-01-13 14:25:44 +08:00 via Android @wizardoz 好晕啊~~~为什么 C/C++是这种设计方式.... |
![]() | 10 MCVector 2016-01-13 14:50:09 +08:00 @maomaomao001 to make your life easier. |
![]() | 11 young 2016-01-13 14:57:14 +08:00 想起了前几天看到的这个 |
![]() | 12 wizardoz 2016-01-13 15:09:16 +08:00 @maomaomao001 其实从语义来讲很对称啊。整个过程只是变量,指针,和 const 三个概念组合以后发生了许多变化。并且组合以后并没有产生与三个概念矛盾的东西。 所以不应该说 C/C++设计成这样,应该说 C 语言的设计者没有进行很多的设计和封装,而是直接把事情的本质放出来了。 |
![]() | 13 maomaomao001 2016-01-13 15:09:41 +08:00 via Android @MCVector 骗子。。。 |
![]() | 14 dorentus 2016-01-13 15:11:27 +08:00 via iPhone 推荐一本书:《征服C指针》 |
![]() | 15 Kilerd 2016-01-13 15:30:08 +08:00 你的 C 功底不行啊,指针其实在 C 里面不算是特别难得吧。 |
16 yurivvvvv 2016-01-13 15:33:53 +08:00 我觉得正是 Pointers on C 把这些费解的东西讲的很清楚了。 |
![]() | 18 jixiangqd 2016-01-13 16:09:41 +08:00 看 const 在*前还是*后,*前则是修饰*,*后则是修饰具体类型 const int * int const * int * const //只有这个修饰 int |
![]() | 20 k9982874 2016-01-13 17:04:21 +08:00 @b244183 你要知道 c/c++的内存操作原理就不会不懂了 c/c++数据传递默认传值,也就是直接做内存 copy ,操作一次就会产生一个内存 copy 如果是 int 之类的简单类型就算了,如果是 struct 或 class 之类的大对象那内存多少都不够用 所以为了解决这个问题引入了指针,指针的大小就是一个 unsiged int 的大小, copy 一个 int 的花销和 copy 一个对象的花销比还是很合算的 这样就避免了值传递时无穷无尽的内存 copy 还有什么修改对象值,前 const ,后 const 之类的东西都是额外的知识。 |
![]() | 21 raysonx 2016-01-13 17:09:12 +08:00 一言以蔽之:指保存的只是一整,和 long 、 int 有本,其他皆法糖。 |
![]() | “右左法则” 你还没有见识过 C++的引用、右值引用、指针 /引用与 template 连用等等 |
![]() | 23 dorentus 2016-01-13 17:31:56 +08:00 我完全不同意 raysonx 的看法 指针和整数是完全不同概念的东西,只是在 C 里面它刚好用一个特定长度的整数值表示而已(原因和硬件或者汇编的细节以及影响了 C 的设计的那些语言的细节有关)。 指针的那些加加减减的操作符才是语法糖。正是这些操作符产生了它在逻辑上就是一个整数的假象。但是要明白,指针并不是整数,对它的这些加加减减代表的意义和遵循的规则并不完全和整数的那些一样。 |
![]() | 24 raysonx 2016-01-13 17:51:02 +08:00 @dorentus 你是在言的面上看的。於 CPU 什型有任何意,他只根你用指令的不同行不同的操作。程序的候,存都是需要地址作操作的。 所加加所代表的意只是器面的西,器自把加法被指向型大小的倍。倍的是硬在目代中的。 |
![]() | 25 iyangyuan 2016-01-13 17:52:10 +08:00 via iPhone 因为是给聪明人看的,像我这种愚钝的人只能搞面向对象 |
27 vanxining 2016-01-13 18:25:36 +08:00 via Android 哦,查了一下,原来是指向一个固定长度数组的指针。第一次看到。新技能 get√。 |
![]() | 28 Reficul 2016-01-13 18:32:10 +08:00 指针就是内存地址, C 语言的指针还是很容易理解的,只是容易在 debug 的时候抓狂 |
![]() | 29 b244183 OP 看了 K&R 的 5.12 Complicated Declarations 基本搞懂了 |
30 woai110120130 2016-01-14 07:29:26 +08:00 via Android 我很费解 楼主为什么很费解 |
![]() | 31 louk78 2016-01-14 08:30:07 +08:00 因为是给聪明人看的,像我这种愚钝的人只能搞面向对象 |
![]() | 32 msg7086 2016-01-14 09:02:54 +08:00 如果你觉得设计得不好,你应该 1972 年的时候就提出来。 如果没有,那么说明你那时候 要么还没这水平去提意见,要么你还没出生。 或者两者皆是。 |
33 saeba1030 2016-01-14 10:41:39 +08:00 对于指针来说,数据类型只是告诉指针应该以什么方式去存取内存里的数据,指针本身无所谓类型。 |
![]() | 34 cheng4741 2016-01-14 11:10:33 +08:00 @msg7086 不同意你的观点,如果一个东西设计得不好,不一定能在当时就体现出来。很多东西都是随着时间的推移才发现原来设计的有问题。 |
37 chiuup 2016-01-14 14:47:49 +08:00 @saeba1030 准确地说,指针的数据类型是告诉编译器应该怎么样翻译成汇编码,指针本身是有类型的,并且这个类型在编译时很重要。 |
38 chiuup 2016-01-14 14:56:47 +08:00 追溯到源头的话, C 是一帮对汇编代码十分精通的大牛设计的, C 是对汇编码最直接的一层抽象。如果你可以站在汇编程序员的角度来看 C 的这些设计的话,很多 C 的设计就很好理解了。比如说你提到指针算术,其实是对 lea 的一种特定用法的抽象。 |
39 ahbcd112 2016-01-14 15:08:58 +08:00 很久很久以前。。。内存是非常非常贵的 怎样节省怎么用。内存各种算 内存的增长是指数增加的(比尔不是说过,个人电脑只要 32M 就够了!!某 N 年前电影,里面有一段,机器人能存储他看到的所有东西,因为他有一个非常非常大的硬盘。。。。 500MB ) 然而,开发费用。。。貌似没降多少吧。 所以 OOP 各种发展,浪费点空间。减少开发、维护工作量。 |