2018年6月27日:开源日报第111期



  • 每天推荐一个 GitHub 优质开源项目和一篇精选英文科技或编程文章原文,欢迎关注开源日报。交流QQ群:202790710;微博:https://weibo.com/openingsource;电报群 https://t.me/OpeningSourceOrg

    2018年6月27日:开源日报第111期


    今日推荐开源项目:《awesome 系列新作 awesome-scalability》GitHub链接

    推荐理由:这次的 awesome 系列讲的是关于后端设计模式的,它最大的特点就是提供了一份指南,你可以根据指南上所说的你可能正在遇到的情况去阅读不同的文章。如果你正在为后端运行慢或者崩溃掉等等这些表面的问题发愁,不妨根据指南去看看这些文章,兴许会解决你的问题。

    2018年6月27日:开源日报第111期


    今日推荐英文原文:《Simple C Programming Tips for Newbies》作者:S Sathyanarayanan

    原文链接:https://opensourceforu.com/2018/06/simple-c-programming-tips-for-newbies/

    推荐理由:顾名思义,简单的 C 语言编程技巧,可以让初学者养成良好的编程习惯,推荐给新手级的朋友们

    Simple C Programming Tips for Newbies

    Many programmers begin their romance with code by learning C. The author suggests a few tips for newbies so they can avoid bad coding practices.

    The C programming language is usually the first one that students are taught in most colleges. It is one of the most widely used languages, particularly in systems programming. Here are a few simple tips to avoid some of the most common pitfalls in the language.

    The scanf function and character input

    One common error is due to the characters remaining in the keyboard buffer after an input is executed by a scanf statement.

    When there are two or more consecutive scanf statements in the program and the second or later scanf statement is for character input, it looks as if the scanf statement is skipped. This is because the newline character, \n, which was input due to the return key being pressed by the user, remains in the keyboard buffer. If the next scanf is for character input, the newline character is taken as the input for the character variable.

    <pre class="crayon-plain-tag">scanf(“%d”, &num);

    scanf (“%c”, &chr);</pre>

    This does not happen for the integer input, as the %d symbol for integers forces all leading white spaces and special characters in the input stream to be skipped.

    This situation can be avoided by using a space before %c. The space character will ensure that the scanf statement skips the leading white spaces and special characters, and the above problem can be avoided.

    <pre class="crayon-plain-tag">scanf(“%d”, &num);

    scanf (“ %c”, &chr); /*space character added before %c */</pre>

    The fflush function

    The fflush function can also be used for flushing the keyboard buffer.

    <pre class="crayon-plain-tag">fflush (stdin);</pre>

    But the fflush function is avoided by many as it is undefined in the C standard for the input stream.

    Magic numbers

    When a number suddenly appears in some part of a program without any background or explanation, it is said to be a magic number. The introduction of magic numbers is a result of poor programming practices and also due to writing a program without thinking it through.

    For example:

    <pre class="crayon-plain-tag">for (i=0; i<10; i++)

    scanf(“ %d”, &a[i]);</pre>

    The above code is used to input an array of integers of size 10. The number 10 has to be used repeatedly to mention the size of the array when processing it. Also, the related numbers have to be used, like 10-1, 10+1, etc.

    If the size of the array has to be changed for some reason, changing the number ‘10’ to some other number has to be done in multiple places. This introduces a scope for error, as there is a chance that one or more occurrences of the number may be missed.

    Defining the list size using #define will avoid this problem, as shown below:

    <pre class="crayon-plain-tag">#define SIZE 10</pre>

    Constant on the left hand side

    When checking for equality, one of the “=” signs is inadvertently left out and the assignment operator “=” is typed instead of “==”, the latter being the relational operator to test equality in a comparison statement. But it is not an error as per the C compiler and is treated as an assignment statement. Hence, the if statement returns true as long as the value assigned is not zero, and this bug is difficult to detect.

    <pre class="crayon-plain-tag">If (i = 10) /* beg your pardon for using a magic number! */

    {

    ….

    ….

    }</pre>

    The above lines assign 10 to the variable ‘i’ and then test whether the value of i is true (non-zero) or false (0). Since the value of i always results in 10, the result of the Boolean expression will always be true.

    The best way to prevent such bugs in the program is to write the constant on the left hand side. The compiler will flag an error if “=” is written instead of “==” since a constant cannot be assigned a value.

    <pre class="crayon-plain-tag">If (10 == i)

    {

    ….

    ….

    }</pre>

    Naming of variables

    Care should be taken when naming variables. It is better to use i, j, k, m and n as names of integer variables; x, y and z for float (or double) variables; and a, b and c as names of arrays or coefficients so as to make the program easy to read and to reduce the effort to understand the code.

    Avoid using similar looking characters like 1 and l as these could be interpreted wrongly by the reader1.

    Beginners can go through the best practices for the naming of variables and functions, and follow a particular standard, consistently.

    Avoid using the gets function

    Many beginners use the gets function to input a string. Since it does not have a way to limit the size of the input string, input data can be bigger than the allocated space for the input, which will result in buffer overflow. The gets function has been deprecated in the C99 standard, and has been removed from the latest C11 standard. I am writing about the gets function as I have seen Turbo C being used even by MCA students in a few colleges in India!

    The fgets function can be used to avoid the above mentioned problem, as the maximum length of the characters that can be read is given as an argument to the function.

    <pre class="crayon-plain-tag">#define MAX 20

    ….

    char name[MAX];

    fgets (name, MAX, stdin);

    …</pre>

    Commenting out blocks of code

    The C language does not allow nesting of comments. Hence, the /* and */ symbols cannot be used to comment out sections of the code temporarily for testing purposes.

    Fortunately, the #if… # endif preprocessor directive can be used to leave out blocks of code from being compiled.

    <pre class="crayon-plain-tag">#if 0

    ……..

    ……..

    #endif</pre>

    The above method makes it easy to comment out large sections of code temporarily.


    每天推荐一个 GitHub 优质开源项目和一篇精选英文科技或编程文章原文,欢迎关注开源日报。交流QQ群:202790710;微博:https://weibo.com/openingsource;电报群 https://t.me/OpeningSourceOrg

    The post 2018年6月27日:开源日报第111期 appeared first on 开源工场.

    https://openingsource.org/2606/


 

友情链接:哈陆lu的博客 WebSocks 主机博客 Mr.Kevin 逗比根据地

本论坛所有内容除特殊注明均为原创。除作者特殊要求外,本站所有内容采用知识共享署名 4.0 国际许可协议进行许可。
知识共享许可协议