C语言8个实用方法代码优化
1、选择合适的算法和数据结构
选择一种合适的数据结构很重要,如果在一堆随机存放的数中使用了大量的插入和删除指令,那使用链表要快得多。数组与指针语包莫有十分密切的关系,一般来说,指针比较灵活简洁,而数组则比较直观,容易理解。对于大部分的编译器,使用指针比使用数组生成的代码更短,执行效率更高
2、使用尽量小的数据类型
能够使用字符型(char)定义的变量,就不要使用整型(int)变量来定义;能够使用整型变量定义的变量就不要用长整型(long int),能不使用浮点型(float)变量就不要使用浮点型变量。当然,在定义变量后不要超过变量的作用范围,如果超过变量的范围赋值,C编译器并不报错,但程序运行结果却错了,而且这样的错误很难发现。
3、减少运算的强度
a、查表(游戏程序员必修课)
一个聪明的游戏大虾,基本上不会在自己的主循环里搞什么运算工作,绝对是先计算好了,再到循环里查表。如果表很大,不好写,就写一个init函数,在循环外临时生成表格。
b、求余运算
位操作只需一个指令周期即可完成,而大部分的C编译器的“%”运算均是调用子程序来完成,代码长、执行速度慢。通常,只要求是求2n方的余数,均可使用位操作的方法来代替。
4、结构体成员的布局
a、按数据类型的长度排序
把结构体的成员按照它们的类型长度排序,声明成员时把长的类型放在短的前面。编译器要求把长型数据类型存放在偶数地址边界。
b、把结构体填充成最长类型长度的整倍数
把结构体填充成最长类型长度的整倍数。照这样,如果结构体的第一个成员对齐了,所有整个结构体自然也就对齐了。
5、循环优化
a、充分分解小的循环
要充分利用CPU的指令缓存,就要充分分解小的循环特别是当循环体本身很小的时候,分解循环可以提高性能。注意,很多编译器并不能自动分解循环。
b、提取公共部分
对于一些不需要循环变量参加运算的任务可以把它们放到循环外面,这里的任务包括表达式、函数的调用、指针运算、数组访问等,应该将没有必要执行多次的操作全部集合在一起,放到一个init的初始化程序中进行。
6、提高CPU的并行性
a、使用并行代码
尽可能把长的有依赖的代码链分解成几个可以在流水线执行单元中并行执行的没有依赖的代码链。很多高级语言,包括C++,并不对产生的浮点表达式重新排序,因为那是一个相当复杂的过程。
b、避免没有必要的读写依赖
当数据保存到内存时存在读写依赖,即数据必须在正确写入后才能再次读取。虽然AMD Athlon等CPU有加速读写依赖延迟的硬件,允许在要保存的数据被写入内存前读取出来,但是,如果避免了读写依赖并把数据保存在内部寄存器中,速度会更快。
7、循环不变计算
对干一些不需要循环变量参加运算的计算任务可以把它们放到循环外面,现在许多编译器还是能自己干这件事,不过对干中间使用了变量的算式它们就不敢动了,所以很多情况下你还得自己干。对于那些在循环中调用的函数,凡是没必要执行多次的操作通通提出来放到一个init函数里,循环前调用。另外尽量减少喂食次数,没必要的话尽量不给它传参,需要循环变量的话让它自己建立一个静态循环变量自己累加,速度会快一点。
8、采用递归
与LISP之类的语言不同,C语言一开始就病态地喜欢用重复代码循环,许多C程序员都是除非算法要求,坚决不用递归。
事实上,C编译器们对优化递归调用一点都不反感,相反,它们还很喜欢干这件事。只有在递归函数需要传递大量参数,可能造成瓶颈的时候,才应该使用循环代码,其他时候,还是用递归好些。
C语言有哪些实用的编程方法?
C语言8个实用方法代码优化 1、选择合适的算法和数据结构 选择一种合适的数据结构很重要,如果在一堆随机存放的数中使用了大量的插入和删除指令,那使用链表要快得多。数组与指针语包莫有十分密切的关系,一般来说,指针比较灵活简洁,而数组则比较直观,容易理解。对于大部分的编译器,使用指针比使用数组...
一些有关C语言中实用且很牛的技能!
二、数组 我们可以指定数组的元素来进行初始化。这非常有用,特别是当我们需要根据一组#define来保持某种映射关系的同步更新时。现在,假设我们想为每个错误码提供一个错误描述的字符串。为了确保数组保持了最新的定义,无论头文件做了任何修改或增补,我们都可以用这个数组指定的语法。这样就可以静态分配足...
C语言可以用来开发哪些项目?这些方向你应该看看非常有趣
基础应用:C语言可以开发简单的计算器,实现基本的加减乘除功能,以此入门编程概念。 通讯管理:尝试用C语言实现一个通讯录程序,涉及结构体、数组和链表,有助于理解数据结构。 并发通信:通过C语言和epoll实现高并发聊天室,学习并发处理和客户端服务器架构。 实用工具:如万年历,输入年月后显示...
c语言有哪些算法
排序算法是数据处理中非常基础的算法之一。在C语言中,常用的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序等。这些排序算法可以用于对数组、列表或其他数据结构进行排序操作。每种排序算法都有其特点和适用场景。搜索算法 搜索算法是用于在数据结构中查找特定元素的算法。在C语言中,常见的搜...
c语言的算法有哪些
C语言的算法主要包括排序算法、查找算法、数据结构相关算法、字符串处理算法等。C语言作为编程语言中的一种,它本身的特性并没有特定的算法与之对应。但是,在进行编程的过程中,根据需求不同会设计到各种算法的应用。以下是关于C语言中常见算法的 排序算法:排序是数据处理中非常常见的操作,C语言中常用的...
C语言中除了使用函数pow实现乘方运算,还有什么方法?
1、操作系统,C语言最著名的应用领域就是操作系统了,目前所有的操作系统内核都是C语言写的,最著名的就是Unix和Linux了。2、单片机,由于C语言在位操作上的优越性,在单片机领域,C语言也一直独领风骚,虽然现在出现了一些用其他编程语言操作单片机的方法,但也都是用C语言封装过的,可以说核心还是C...
C语言的怎样编程啊?
编程的东西太多了,我就说scanf,printf吧。1.首先要应用这两个函数就要导入一个包所以要在前面加一个宏定义#include<stdio.h> 2.然后就是写一个main函数这是程序的入口void main(){} 3.要输入的话,首先的定义一个变量来存储你输入的东西。如int no;或char name[20];然后写一个输入函数,scanf...
c语言有哪10种方法提高运行速度?
强制高c的10种方法具体如下:强制高C的十种方法是使用优化,使用内存池,使用平行化编程,使用向量化编程,减少函数调用,使用循环展开,将数据读取到缓存,编写高效的算法,使用高效的数据结构,减少对象的拷贝。使用优化。使用各种优化技术可以提高程序的运行速度。例如,在编译器中启用编译器优化选项、使用...
学习计算机专业中的C 语言都有哪些方法?
学习计算机专业中的C语言是进入编程世界的重要一步,因为C语言不仅是许多高级编程语言的基础,也是理解计算机底层原理的钥匙。以下是一些有效的学习方法:1. 理论学习 阅读教材:选择一本适合初学者的C语言教材,如《C程序设计语言》等,系统学习C语言的基本语法、数据类型、运算符、控制结构等基础知识。在线...
怎样使用C语言进行编程?
1、首先,编写头文件以及main函数主框架。2、接下来可以for语句给他赋值。3、为了方便测试,可以将其输出。4、然后我们点击编译运行按钮。5、这个时候便可以看到如下图效果。注意事项:尽管C语言提供了许多低级处理的功能,但仍然保持着跨平台的特性,以一个标准规格写出的C语言程序可在包括类似嵌入式处理...