免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12345下一页
最近访问板块 发新帖
查看: 11212 | 回复: 40
打印 上一主题 下一主题

[C] 【你认为最优美的代码风格是什么样子的?】 [复制链接]

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-01-31 17:18 |只看该作者 |倒序浏览
本帖最后由 linux_c_py_php 于 2013-01-31 17:18 编辑

这里所指的 " 代码风格 " 是指 单纯的排版, 即indent工具能够取代我们做到的事情.

最近偶然看到一种个性的风格, 发现非常美观, 一句话总结就是:  多使用水平留白,   尽可能使用大段的留白对齐代码,   可以显著地增加代码的 层叠感 与 优雅程度.

平时写代码也会刻意的留白对齐, 但实际编码反复修改, 没有形成习惯.

大家刻意注意到括号内部两侧全都留白了, 甚至[ 这里也留白了 ], 如果整片采用这种风格, 最后代码看起来特别的清晰.

大家看一下这种风格如何? 留下你觉得漂亮的排版.
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>

  4. int main( int argc, char* const argv[] ) {
  5.     int   i         = 2;
  6.     short j         = 3;
  7.     char  line[ 5 ] = { '\0' };
  8.    
  9.     while ( fgets( line, sizeof( line ), stdin ) != NULL) {
  10.         int len = strlen( line );
  11.         if ( line[ len - 1 ] != '\n' ) {
  12.             printf( "line is too long" );
  13.         }
  14.     }
  15.    
  16.     return 0;
  17. }
复制代码

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
2 [报告]
发表于 2013-01-31 17:25 |只看该作者
回复 1# linux_c_py_php

花括号我还是觉得这种好些
  1. while ( )
  2. {
  3.         ......
  4. }
复制代码

论坛徽章:
8
CU大牛徽章
日期:2013-04-17 10:59:39CU大牛徽章
日期:2013-04-17 11:01:45CU大牛徽章
日期:2013-04-17 11:02:15CU大牛徽章
日期:2013-04-17 11:02:36CU大牛徽章
日期:2013-04-17 11:02:58技术图书徽章
日期:2013-12-04 10:48:50酉鸡
日期:2014-01-03 10:32:30辰龙
日期:2014-03-06 15:04:07
3 [报告]
发表于 2013-01-31 17:29 |只看该作者
基本就这样……其中运算符两侧留空是以前写TCL代码时养成的习惯。

另外,= 对齐比较恶心,有的编程规范明文禁止这么做……但偶就是喜欢……尤其是写python代码,简直无所适从了……一个库一种写法。偶只好自己找个google规范照着做,不然实在太容易引发强迫症了……

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2013-01-31 17:30 |只看该作者
这不就是我的风格吗……

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
5 [报告]
发表于 2013-01-31 17:31 |只看该作者
linux_c_py_php 发表于 2013-01-31 17:18
这里所指的 " 代码风格 " 是指 单纯的排版, 即indent工具能够取代我们做到的事情.

最近偶然看到一种个性 ...


好吧, 本不想回的, 既然 flw 发话了, 我不得不说了, 我觉得这种竖向对齐的风格, 简直丑透了

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
6 [报告]
发表于 2013-01-31 17:32 |只看该作者
cokeboL 发表于 2013-01-31 17:25
回复 1# linux_c_py_php

花括号我还是觉得这种好些


花括号这一点比较随意, 不影响代码美观, 但会增加代码纵向深度, 不太好.

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
7 [报告]
发表于 2013-01-31 17:32 |只看该作者
运算符留空是常见的, 但()内侧留空不常见, 我觉得挺好看的.

shan_ghost 发表于 2013-01-31 17:29
基本就这样……其中运算符两侧留空是以前写TCL代码时养成的习惯。

另外,= 对齐比较恶心,有的编程规范明 ...

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
8 [报告]
发表于 2013-01-31 17:33 |只看该作者
好吧, 核心是"横向拉长", "避免写出瘦子代码, 丑的要死, 一条缝下来的代码伤不起."


zylthinking 发表于 2013-01-31 17:31
好吧, 本不想回的, 既然 flw 发话了, 我不得不说了, 我觉得这种竖向对齐的风格, 简直丑透了 ...

论坛徽章:
8
CU大牛徽章
日期:2013-04-17 10:59:39CU大牛徽章
日期:2013-04-17 11:01:45CU大牛徽章
日期:2013-04-17 11:02:15CU大牛徽章
日期:2013-04-17 11:02:36CU大牛徽章
日期:2013-04-17 11:02:58技术图书徽章
日期:2013-12-04 10:48:50酉鸡
日期:2014-01-03 10:32:30辰龙
日期:2014-03-06 15:04:07
9 [报告]
发表于 2013-01-31 17:48 |只看该作者
linux_c_py_php 发表于 2013-01-31 17:32
运算符留空是常见的, 但()内侧留空不常见, 我觉得挺好看的.


这个……

一般()表达式内侧是不留空的,外侧要留空;而函数调用呢,外侧是不留空的,但里面有多个参数的话,分割参数的逗号后要有一个空格。但没有内侧留空的习惯……所以偶尔写shell脚本恶心的要死啊…… [ 之类符号两侧你敢不留空它就敢给你乱执行……

论坛徽章:
11
摩羯座
日期:2013-09-16 11:10:272015亚冠之阿尔萨德
日期:2015-06-12 22:53:29午马
日期:2014-04-15 11:08:53亥猪
日期:2014-03-02 23:46:35申猴
日期:2013-12-06 22:07:00亥猪
日期:2013-11-28 12:03:13双鱼座
日期:2013-11-21 14:43:56亥猪
日期:2013-10-23 10:55:49处女座
日期:2013-10-17 18:15:43午马
日期:2013-09-27 17:40:4215-16赛季CBA联赛之青岛
日期:2016-06-22 00:45:55
10 [报告]
发表于 2013-01-31 17:48 |只看该作者
本帖最后由 Ager 于 2013-01-31 17:49 编辑
linux_c_py_php 发表于 2013-01-31 17:18
这里所指的 " 代码风格 " 是指 单纯的排版, 即indent工具能够取代我们做到的事情.


顶楼主!

我对“代码风格”(不仅包括单纯的排版,还包括表达编程思想的方法与风格)的看法是:

(1)具有一定的可读性(美观性),就可以了。

(2)上述风格,自始至终,高度一致,杜绝前后矛盾与“例外”。

第(2)条比第(1)条重要得多,也更有难度得多。

第(2)条的意义在于:读懂了代码的一处,就等于读懂了代码的全部。

呵呵,仅供参考:)

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP