C语言必备的常用的代码

简介: C语言常用的代码

C语言经常需要发明各种轮子,为方便以后能够把精力放在应用逻辑上而不在发明轮子上,把一些常用的代码片段列于此。

首先是字符串处理方面的,strcpy 函数容易越界,习惯使用 strncpy 函数,但此函数只管复制最多 n 个字符,并不会把末尾的字符自动修改为 '\0',所以给它加上这个操作:
char utils_strncpy (char dest, const char src, size_t length)
{
strncpy (dest, src, length);
dest[length] = '\0';
return dest;
} 内存分配函数 malloc 分配内存却不进行初始化,给它也加上初始化的操作:
void
utils_malloc (size_t size)
void ptr = malloc (size);
if (ptr != NULL)
memset (ptr, 0, size);
return ptr;
} 内存释放函数 free 只是释放内存,却不把指针置为空指针,而且对空指针执行 free 也不知道是否安全,于是改造如下:
void utils_free(void **p)
if (p == NULL ||
p == NULL)
return;
free(p); p = NULL;
}
相应的有字符串复制函数:
char utils_strdup (const char ch)
char copy;
size_t length;
if (ch == NULL)
return NULL;
length = strlen (ch);
copy = (char
) utils_malloc (length + 1);
if (copy==NULL)
utils_strncpy (copy, ch, length);
return copy;
把字符串中的大写字母改为小写:
int utils_tolower (char word)
size_t i;
size_t len = strlen (word);
for (i = 0; i <= len - 1; i++)
if ('A' <= word[i] && word[i] <= 'Z')
word[i] = word[i] + 32;
return 0;
} 清除字符串首尾的空白字符(空格,\r,\n,\r):
int utils_clrspace (char
word)
char pbeg;
char
pend;
//代码效果参考:http://www.zidongmutanji.com/zsjx/40201.html

size_t len;
if (word == NULL)
return -1;
if (word == '\0')
len = strlen (word);
pbeg = word;
while ((' ' ==
pbeg) || ('\r' == pbeg) || ('\n' == pbeg) || ('\t' == pbeg))
pbeg++;
pend = word + len - 1;
while ((' ' ==
pend) || ('\r' == pend) || ('\n' == pend) || ('\t' == pend))
pend--;
if (pend < pbeg)
word = '\0';
/ Add terminating NULL only if we've cleared room for it /
if (pend + 1 <= word + (len - 1))
pend[1] = '\0';
if (pbeg != word)
memmove (word, pbeg, pend - pbeg + 2);

相关文章
|
4月前
|
NoSQL 编译器 程序员
【C语言】揭秘GCC:从平凡到卓越的编译艺术,一场代码与效率的激情碰撞,探索那些不为人知的秘密武器,让你的程序瞬间提速百倍!
【8月更文挑战第20天】GCC,GNU Compiler Collection,是GNU项目中的开源编译器集合,支持C、C++等多种语言。作为C语言程序员的重要工具,GCC具备跨平台性、高度可配置性及丰富的优化选项等特点。通过简单示例,如编译“Hello, GCC!”程序 (`gcc -o hello hello.c`),展示了GCC的基础用法及不同优化级别(`-O0`, `-O1`, `-O3`)对性能的影响。GCC还支持生成调试信息(`-g`),便于使用GDB等工具进行调试。尽管有如Microsoft Visual C++、Clang等竞品,GCC仍因其灵活性和强大的功能被广泛采用。
133 1
|
4月前
|
存储 C语言
【C语言】基础刷题训练4(含全面分析和代码改进示例)
【C语言】基础刷题训练4(含全面分析和代码改进示例)
|
2月前
|
存储 搜索推荐 C语言
深入C语言指针,使代码更加灵活(二)
深入C语言指针,使代码更加灵活(二)
|
2月前
|
存储 程序员 编译器
深入C语言指针,使代码更加灵活(一)
深入C语言指针,使代码更加灵活(一)
|
2月前
|
C语言
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
|
3月前
|
安全 C语言
在C语言中,正确使用运算符能提升代码的可读性和效率
在C语言中,运算符的使用需要注意优先级、结合性、自增自减的形式、逻辑运算的短路特性、位运算的类型、条件运算的可读性、类型转换以及使用括号来明确运算顺序。掌握这些注意事项可以帮助编写出更安全和高效的代码。
51 4
|
2月前
|
C语言
C语言练习题代码
C语言练习题代码
|
3月前
|
存储 算法 C语言
数据结构基础详解(C语言):单链表_定义_初始化_插入_删除_查找_建立操作_纯c语言代码注释讲解
本文详细介绍了单链表的理论知识,涵盖单链表的定义、优点与缺点,并通过示例代码讲解了单链表的初始化、插入、删除、查找等核心操作。文中还具体分析了按位序插入、指定节点前后插入、按位序删除及按值查找等算法实现,并提供了尾插法和头插法建立单链表的方法,帮助读者深入理解单链表的基本原理与应用技巧。
602 6
|
3月前
|
存储 C语言 C++
数据结构基础详解(C语言) 顺序表:顺序表静态分配和动态分配增删改查基本操作的基本介绍及c语言代码实现
本文介绍了顺序表的定义及其在C/C++中的实现方法。顺序表通过连续存储空间实现线性表,使逻辑上相邻的元素在物理位置上也相邻。文章详细描述了静态分配与动态分配两种方式下的顺序表定义、初始化、插入、删除、查找等基本操作,并提供了具体代码示例。静态分配方式下顺序表的长度固定,而动态分配则可根据需求调整大小。此外,还总结了顺序表的优点,如随机访问效率高、存储密度大,以及缺点,如扩展不便和插入删除操作成本高等特点。
215 5
|
3月前
|
存储 C语言
数据结构基础详解(C语言): 栈与队列的详解附完整代码
栈是一种仅允许在一端进行插入和删除操作的线性表,常用于解决括号匹配、函数调用等问题。栈分为顺序栈和链栈,顺序栈使用数组存储,链栈基于单链表实现。栈的主要操作包括初始化、销毁、入栈、出栈等。栈的应用广泛,如表达式求值、递归等场景。栈的顺序存储结构由数组和栈顶指针构成,链栈则基于单链表的头插法实现。
418 3