【C语言】如何写出好的代码?

这篇具有很好参考价值的文章主要介绍了【C语言】如何写出好的代码?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

哈喽,大家好,今天我们来学习如何才能写出优秀的代码,主要讲的是assertconst的用法。

【C语言】如何写出好的代码?

 首先,什么样的代码才算的上是优秀的代码呢?应该符合下面的要求:

1. 代码运行正常

2. bug很少

3. 效率高

4. 可读性高

5. 可维护性高

6. 注释清晰

7. 文档齐全

 常见的coding技巧:

1. 使用assert

2. 尽量使用const

3. 养成良好的编码风格

4. 添加必要的注释

5. 避免编码的陷阱。

今天我们主要讲的是assert和const。

assert

assert 是一个 C 语言标准库函数,用于在程序运行时对某个条件进行检测,如果该条件的值为假,则会使程序失败并终止运行,并将错误信息输出到 stderr 流。

assert 的作用是在程序运行时,检查某个条件是否成立,如果条件不成立,则表示程序的状态出现了错误,此时就会终止程序执行,打印出错信息。通过使用 assert 可以提高代码的健壮性和可靠性。assert 通常在程序中用来检查某些不可恢复的错误,例如内部逻辑出错,逻辑异常等等,当这些错误发生时,直接停止程序的运行可以让开发者快速定位问题。

const

在 C 语言中, const 关键字用于定义常量。const 可以用来修饰变量、函数参数、函数返回值等。

在变量声明时使用 const 关键字,可以定义一个值不能改变的常量,如下所示:

const int a = 10;

使用 const 关键字定义的常量,在编译时就会在符号表中分配空间,并赋予其一个确定的地址,因而不可以被修改。如果在程序中试图修改 const 类型的常量的值,那么编译器就会在编译时发现并报错。

在函数定义或声明中使用 const 关键字,可以将函数参数或函数返回值设置为常量,如下所示:

int func(const int arg1, const int arg2);

const int func2(void);

这些语法规则表明函数不会改变函数参数或返回值,可以方便调用者判断程序背后的逻辑,也同时可以保证被调用的函数不会无意间修改其他变量的值,增加了代码的可靠性。

总的来说,使用 const 关键字可以帮助程序员在编写程序时发现潜在的错误,提高代码的健壮性,并增加代码可读性。

示范:

模拟实现库函数:strcpy

 一般写法:

void my_strcpy(char* dest, char* src)
{
	while (*src != '\0')
	{
		*dest = *src;
		dest++;
		src++;
	}
	*dest = *src;//'\0'的拷贝
}

int main()
{
	char arr1[] = "hello world";
	char arr2[20] = "xxxxxxxxxxxxxxx";
	my_strcpy(arr2, arr1);
	printf("%s\n", arr2);
	return 0;
}

 程序可以正常运行:

【C语言】如何写出好的代码?

 但是如果我们在函数实参中传入一个空指针,程序就会崩溃,没有任何错误信息提示:

【C语言】如何写出好的代码?

 使用assert后:

【C语言】如何写出好的代码?

 虽然程序仍然会崩溃,但此时有了错误信息提示:

【C语言】如何写出好的代码?

 当然,代码可以简化:

【C语言】如何写出好的代码?

如果想要函数返回目的字符串的地址:

【C语言】如何写出好的代码?

 即使是这样,代码还是不够优秀,我们还能继续加强代码的健壮性:

因为我们只需要改变dest所指向的内容,而src所指向的内容不需要改变,为了防止在写程序的过程中把src所指向的内容改变,我们可以在*src前面加上关键字const

【C语言】如何写出好的代码?

在 C 语言中,const 可以用于以下几个方面:

1.定义常量

使用 const 关键字可以定义常量,常量的值不能被修改,例如:

【C语言】如何写出好的代码?

2.常量指针

使用 const 关键字可以定义常量指针,即指针本身不能修改其指向的地址,例如:

【C语言】如何写出好的代码?

上述代码定义了一个指针 p,其类型为 const char *,即指针本身不能修改,同时指向的地址里的值也不能修改。

3.指向常量的指针

使用 const 关键字可以定义指向常量的指针,即指针指向地址中的值不能被修改,例如:

【C语言】如何写出好的代码?

 上述代码定义了一个指针 p,其类型为 char * const,即指针指向的地址本身不能修改,但是地址中存储的值可以被修改。

const int *p,int const  *p(指向常变量的指针变量,可以指向常变量,还可以指向未被声明为const的变量,但此时只能修改指向地址,不能修改值,可以修改指向的那个变量的值,不能用本身对指针变量地址修改的方式来修改值,如果一个变量已经被声明为常变量,不能用它进行初始化别的变量,而且只能用常变量的指针去指向它,而不能用一般的非const类型指针变量去指向它。)

