snprintf() у бібліотеці C

The функція snprintf(). визначається в заголовний файл і використовується для зберігання вказаного рядка до заданої довжини у вказаному форматі.

Характеристики методу snprintf():

  • Функція snprintf() форматує та зберігає ряд символів і значень у буфері масиву.
  • Функція snprintf() приймає аргумент «n», який вказує максимальну кількість символів (включно з нульовим символом у кінці), які потрібно записати в буфер.
  • Функція snprintf() використовується для перенаправлення виводу функції printf() у буфер.
  • Функція snprintf() також повертає кількість символів, які мали бути записані в буфер (за винятком нульового термінатора), незалежно від переданого значення «n».
  • Таким чином, лише якщо повернуте значення є невід’ємним і менше ніж «n», рядок було повністю записано, як очікувалося.

Синтаксис: Синтаксис методу snprintf() такий:

int snprintf(char *str, size_t size, const char *format, …);

Параметри:

    *str: це буфер. size : максимальна кількість байтів (символів), яка буде записана в буфер. format : рядок C, який містить рядок формату, який відповідає тим самим специфікаціям, що й format у printf … : необов’язкові (…) аргументи це лише формати рядків, як-от (%d, myint), як показано у printf.

Повернене значення:

  • Кількість символів, які були б записані в буфер, якби «n» було достатньо великим. Кінцевий нульовий символ не враховується.
  • Якщо виникає помилка кодування, повертається від’ємне число.

Нижче наведено приклад для ілюстрації роботи методу snprintf():

Приклад 1:

C




// C program to demonstrate snprintf()> #include> int> main()> {> > char> buffer[50];> > char> * s => 'geeksforgeeks'> ;> > // Counting the character and storing> > // in buffer using snprintf> > printf> (> 'Writing %s onto buffer'> > ' with capacity 6'> ,> > s);> > int> j = snprintf(buffer, 6,> '%s '> , s);> > // Print the string stored in buffer and> > // character count> > printf> (> ' String written on '> > 'buffer = %s'> , buffer);> > printf> (> ' Value returned by '> > 'snprintf() method = %d '> , j);> > return> 0;> }>

Вихід

Writing geeksforgeeks onto buffer with capacity 6 String written on buffer = geeks Value returned by snprintf() method = 14 

приклад 2:

C




// C program to demonstrate snprintf()> #include> int> main()> {> > char> buffer[50];> > > // join two or more strings> > char> * str1 => 'quick'> ;> > char> * str2 => 'brown'> ;> > char> * str3 => 'lazy'> ;> > int> max_len => sizeof> buffer;> > int> j = snprintf(buffer, max_len,> > 'The %s %s fox jumped over the %s dog.'> ,> > str1, str2, str3);> > printf> (> ' The number of bytes printed to 'buffer' '> > '(excluding the null terminator) is %d '> ,> > j);> > if> (j>= max_len)> > fputs> (> 'Buffer length exceeded; string truncated'> ,> > stderr);> > puts> (> 'Joined string:'> );> > puts> (buffer);> > return> 0;> }>

Вихід

The number of bytes printed to 'buffer' (excluding the null terminator) is 45 Joined string: The quick brown fox jumped over the lazy dog.