C Programming - Standard Library Functions
Why should I learn to solve C Programming: Standard Library Functions technical interview questions?
Learn and practise solving C Programming: Standard Library Functions technical interview questions and answers to enhance your skills for clearing technical interviews, HR interviews, campus interviews, and placement tests.
Where can I get technical C Programming: Standard Library Functions technical interview questions and answers with explanations?
IndiaBIX provides you with lots of fully solved C Programming: Standard Library Functions technical interview questions and answers with a short answer description. You can download C Programming: Standard Library Functions technical interview questions and answers as PDF files or e-books.
How do I answer C Programming: Standard Library Functions technical interview questions from various companies?
You can answer all kinds of C Programming: Standard Library Functions technical interview questions by practising the given exercises (short answer type). You can also find the frequently asked C Programming: Standard Library Functions technical interview questions with answers from various companies, such as TCS, Wipro, Infosys, CTS, IBM, etc.
The standard library functions have three advantages: they work, they're efficient, and they're portable. They work: Your compiler vendor probably got them right. More important, the vendor is likely to have done a thorough test to prove they're right, more thorough than you probably have time for. (There are expensive test suites to make that job easier.)
They're efficient: Good C programmers use the standard library functions a lot, and good compiler vendors know that. There's a competitive advantage for the vendor to provide a good implementation. When competing compilers are compared for efficiency, a good compiler implementation can make all the difference. The vendor has more motivation than you do, and probably more time, to produce a fast implementation.
They're portable: In a world where software requirements change hourly, the standard library functions do the same thing, and mean the same thing, for every compiler, on every computer. They're one of the few things you, as a C programmer, can count on.
The funny thing is, one of the most standard pieces of information about the standard library is hard to find. For every function, there's one header file (or, rarely, two) that guarantees to give you that function's prototype. (You should always include the prototype for every function you call;) What's funny? That header file might not be the file that actually contains the prototype. In some (sad!) cases, it's not even the header file recommended by the compiler manual. The same is true for macros, typedefs, and global variables.
The funny thing is, these are not necessarily the files that define what you're looking for. Your compiler guarantees that (for example) if you want the EDOM macro, you can get it by including <errno.h>. EDOM might be defined in <errno.h>, or <errno.h> might just include something that defines it. Worse, the next version of your compiler might define EDOM somewhere else.
Don't look in the files for the definition and use that file. Use the file that's supposed to define the symbol you want. It'll work.
A few names are defined in multiple files: NULL, size_t, and wchar_t. If you need a definition for one of these names, use a file you need to include anyway, or pick one arbitrarily. (<stddef.h> is a reasonable choice; it's small, and it defines common macros and types.)
Standard library functions header files.
Function/Macro | Header File | |
---|---|---|
abort | - | stdlib.h |
abs | - | stdlib.h |
acos | - | math.h |
asctime | - | time.h |
asin | - | math.h |
assert | - | assert.h |
atan | - | math.h |
atan2 | - | math.h |
atexit | - | stdlib.h |
atof | - | stdlib.h |
atoi | - | stdlib.h |
atol | - | stdlib.h |
bsearch | - | stdlib.h |
BUFSIZ | - | stdlib.h |
calloc | - | stdlib.h |
ceil | - | math.h |
clearerr | - | stdio.h |
clock | - | time.h |
CLOCKS_PER_SEC | - | time.h |
clock_t | - | time.h |
cos | - | math.h |
cosh | - | math.h |
ctime | - | time.h |
difftime | - | time.h |
div | - | stdlib.h |
div_t | - | stdlib.h |
EDOM | - | errno.h |
EOF | - | stdio.h |
ERANGE | - | errno.h |
errno | - | errno.h |
exit | - | stdlib.h |
EXIT_FAILURE | - | stdlib.h |
EXIT_SUCCESS | - | stdlib.h |
exp | - | math.h |
fabs | - | math.h |
fclose | - | stdio.h |
feof | - | stdio.h |
ferror | - | stdio.h |
fflush | - | stdio.h |
fgetc | - | stdio.h |
fgetpos | - | stdio.h |
fgets | - | stdio.h |
FILE | - | stdio.h |
FILENAME_MAX | - | stdio.h |
floor | - | math.h |
fmod | - | math.h |
fopen | - | stdio.h |
FOPEN_MAX | - | stdio.h |
fpos_t | - | stdio.h |
fprintf | - | stdio.h |
fputc | - | stdio.h |
fputs | - | stdio.h |
fread | - | stdio.h |
freopen | - | stdio.h |
frexp | - | math.h |
fscanf | - | stdio.h |
fseek | - | stdio.h |
fsetpos | - | stdio.h |
ftell | - | stdio.h |
fwrite | - | stdio.h |
getc | - | stdio.h |
getchar | - | stdio.h |
getenv | - | stdlib.h |
gets | - | stdio.h |
gmtime | - | time.h |
HUGE_VAL | - | math.h |
_IOFBF | - | stdio.h |
_IOLBF | - | stdio.h |
_IONBF | - | stdio.h |
isalnum | - | ctype.h |
isalpha | - | ctype.h |
iscntrl | - | ctype.h |
isdigit | - | ctype.h |
isgraph | - | ctype.h |
islower | - | ctype.h |
isprint | - | ctype.h |
ispunct | - | ctype.h |
isspace | - | ctype.h |
isupper | - | ctype.h |
isxdigit | - | ctype.h |
jmp_buf | - | setjmp.h |
labs | - | stdlib.h |
LC_ALL | - | locale.h |
LC_COLLATE | - | locale.h |
LC_CTYPE | - | locale.h |
LC_MONETARY | - | locale.h |
LC_NUMERIC | - | locale.h |
LC_TIME | - | locale.h |
struct lconv | - | locale.h |
ldexp | - | math.h |
ldiv | - | stdlib.h |
ldiv_t | - | stdlib.h |
localeconv | - | locale.h |
localtime | - | time.h |
log | - | math.h |
log10 | - | math.h |
longjmp | - | setjmp.h |
L_tmpnam | - | stdio.h |
malloc | - | stdlib.h |
mblen | - | stdlib.h |
mbstowcs | - | stdlib.h |
mbtowc | - | stdlib.h |
MB_CUR_MAX | - | stdlib.h |
memchr | - | string.h |
memcmp | - | string.h |
memcpy | - | string.h |
memmove | - | string.h |
memset | - | string.h |
mktime | - | time.h |
modf | - | math.h |
NDEBUG | - | assert.h |
NULL | - | locale.h, stddef.h, stdio.h, stdlib.h, string.h, time.h |
offsetof | - | stddef.h |
perror | - | stdio.h |
pow | - | math.h |
printf | - | stdio.h |
ptrdiff_t | - | stddef.h |
putc | - | stdio.h |
putchar | - | stdio.h |
puts | - | stdio.h |
qsort | - | stdlib.h |
raise | - | signal.h |
rand | - | stdlib.h |
RAND_MAX | - | stdlib.h |
realloc | - | stdlib.h |
remove | - | stdio.h |
rename | - | stdio.h |
rewind | - | stdio.h |
scanf | - | stdio.h |
SEEK_CUR | - | stdio.h |
SEEK_END | - | stdio.h |
SEEK_SET | - | stdio.h |
setbuf | - | stdio.h |
setlocale | - | locale.h |
setvbuf | - | stdio.h |
SIGABRT | - | signal.h |
SIGFPE | - | signal.h |
SIGILL | - | signal.h |
SIGINT | - | signal.h |
signal | - | signal.h |
SIGSEGV | - | signal.h |
SIGTERM | - | signal.h |
sig_atomic_t | - | signal.h |
SIG_DFL | - | signal.h |
SIG_ERR | - | signal.h |
SIG_IGN | - | signal.h |
sin | - | math.h |
sinh | - | math.h |
size_t | - | stddef.h, stdlib.h, string.h, sprintf, stdio.h |
sqrt | - | math.h |
srand | - | stdlib.h |
sscanf | - | stdio.h |
stderr | - | stdio.h |
stdin | - | stdio.h |
stdout | - | stdio.h |
strcat | - | string.h |
strchr | - | string.h |
strcmp | - | string.h |
strcoll | - | string.h |
strcpy | - | string.h |
strcspn | - | string.h |
strerror | - | string.h |
strftime | - | time.h |
strlen | - | string.h |
strncat | - | string.h |
strncmp | - | string.h |
strncpy | - | string.h |
strpbrk | - | string.h |
strrchr | - | string.h |
strspn | - | string.h |
strstr | - | string.h |
strtod | - | stdlib.h |
strtok | - | string.h |
strtol | - | stdlib.h |
strtoul | - | stdlib.h |
strxfrm | - | string.h |
system | - | stdlib.h |
tan | - | math.h |
tanh | - | math.h |
time | - | time.h |
time_t | - | time.h |
struct tm | - | time.h |
tmpfile | - | stdio.h |
tmpnam | - | stdio.h |
TMP_MAX | - | stdio.h |
tolower | - | ctype.h |
toupper | - | ctype.h |
ungetc | - | stdio.h |
va_arg | - | stdarg.h |
va_end | - | stdarg.h |
va_list | - | stdarg.h |
va_start | - | stdarg.h |
vfprintf | - | stdio.h |
vprintf | - | stdio.h |
vsprintf | - | stdio.h |
wchar_t | - | stddef.h, stdlib.h |
wcstombs | - | stdlib.h |
wctomb | - | stdlib.h |
Use <stdarg.h>. This defines some macros that let your program deal with variable numbers of arguments.
There's no portable way for a C function, with no constraints on what it might be passed, to know how many arguments it might have gotten or what their types are. If a C function doesn't take a fixed number of arguments (of fixed types), it needs some convention for what the arguments are. For example, the first argument to printf is a string, which indicates what the remaining arguments are:
printf("Hello, world!\n"); /* no more arguments */
printf("%s\n", "Hello, world!"); /* one more string argument */
printf("%s, %s\n", "Hello", "world!"); /* two more string arguments */
printf("%s, %d\n", "Hello", 42); /* one string, one int */
The below program shows a simple printf-like function. The first argument is the format; from the format string, the number and types of the remaining arguments can be determined. As with the real printf, if the format doesn't match the rest of the arguments, the result is undefined. There's no telling what your program will do then (but probably something bad).
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>
static char * int2str(int n)
{
int minus = (n < 0);
static char buf[32];
char *p = &buf[31];
if (minus)
n = -n;
*p = '\0';
do {
*--p = '0' + n % 10;
n /= 10;
} while (n > 0);
if (minus)
*--p = '-';
return p;
}
/* This is a simple printf-like function that handles only
the format specifiers %%, %s, and %d. */
void simplePrintf(const char *format, ...)
{
va_list ap; /* ap is our argument pointer. */
int i;
char *s;
/* Initialize ap to start with the argument after "format" */
va_start(ap, format);
for ( ; *format; format++)
{
if (*format != '%')
{
putchar(*format);
continue;
}
switch (*++format)
{
case 's':
/* Get next argument (a char*) */
s = va_arg(ap, char *);
fputs(s, stdout);
break;
case 'd':
/* Get next argument (an int) */
i = va_arg(ap, int);
s = int2str(i);
fputs(s, stdout);
break;
case '\0':
format--;
break;
default:
putchar(*format);
break;
}
}
/* Clean up varying arguments before returning */
va_end(ap);
}
void main()
{
simplePrintf("The %s tax rate is %d%%.\n", "sales", 6);
}
Not all C programmers write database management systems and word processors. Some write code for embedded systems, such as anti-lock braking systems and intelligent toasters. Embedded systems don't necessarily have any sort of file system, or much of an operating system at all. The ANSI/ISO standard calls these "free-standing" systems, and it doesn't require them to provide anything except the language itself. The alternative is a program running on a PC or a mainframe or something in-between; that's a "hosted" environment.
Even people developing for free-standing environments should pay attention to the standard library. For one thing, if a free-standing environment provides some functionality (such as a square root function), it's likely to provide it in a way that's compatible with the standard. (Reinventing the square root is like reinventing the square wheel; what's the point?) Beyond that, embedded programs are often tested on a PC before they're downloaded to a toaster (or whatever). Using the standard functions will increase the amount of code that can be identical in both the test and the real environments.