int * const p(指向变量的常指针,只能修改值,不能修改指向地址

总结:指向常变量的指针变量除了可以指向常变量,还可以指向未被声明为const的变量,此时可以通过指针变量访问该变量,但不能通过此指针变量改变该变量的值。如果不是通过指针变量来访问,则变量的值是可改变的,
注意:定义了指向常变量的指针变量p并使它指向了c1,并不意味着把c1也声明为常变量,而只是在用指针变量访问c1期间,c1具有常量的特征,其值不能改变,其他情况下,c1仍然是一个普通的变量,其值是可以改变的。

当const修饰指针的时候:

        当const放在 * 的左边的时候,限制的是指针指向的内容,不能通过指针变量改变指针指向的内容,但指针变量本身是可以改变的。

        当const放在 * 的右边的时候,限制的是指针变量本身,指针变量本身是不可以改变的,但是指针指向的内容是可以通过指针改变的

总的来说,const 关键字可以用来限制变量、指针、函数参数、函数返回值等的使用,从而提高程序的可读性、可维护性和安全性,是 C 语言中一个非常重要的关键字。

模拟实现strlen函数

【C语言】如何写出好的代码?文章来源地址https://www.toymoban.com/news/detail-490388.html

到了这里,关于【C语言】如何写出好的代码?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 想必大家都为测试用例头疼过,那么如何才能设计出一个“好的”测试用例

    目录 前言: “好的”测试用例具备的特征 1.等价类划分方法 2.边界值分析方法 “好的”测试用例的设计方法 测试用例设计的其他经验 作为测试人员,需要注意以下几点: 前言: 设

    2024年02月08日
    浏览(46)
  • MacBook pro今天开机屏幕不亮了,其它什么都好的,键盘也亮的,声音软件都好的...

    MacBook pro前两天从柜子上摔下来了,开机后发现屏幕不亮,其余的键盘灯,开机声音,显示器背面的logo也是亮的。自己试了很多网上的方法都不行。   有两种可能性: 1.可能是屏幕排线松动引起的屏幕无法显示图像。 2.可能是主板损坏,导致屏幕无法显示图像。  拿去华强

    2024年02月16日
    浏览(84)
  • 如何写出高质量代码?

    作为一名资深开发人员,写出高质量的代码是我们必须要追求的目标。然而,在实际开发中,我们常常会遇到各种问题。比如,代码的可读性、可维护性、健壮性和灵活性等,这些都会影响代码的质量。那么,究竟如何才能写出高质量的代码呢? 代码结构清晰易懂,能够使代

    2024年02月02日
    浏览(52)
  • 如何写出高质量代码

    一、 前言 编写高质量代码是每一位程序员的追求。高质量的代码可以提高代码可读性、可维护性、可扩展性以及软件运行的性能和稳定性。在这篇文章中,我将分享一些编写高质量代码的特征、编程实践技巧和软件工程方法论。 可读性:好的代码应该能够被维护者轻易地理

    2024年02月02日
    浏览(81)
  • 如何写出高质量的代码

    你是否曾经为自己写的代码而感到懊恼?你是否想过如何才能写出高质量代码?那就不要错过这个话题!在这里,我们可以讨论什么是高质量代码,如何写出高质量代码等问题。无论你是初学者还是资深开发人员,都可以在这个话题下进行分享,汲取灵感和知识,共同提高自

    2023年04月25日
    浏览(122)
  • 今天跟大家推荐几款实用的ai写作生成器

    自ai技术的发展以来,人工智能在各个领域都展现出了无限可能。在学术界,写作论文是科研人员不可避免的重要任务,然而,论文写作需要大量的时间和经验技能,而这对刚刚步入学术领域的年轻科研人员来说尤为困难。在这样的背景下,提高写作效率、降低人力成本、缩

    2024年02月13日
    浏览(43)
  • 今天跟大家分享好用的智能ai绘画免费软件有哪些

    在教学的时候配合进行ai绘画操作来讲解日常的知识,可以帮助学生更好的理解,比如在讲解化学反应的时候,我们可以通过文字描述反应的化学式和反应过程,但是这可能会让学生感到无趣和枯燥,知识没办法真正的进入大脑。而如果借助ai绘画的软件,我们可以将反应的过

    2024年02月12日
    浏览(46)
  • 今天给大家介绍一下华为智选手机与华为手机的区别

    华为智选手机是由华为品牌方与其他公司合作推出的手机产品,虽然其机身上没有“华为”标识,但是其品质和技术水平都是由华为来保证的。这些手机在制造、设计和使用方面都采用了华为的相关技术和标准,因此可以享受到和华为旗舰手机相同的优质使用体验。    目前

    2024年02月09日
    浏览(48)
  • 今天跟大家好好介绍一下接口工具(jmeter、postman、swagger等)

    一、接口都有哪些类型? 接口一般分为两种:1.程序内部的接口 2.系统对外的接口 系统对外的接口:比如你要从别的网站或服务器上获取资源或信息,别人肯定不会把 数据库共享给你,他只能给你提供一个他们写好的方法来获取数据,你引用他提供的接口就能使用他写好的

    2024年02月05日
    浏览(51)
  • 27岁,没有学历,没有技术,大家有什么好的职业发展建议吗?

    我们常常把人的学习能力划分为三个阶段,25岁以前的黄金期,25-28岁的白银期,28-33岁以后的青铜期。主要依据无外乎个人的学习能力、记忆力和精力、生活压力等各方面因素综合考量而来的。一般都是越年轻越有活力,思维更敏捷,学习东西也更快;但也不是说年龄大了就

    2023年04月27日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包