免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: ccjsj1
打印 上一主题 下一主题

[C] 单链表,表头中在哪域存放下一节点的地址 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2010-04-13 11:03 |只看该作者
指针都是存放地址的,一般来说指针和整形的大小相同。。。。
head ,p1, p2都是4个字节的大小(32位机器),,
整形里面存放的是数值,指针里面存放的也是数值,但是指针里的数值当做地址来用。。。
另外,malloc的返回值不需要类型转换。

论坛徽章:
0
12 [报告]
发表于 2010-04-13 11:46 |只看该作者
指针都是存放地址的,一般来说指针和整形的大小相同。。。。
head ,p1, p2都是4个字节的大小(32位机器), ...
unistd 发表于 2010-04-13 11:03



    转换一下是个好习惯, 从代码可读性来说. 细节决定成败, 自以为聪明的人往往最后都成不了大气候.

论坛徽章:
0
13 [报告]
发表于 2010-04-13 15:23 |只看该作者
本帖最后由 unistd 于 2010-04-13 15:31 编辑
转换一下是个好习惯, 从代码可读性来说. 细节决定成败, 自以为聪明的人往往最后都成不了大气候.
samlumengjun 发表于 2010-04-13 11:46


事实是,自作聪明的恰恰是你!
C语言没有void *之前是用char *的,所以需要一个显式的类型转换。
但是后来标准引入void *类型,可以隐式转化为其它类型,根本不需要强制类型转换。。。。



http://blog.csdn.net/haoel/archive/2010/04/08/5461684.aspx

在过去的N年中,我遇到了很多使用囧然不同风格的开发者,下面是我所知道的一些,你还知道其它的吗?

散弹枪编程
这种编程风格是一种开发者使用非常随意的方式对待代码。“嗯,这个方法调用出错了……那么我会试着把传出的参数从 false 变成 true!”,当然依然出错,于是我们的程序员会这样:“好吧,那我就注释掉整个方法吧”,或是其它更为随意的处理方式,直到最后让这个调用成功。或是被旁边的某个程序员指出一个正确的方法。
如果我们把一个正规的程序员和一个撞大运的程序员放在一起做结对,那么,那个正规的程序可以马上变得发疯起来,并且,可以把正规的程序员的智商降到最低。两个撞大运的程序员不应该在一起做结对编程,这是因为他们的破坏性能造成的伤害会比只有一个还大。

撞大运编程
这是一种比散弹枪编程要温和一些的编程方式,我相信这种方式可能会是大多数程序员都会使用的方式。这种编程方式经常出现于程序员并不确切知道他们在干什么,也不知道所写的程序的本质和实际,但是可以让程序工作起来。他们以一种撞大运的方式在写程序,某些时候,他们根本就不知道某个错误的原因,就开始稀里糊涂地修改代码。一旦出现问题,他们会用两条路:1)停下来,理解一下程序,找到出错的原因。2)使用散弹枪编程方式开始解决问题。
测试驱动开发(Test Driven Development)是一种可以用来拯救上百万的撞大运编程的程序员。于是,他们有了一个更为NB的借口:只要我的程序通过测试了,你还有什么话好说?别骂我,测试驱动开发是一个不错的事物,其主要是用来控制撞大运开发所带来的问题。

Cargo-Cult 编程
关于Cargo Cults 这个词儿来自二战期间的某些太平洋上小岛里的土著人。在战争期间,美国利用这些小岛作为太平洋战场上的补给站。他们在这些小岛上修建自己的飞机跑道以用来运输战争物资。而那些小岛上的土著人从来没有见过飞机,当他们看到飞机的时候,觉得相当的牛,可以为那些白人带来各种各样的物品和食物。当二战结束后,那些土著人仿照着修建了飞机跑道,并用竹子修建了塔台。然后就在那期望着有飞机为他们送来物品和食物。
Cargo Cult 编程是一种非常流行的编程方法,使用这种方法的程序员会学习其它编程高手的编程方法,虽然他们并不知道为什么高手们要那样做,但是他们觉得那样做可以让程序工作起来。举个例子,当时有大量的程序员在J2EE出现的第一年中过度地使用了EJBs和Entity Beans。

刻舟求剑编程
刻舟求剑是一个很流行的寓言了。这种风格的编程在程序员的圈子里是非常常见的。比如,有一天,你发现了一个空指针的异常,于是你到了产生空指针异常的地方,简单地放上一个判断: if (p != NULL)。
是的,这样的fix可以让你的程序工作起来,但你并没有真正地解决问题。你只不过是在你的船边记下了剑掉下去的位置,这样做只不过把问题隐藏起来,最终只会让你的程序的行为变得神出鬼没。你应该找到为什么指针会为空的原因,然后再解决这个问题。

设计模式驱动型编程
正如这种编程的名字所说的,这种编程风格使用大量的设计模式,在你的程序中,四处都是设计模式,你的代码到处都是Facade,Observer ,Strategy,Adapter,等等等等。于是,你的程序要处理的业务逻辑被这些设计模式打乱得无法阅读,最后,也不知道是业务逻辑重要,还是设计模式重要,总之,实际业务需求的程序逻辑被各种设计模式混乱得不堪入目。

侦探型编程
在解决一个Bug的时候,侦探型程序员会调查这个Bug的原因。然后,则调查引发这个BUG的原因的原因。再然后,其会分析修正代码后是否会导致其它代码失败的因果关系。再然后然后,他会使用文本搜索查找所有使用这个改动的代码,并继续查找更上一级的调用代码。最后,这个程序员会写下30个不同的情形的测试案例,就算这些测试案例和那个Bug没有什么关系,最最后,这个程序员有了足够多的信心,并且精确地修正了一个拼写错误。
与此同时,其它一个正常的程序员修正了其它5个Bug。

屠宰式编程
使用这种风格的程序员,对重构代码有着一种难以控制的极端冲动。他们几乎会重构所有经手的代码。就算是在产品在Release的前夜,当他在修正几个拼写错误的bug同时,其会修改10个类,以及重构与这10个类有联系的另20个类,并且修改了代码的build脚本,以及5个部署描述符。

论坛徽章:
0
14 [报告]
发表于 2010-04-13 15:40 |只看该作者
事实是,自作聪明的恰恰是你!
C语言没有void *之前是用char *的,所以需要一个显式的类型转换。
但是 ...
unistd 发表于 2010-04-13 15:23



    当然不转换没错,而且代码也省. 你很聪明,非常聪明,所以你成不了大气候.

论坛徽章:
0
15 [报告]
发表于 2010-04-13 16:06 |只看该作者
本帖最后由 unistd 于 2010-04-13 16:11 编辑

看来这位兄弟真有做大事的气魄啊!

那这么说的话,我觉得c中连if ... else ... 这些语句后面都应该注释上“如果”、“否则”,i++这样的语句也应该写成 i = i + 1...,要不然程序别人可能看不懂,可维护性不好。。。

论坛徽章:
0
16 [报告]
发表于 2010-04-13 16:31 |只看该作者
这楼真有意思。

论坛徽章:
0
17 [报告]
发表于 2010-04-13 21:59 |只看该作者
不想说话可以不说话,但是不会说话就不要说话了!
唉。

论坛徽章:
0
18 [报告]
发表于 2010-04-13 22:08 |只看该作者
这楼真有意思,lz只不过来问个问题而已


我也是新手,我觉得应该就是在head->next中保存下一个节点的地址,
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP