C语言函数大全
本篇介绍C语言函数大全-- l 开头的函数
1. labs,llabs
1.1 函数说明
函数声明 | 函数功能 |
---|---|
long labs(long n); | 计算长整型的绝对值 |
long long int llabs(long long int n); | 计算long long int 类型整数的绝对值 |
1.2 演示示例
#include <stdio.h>
#include <stdlib.h>int main(void)
{long result;long x = -12345678L;result= labs(x);printf("number: %ld , abs value: %ld\n", x, result);long long resultL;long long int xL = -1234567890123456789;resultL = llabs(xL);printf("The absolute value of %lld is %lld\n", xL, resultL);return 0;
}
1.3 运行结果
2. ldexp,ldexpf,ldexpl
2.1 函数说明
函数声明 | 函数功能 |
---|---|
double ldexp(double x, int exp); | 计算 x 乘以 2 的指定次幂(double) |
float ldexpf(float x, int exp); | 计算 x 乘以 2 的指定次幂(float) |
long double ldexpl(long double x, int exp); | 计算 x 乘以 2 的指定次幂(long double) |
2.2 演示示例
#include <stdio.h>
#include <math.h>int main()
{int n = 3;double x = 3.5, result;result = ldexp(x, n);float xf = 3.5f, resultf;resultf = ldexpf(xf, n);long double xL = 3.5L, resultL;resultL = ldexpl(xL, n); printf("ldexp(%lf, %d) = %lf\n", x, n, result);printf("ldexpf(%f, %d) = %f\n", xf, n, resultf);printf("ldexpl(%Lf, %d) = %Lf\n", xL, n, resultL);return 0;
}
注意:ldexp,ldexpf,ldexpl 函数会对参数进行溢出和下溢处理,因此可以处理很大或很小的数值。
2.3 运行结果
3. ldiv,lldiv
3.1 函数说明
函数声明 | 函数功能 |
---|---|
ldiv_t ldiv(long int numer, long int denom); | 计算两个 long int 类型整数的商和余数 |
lldiv_t lldiv(long long int numer, long long int denom); | 计算两个 long long int 类型整数的商和余数 |
参数:
- numer : 被除数
- denom : 除数
ldiv
函数的返回值类型 ldiv_t
是一个结构体类型,定义如下:
typedef struct {long int quot; // 商long int rem; // 余数
} ldiv_t;
lldiv
函数的返回值类型 lldiv_t
是一个结构体类型,定义如下:
typedef struct {long long int quot; // 商long long int rem; // 余数
} lldiv_t;
3.2 演示示例
#include <stdio.h>
#include <stdlib.h>int main()
{long int numer = 1234567890;long int denom = 987654321;ldiv_t result;result = ldiv(numer, denom);printf("%ld / %ld = %ld, %ld %% %ld = %ld\n", numer, denom, result.quot, numer, denom, result.rem);long long int numerL = 1234567890123456789LL;long long int denomL = 987654321LL;lldiv_t resultL;resultL = lldiv(numerL, denomL);printf("%lld / %lld = %lld, %lld %% %lld = %lld\n", numerL, denomL,resultL.quot, numerL, denomL, resultL.rem);return 0;
}
注意: 如果 denom 参数为零,则
ldiv()
函数会产生一个异常情况。此外,如果两个参数中有一个或两个都是负数,则商和余数的计算规则将根据 C 标准进行调整。
3.3 运行结果
4. lfind
4.1 函数说明
函数声明 | 函数功能 |
---|---|
void *lfind(const void *key, const void *base, size_t nmemb, size_t size, int (*compar)(const void *, const void *)); | 它是标准 C 库函数 <search.h> 中的一个函数,用于在一个数组中查找指定元素。 |
参数:
- key : 要查找的元素
- base : 要查找的数组的首地址
- nmemb : 数组元素个数
- size : 每个数组元素的大小(以字节为单位)
- compar : 比较函数,用于比较数组元素和要查找的元素。compar 函数需要返回一个整数值,表示两个元素之间的关系:
- 如果第一个元素小于第二个元素,则返回一个负数。
- 如果第一个元素等于第二个元素,则返回零。
- 如果第一个元素大于第二个元素,则返回一个正数。
4.2 演示示例
#include <stdio.h>
#include <stdlib.h>
#include <search.h>int compare(const void *a, const void *b)
{return (*(int*)a - *(int*)b);
}int main()
{int arr[] = {1, 2, 3, 4, 5};int n = sizeof(arr) / sizeof(arr[0]);for (int i = 0; i < n; i++)printf("%d ", arr[i]);unsigned int * number = (unsigned int *)&n;int key = 2;int *result;result = (int *)lfind(&key, arr, number, sizeof(int), compare);if (result != NULL) {printf("\n%d is found at index %lld\n", key, result - arr);} else {printf("\n%d is not found in the array\n", key);}return 0;
}
注意:
lfind()
函数使用线性搜索算法,因此对于大规模数据可能不太适用。除此之外,该函数还有一些变种函数,例如bsearch()
和tfind()
等,也可以用于在数组或树结构中查找元素。
4.3 运行结果
5. line
5.1 函数说明
函数声明 | 函数功能 |
---|---|
void line( int x1, int y1, int x2, int y2); | 在指定两点间画一直线 |
参数:
(x1, y1) : 第一个点的坐标
(x2, y3) : 第二个点的坐标
5.2 演示示例
#include <graphics.h>int main(void)
{int gdriver = DETECT, gmode;int xmax, ymax;initgraph(&gdriver, &gmode, "");setcolor(getmaxcolor());xmax = getmaxx();ymax = getmaxy();// 在(0,0) 和(xmax, ymax)之间画一直线line(0, 0, xmax, ymax);// 在(0,ymax) 和(xmax, 0)之间画一直线line(0, ymax, xmax, 0);/* clean up */getch();closegraph();return 0;
}
5.3 运行结果
6. linerel
6.1 函数说明
函数声明 | 函数功能 |
---|---|
void linerel(int dx, int dy); | 从当前位置绘制一条指定长度和方向的线段。 |
参数:
- dx : 线段在 X 轴上的位移量
- dy : 线段在 Y 轴上的位移量
6.2 演示示例
#include <graphics.h>int main()
{int gd = DETECT, gm;initgraph(&gd, &gm, "");moveto(100, 100); // 将当前点移动到 (100, 100)linerel(50, 0); // 绘制长度为 50,方向为水平(X 轴正方向)的线段linerel(0, 50); // 绘制长度为 50,方向为垂直(Y 轴正方向)的线段linerel(-50, 0); // 绘制长度为 50,方向为水平(X 轴反方向)的线段linerel(0, -50); // 绘制长度为 50,方向为垂直(Y 轴反方向)的线段getch();closegraph();return 0;
}
6.3 运行结果
7. lineto
7.1 函数说明
函数声明 | 函数功能 |
---|---|
void lineto(int x, int y); | 从当前位置绘制一条直线到指定位置 |
参数:
x : 线段终点的 X 坐标
y : 线段终点的 Y 坐标
7.2 演示示例
#include <graphics.h>int main()
{int gd = DETECT, gm;initgraph(&gd, &gm, "");moveto(100, 100); // 将当前点移动到 (100, 100)lineto(150, 150); // 绘制一条从当前点到 (150, 150) 的线段lineto(200, 100); // 绘制一条从当前点到 (200, 100) 的线段lineto(150, 50); // 绘制一条从当前点到 (150, 50) 的线段lineto(100, 100); // 绘制一条从当前点到 (150, 50) 的线段getch();closegraph();return 0;
}
7.3 运行结果
8. localtime
8.1 函数说明
函数声明 | 函数功能 |
---|---|
struct tm *localtime(const time_t *timep); | 将 UNIX 时间戳转换为本地时间 |
参数:
- timep : 指向 time_t 类型的指针,表示要转换的 UNIX 时间戳
返回值:
- struct tm * : 一个指向 struct tm 类型的指针,该结构体包含了表示本地时间的各个字段,例如年、月、日、时、分、秒等。
8.2 演示示例
#include <stdio.h>
#include <time.h>int main()
{time_t now;struct tm *local;now = time(NULL); // 获取当前时间戳local = localtime(&now); // 将当前时间戳转换为本地时间printf("Current date and time: %s\n", asctime(local));return 0;
}
注意: 在使用
localtime()
函数时需要注意结构体中的字段值是否正确,例如月份、星期等的表示方式可能因不同系统而异。
8.3 运行结果
9. lock
9.1 函数说明
函数声明 | 函数功能 |
---|---|
int lock(int fd, int cmd, off_t len); | 它是标准 C 库函数 <fcntl.h> 中的一个函数,用于对文件进行加锁或解锁操作 |
参数:
- fd : 文件描述符
- cmd : 要执行的加锁或解锁操作(例如 F_LOCK、F_ULOCK 等)
- len : 要锁定的字节数。
返回值:
返回一个整数值表示操作是否成功,若成功则返回 0,否则返回 -1
9.2 演示示例
#include <stdio.h>
#include <fcntl.h>int main()
{int fd;char buf[128];int nbytes;fd = open("test.txt", O_RDWR | O_CREAT, 0666);if (fd == -1) {perror("open");return 1;}// 加锁if (lock(fd, F_LOCK, 0) == -1) {perror("lock");return 1;}// 写入数据sprintf(buf, "Hello, world!\n");nbytes = write(fd, buf, sizeof(buf));if (nbytes == -1) {perror("write");return 1;}// 解锁if (lock(fd, F_ULOCK, 0) == -1) {perror("unlock");return 1;}close(fd);return 0;
}
上述示例程序中,首先通过 open()
函数打开一个名为 test.txt
的文件,并设置文件访问模式为可读写。接着,调用 lock()
函数对该文件进行加锁操作,保护写入数据的过程。然后,通过 write()
函数将数据写入到文件中。最后,调用 lock()
函数对该文件进行解锁操作,释放锁定的资源。
注意: 在使用
lock()
函数时需要注意加锁和解锁的顺序、范围等问题,否则可能会造成死锁或其他问题。此外,该函数只适用于文件系统,不能用于套接字等其他类型的文件描述符。
10. log
10.1 函数说明
函数声明 | 函数功能 |
---|---|
double log(double x); | 计算自然对数 |
参数:
- x : 要计算自然对数的数字。
返回值:
- x 的自然对数,即
ln(x)
。
10.2 演示示例
#include <stdio.h>
#include <math.h>int main()
{double x = 2.0;double result = log(x);printf("The natural logarithm of %lf is %lf.\n", x, result);return 0;
}
注意: 由于
log()
函数接受的参数和返回值都是double
类型,因此在使用时需要保证传入的参数类型正确,避免发生精度损失等问题。同时,log()
函数的参数不能为负数或零,否则会产生不可预知的行为。
10.3 运行结果
11. log10
11.1 函数说明
函数声明 | 函数功能 |
---|---|
double log10(double x); | 计算以 10 为底的对数 |
参数:
- x : 要计算以 10 为底的对数的数字
返回值:
- x 的以 10 为底的对数,即
log10(x)
11.2 演示示例
#include <stdio.h>
#include <math.h>int main()
{double x = 100.0;double result = log10(x);printf("The logarithm base 10 of %lf is %lf.\n", x, result);return 0;
}
11.3 运行结果
12. longjmp
12.1 函数说明
函数声明 | 函数功能 |
---|---|
void longjmp(jmp_buf env, int val); | 跳转到指定的程序位置并恢复相应的上下文环境 |
参数:
- env : 保存上下文环境的缓冲区
- val : 跳转时返回的值
注意:在使用
longjmp()
函数之前,需要先调用setjmp()
函数来设置上下文环境,并将其保存在jmp_buf
数据类型中。然后,在程序执行过程中,如果需要跳转到之前设定的位置,就可以使用longjmp()
函数进行跳转和上下文恢复。
12.2 演示示例
#include <stdio.h>
#include <setjmp.h>jmp_buf buf;void do_something()
{printf("do_something() start.\n");// 跳转到 setjmp() 处longjmp(buf, 1);printf("do_something() end.\n");
}int main()
{int val = 0;// 设置上下文环境if (setjmp(buf) == 0) {printf("setjmp() called.\n");do_something();} else {printf("longjmp() called.\n");val = 1;}printf("Program ends with value %d.\n", val);return 0;
}
上述示例程序中,首先在主函数中调用 setjmp()
函数设置上下文环境,并将其保存在 buf 变量中。然后,程序调用 do_something()
函数,在其中调用 longjmp()
函数跳转到之前设定的位置,并返回值为 1。
由于 longjmp()
调用后不会返回到调用它的位置,因此 do_something()
函数在被调用后并未执行完毕,而是直接跳转到了 setjmp()
所在的位置。当程序回到 setjmp()
处时,检测到了从 longjmp()
跳转过来的信号,并返回值为 1,表示跳转成功。
最后,程序输出 "Program ends with value 1."
,结束运行。
注意: 使用
longjmp()
和setjmp()
函数进行跳转时,必须保证跳转的目标位置和之前设置的上下文环境是兼容的,否则可能会导致程序崩溃或其他严重问题。同时,尽管longjmp()
可以快速跳出当前函数或代码块,但在实际应用中应该尽量避免使用它,以免造成代码逻辑混乱和难以调试的问题。
12.3 运行结果
13. lowvideo
13.1 函数说明
函数声明 | 函数功能 |
---|---|
void lowvideo(void); | 用于将文本颜色设置为低对比度模式 |
13.2 演示示例
#include <conio.h>int main(void)
{clrscr(); // 清空屏幕highvideo(); // 将文本颜色设置为高对比度模式cprintf("High Intesity Text\r\n");lowvideo(); // 将文本颜色设置为低对比度模式gotoxy(1,2); // 将光标移动到指定的坐标 (x, y),其中 x 和 y 分别为列和行数cprintf("Low Intensity Text\r\n");return 0;
}
当该程序运行时,首先清空了控制台屏幕,然后将文本颜色设置为高对比度模式并输出一段文本。接着,将文本颜色设置为低对比度模式,并将光标移动到第二行第一个字符位置,输出另外一段文本。最后,程序执行结束,并返回 0。
注意:
<conio.h>
头文件中的函数在不同的操作系统和编译器下可能会有所不同,并且并非所有的平台都支持低对比度文本模式。在实际应用中,应该避免过度使用低对比度模式,以免影响用户体验和可读性。
14. _lrotl
14.1 函数说明
函数声明 | 函数功能 |
---|---|
unsigned long _lrotl(unsigned long value, int shift); | 它是 Windows 系统特有的函数,用于将 32 位无符号整数按位循环左移。 |
参数:
- value : 要进行循环左移的 32 位无符号整数
- shift : 左移的位数
返回值:
- 左移后的结果。
14.2 演示示例
#include <stdlib.h>
#include <stdio.h>int main()
{unsigned long result;unsigned long value = 2;result = _lrotl(value, 2);printf("The value %lu rotated left one bit is: %lu\n", value, result);return 0;
}
注意:
_lrotl()
函数是 Windows 系统特有的函数,在其他操作系统或编译器下可能不可用或使用方式有所不同。此外,由于该函数只适用于 32 位无符号整数,如果需要对 64 位整数进行位移操作,则需要使用其他函数。
14.3 运行结果
15. lsearch
15.1 函数说明
函数声明 | 函数功能 |
---|---|
void *lsearch(const void *key, void *base, size_t *nelp, size_t width, int (*compar)(const void *, const void *)); | 用于在指定的数组中查找指定元素,并返回该元素在数组中的地址 |
参数:
- key : 要查找的元素指针
- base : 要进行查找的数组首地址
- nelp : 当前数组中元素的个数
- width : 数组中每个元素所占用的字节数
- compar : 比较函数指针,用于比较两个元素的大小关系。
15.2 演示示例
#include <stdio.h>
#include <stdlib.h>
#include <search.h>int compare(const void *a, const void *b)
{return *(int *)a - *(int *)b;
}int main()
{int arr[] = { 3, 1, 4, 1, 5, 9, 2, 6, 5 };int len = sizeof(arr) / sizeof(int);int key = 5;int *result = lsearch(&key, arr, &len, sizeof(int), compare);if (result != NULL) {printf("Found %d at index %ld.\n", *result, result - arr);} else {printf("%d not found in the array.\n", key);}return 0;
}
上述示例程序中,首先定义了一个整型数组 arr 并初始化为 { 3, 1, 4, 1, 5, 9, 2, 6, 5 }
。然后,将要查找的元素值 key 设置为 5,并调用 lsearch()
函数在数组中查找该元素。如果找到了,则输出该元素在数组中的下标;否则输出未找到的提示。
注意:
lsearch()
函数在查找数组元素时,只能够找到第一个匹配的元素,并返回其地址。如果数组中存在多个相同的元素,则无法区分它们的位置。此外,使用lsearch()
函数进行查找时,必须保证数组已经按照指定的比较函数从小到大排好序,否则可能会导致查找失败或找到错误的元素。
15.3 运行结果
16. lseek
16.1 函数说明
函数声明 | 函数功能 |
---|---|
long lseek(int handle, long offset, int fromwhere); | 设置文件操作指针,即改变文件读取或写入的位置 |
参数:
- handle : 文件描述符
- offset : 偏移量
- whence : 偏移量的参考位置
- SEEK_SET: 从文件开头开始计算偏移量(即绝对位置)
- SEEK_CUR: 从当前位置开始计算偏移量(即相对位置)
- SEEK_END: 从文件结尾开始计算偏移量(即反向偏移)
返回值:
- 如果成功,则返回新的文件指针位置(即距离文件开头的字节数);
- 如果发生错误,则返回 -1。
16.2 演示示例
#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>int main()
{int fd = open("temp.txt", O_RDWR);if (fd == -1) {printf("Failed to open the file.\n");return -1;}off_t pos = lseek(fd, 5, SEEK_SET);if (pos == -1) {printf("Failed to seek the file.\n");close(fd);return -1;}char buf[10];ssize_t nread = read(fd, buf, 5);if (nread == -1) {printf("Failed to read the file.\n");close(fd);return -1;}buf[nread] = '\0';printf("Read %ld bytes from position %ld: %s\n", nread, pos, buf);close(fd);return 0;
}
上述示例程序中,首先使用 open()
函数打开名为 "temp.txt"
的文件,并获取其文件描述符。然后,调用 lseek()
函数将文件指针移动到距离文件开头 5 个字节处。接着,调用 read()
函数从该位置开始读取 5 个字节的数据,并输出读取结果。
注意:
lseek()
函数只能够对可寻址的文件进行操作,如磁盘文件、终端设备等,而不能对无法随机访问的流式数据进行操作,如管道、套接字等。同时,在使用lseek()
函数时应该注意文件操作模式和文件共享模式,以免影响其他进程或线程的文件访问。
16.3 运行结果
17. ltoa
17.1 函数说明
函数声明 | 函数功能 |
---|---|
char *ltoa(long value, char *str, int radix); | 用于将长整型数值转换为字符串格式 |
参数:
- value : 要转换的长整型数值
- str : 保存转换结果的字符缓冲区指针
- radix : 要转换的进制数(如2进制、 10 进制、16 进制等),取值范围为 2~36
返回值:
- 指向转换结果的指针(即 str 参数的值)
17.2 演示示例
#include <stdio.h>
#include <stdlib.h>int main()
{long value = 123456789L;char str[20];ltoa(value, str, 2);printf("The result of converting %ld to binary string is: %s\n", value, str);ltoa(value, str, 10);printf("The result of converting %ld to decimal string is: %s\n", value, str);ltoa(value, str, 16);printf("The result of converting %ld to hexadecimal string is: %s\n", value, str);return 0;
}
注意:
ltoa()
函数在将长整型数值转换为字符串时,会将负数转换为相应的带符号字符串。如果要对无符号长整型进行转换,则需要使用其他函数或技巧。此外,由于ltoa()
函数没有对输出缓冲区溢出进行检查,因此在使用时应该确保缓冲区足够大,以免发生错误。
17.3 运行结果
18. lltoa
18.1 函数说明
函数声明 | 函数功能 |
---|---|
char *lltoa(long long value, char *str, int radix); | 用于将长长整型数值转换为字符串格式 |
参数:
- value : 要转换的长长整型数值
- str : 保存转换结果的字符缓冲区指针
- radix : 要转换的进制数(如 2进制、10 进制、16 进制等),取值范围为 2~36
返回值:
- 指向转换结果的指针(即 str 参数的值)
18.2 演示示例
#include <stdio.h>
#include <stdlib.h>int main()
{long long value = 123456789012345LL;char str[20];lltoa(value, str, 2);printf("The result of converting %lld to binary string is: %s\n", value, str);lltoa(value, str, 10);printf("The result of converting %lld to decimal string is: %s\n", value, str);lltoa(value, str, 16);printf("The result of converting %lld to hexadecimal string is: %s\n", value, str);return 0;
}
18.3 运行结果
参考
- [API Reference Document]