SlideShare una empresa de Scribd logo
1 de 11
NOMBRE: ¿?
AULA: BLOQUE C SANGOLQUI C304
FECHA: 28 – Julio – 2014
NRC: 4258
FUNDAMENTOS DE PROGRAMACIÓN
TÍTULO: Librería “ string.h “
C pone a nuestra disposición una librería centrada en el tratamiento de cadenas, la librería
string.h, es un archivo de la Biblioteca estándar del lenguaje de programación C que contiene las
funciones y tipos de utilidad para trabajar con cadenas de caracteres. Con ella podremos realizar
prácticamente cualquier tipo de operación con cadenas. También cuenta con procedimientos
para manejar memoria.
Las funciones declaradas en string.h se han hecho muy populares, por lo que están garantizadas
para cualquier plataforma que soporte C. Además, las funciones para cadenas de caracteres sólo
trabajan con conjuntos de caracteres ASCII o extensiones ASCII compatibles.
Constantes y tipos
NOMBRE DESCRIPCIÓN
NULL
Macro que representa la constante puntero nulo; representa un valor de puntero
que no apunta a ninguna dirección válida de objeto alguno en memoria
size_t Tipo entero sin signo (positivo); es el tipo devuelto por el operador sizeof
Funciones
NOMBRES DESCRIPCIÓN
memcpy Copia n bytes entre dos áreas de memoria que no deben solaparse
memmove
Copia n bytes entre dos áreas de memoria; al contrario que memcpy las áreas
pueden solaparse
memchr
Busca un valor a partir de una dirección de memoria dada y devuelve un puntero
a la primera ocurrencia del valor buscado o NULL si no se encuentra
memcmp Compara los n primeros caracteres de dos áreas de memoria
memset Sobre escribe un área de memoria con un patrón de bytes dado
strcat Añade una cadena al final de otra
strncat Añade los n primeros caracteres de una cadena al final de otra
strchr Localiza un carácter en una cadena, buscando desde el principio
strrchr Localiza un carácter en una cadena, buscando desde el final
strcmp Compara dos cadenas alfabéticamente ('a'!='a')
strncmp Compara los n primeros caracteres de dos cadenas numéricamente ('a'!='a')
strcoll Compara dos cadenas según la colación actual ('a'=='A')
strcpy Copia una cadena en otra
strncpy Copia los n primeros caracteres de una cadena en otra
strerror
Devuelve la cadena con el mensaje de error correspondiente al número de error
dado
strlen Devuelve la longitud de una cadena
strspn
Devuelve la posición del primer carácter de una cadena que no coincide con
ninguno de los caracteres de otra cadena dada
strcspn
Devuelve la posición del primer carácter que coincide con alguno de los
caracteres de otra cadena dada
strpbrk
Encuentra la primera ocurrencia de alguno de los caracteres de una cadena dada
en otra
strstr Busca una cadena dentro de otra
strtok Parte una cadena en una secuencia de tokens
strxfrm Transforma una cadena en su forma de colación (??)
strrev Invierte una cadena
Extensiones para C SIO
NOMBRE DESCRIPCIÓN ESPECIFICACIÓN
strdup
Hace un duplicado de la cadena dada
reservando dinámicamente la memoria
necesaria
POSIX; originalmente una extensión BSD
strcpy s Variante de strcpy que verifica los límites ISO/IEC WDTR 24731
mempcpy
Variante de memcpy que devuelve un
puntero al byte siguiente al último byte
escrito
GNU
memccpy
Variante de memcpy que para al
encontrar un byte determinado
UNIX 98?
strerror r Análogo a strerror_r(thread-safe) GNU, POSIX
strlcpy Variante de strcpy que verifica los límites
originalmenteOpenBSD, actualmente
tambiénFreeBSD, Solaris, OS X
strtok r Versión thread-safe destrtok POSIX
strsignal
Análogamente a strerror, devuelve la
cadena representación de la
señalsig (no thread safe)
BSDs, Solaris, Linux
Cadena de Caracteres
Una cadena es un conjunto de caracteres, el cual cada caracter se encuentra en una posición
determinada dentro de la cadena. Se puede utilizar una cadena general o una cadena fija de un
número determinado de caracteres, estas se declaran en el siguiente formato:
Ejemplo:
char* var_cadena; // declaración de una cadena de hasta 255 caracteres
char cadena[N]; // declaración de una cadena de N caracteres
La librería de manejo de cadenas string.h es un conjunto de funciones útiles para manipulación
de datos de cadenas, entre ellas tenemos:
Ejemplos:
#include <stdio.h>
#include <string.h>
char completo [80];
char nombre[32] = "Pedro";
char apellidos [32] = "Medario Arenas";
main()
{
/* Construye el nombre completo */
strcpy ( completo, nombre ); /* completo <- "Pedro" */
strcat ( completo, " "); /* completo <- "Pedro " */
strcat ( completo, apellidos ); /* completo <- "Pedro
Medario Arenas" */
printf ( "El nombre completo es %sn", completo );
}
Función strlen()
Calcula la longitud de una cadena.
Sintaxis:
size_t strlen(const char *s);
strlen calcula la longitud de la cadena s.
Valor de retorno:
strlen devuelve el número de caracteres que hay en s, excluyendo el carácter nulo de terminación
de cadena.
Ejemplo:
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char *cadena = "Una cadena C++ termina con cero";
cout << "La cadena: [" << cadena << "] tiene "
<< {f:strlen}(cadena) << " caracteres" << endl;
return 0;
}
Función strcpy()
Copia una cadena en otra.
Sintaxis:
char *strcpy(char *dest, const char *orig);
Copia la cadena orig a dest, la copia de caracteres se detendrá cuando sea copiado el carácter
nulo.
Valor de retorno:
strcpy devuelve el puntero dest.
Ejemplo:
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char *cadena = "Cadena ejemplo";
char cad[32];
cout << strcpy(cad, cadena) << endl;
cout << cad << endl;
return 0;
}
Función strcmp()
Compara dos cadenas.
Sintaxis:
int strcmp(char *cad1, const char *cad2);
Compara las dos cadenas, si la cad1 es mayor que cad2 el resultado será mayor de 0, si cad1 es
menor que cad2, el resultado será menor de 0, si son iguales, el resultado será 0.
La comparación se realiza carácter a carácter. Mientras los caracteres comparados sean iguales,
secontinúa con el siguientecarácter. Cuando se encuentran caracteres distintos, aquél que tenga
un código ASCII menor pertenecerá a la cadena menor. Por supuesto, si las cadenas son iguales
hasta que una de ellas se acaba, la más corta es la menor.
Ejemplo:
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char *cadena1 = "Cadena ejemplo 1";
char *cadena2 = "Cadena ejemplo 2";
char *cadena3 = "Cadena";
char *cadena4 = "Cadena";
if(strcmp(cadena1, cadena2) < 0)
cout << cadena1 << " es menor que " << cadena2 << endl;
else if(strcmp(cadena1, cadena2) > 0)
cout << cadena1 << " es menor que " << cadena2 << endl;
else
cout << cadena1 << " es igual que " << cadena2 << endl;
cout << strcmp(cadena3, cadena2) << endl;
cout << strcmp(cadena3, cadena4) << endl;
return 0;
}
Función strcat()
Añade o concatena una cadena a otra.
Sintaxis:
char *strcat(char *dest, const char *orig);
strcat añade una copia de orig al finalde dest. La longitud de la cadenaresultante será strlen(dest)
+ strlen(orig).
Valor de retorno:
strcat devuelve un puntero a la cadena concatenada.
Ejemplo:
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char *cadena1 = "Cadena de";
char *cadena2 = " ejemplo";
char cadena3[126];
strcpy(cadena3, cadena1);
cout << strcat(cadena3, cadena2) << endl;
return 0;
}
Función strncpy()
Copia un determinado número de caracteres de una cadena en otra.
Sintaxis:
char *strncpy(char *dest, const char *orig, size_t maxlong);
Copia maxlong caracteres de la cadena orig a dest, si hay más caracteres se ignoran, si hay menos
se rellenará con caracteres nulos. La cadena dest no se terminará con nulo si la longitud de orig
es maxlong o más.
Valor de retorno:
strncpy devuelve el puntero dest.
Ejemplo:
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char *cadena = "Cadena ejemplo";
char cad[32];
strncpy(cad, cadena, 4);
cad[4] = '0';
cout << cad << endl;
return 0;
}
Función strncmp()
Compara dos porciones de cadenas.
Sintaxis:
int strncmp(char *cad1, const char *cad2, size_t maxlong);
Compara las dos cadenas igual que strcmp, pero sólo se comparan los primeros maxlong
caracteres.
Ejemplo:
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char *cadena1 = "Cadena ejemplo 1";
char *cadena2 = "Cadena ejemplo 2";
char *cadena3 = "Cadena";
char *cadena4 = "Cadena";
if(strncmp(cadena1, cadena2, 6) < 0)
cout << cadena1 << " es menor que " << cadena2 << endl;
else if(strncmp(cadena1, cadena2, 6) > 0)
cout << cadena1 << " es menor que " << cadena2 << endl;
else
cout << cadena1 << " es igual que " << cadena2 << endl;
cout << strncmp(cadena3, cadena2, 5) << endl;
cout << strncmp(cadena3, cadena4, 4) << endl;
return 0;
}
Función strncat()
Añade o concatena una porción de una cadena a otra.
Sintaxis:
char *strncat(char *dest, const char *orig, size_t maxlong);
strncat añade como máximo maxlong caracteres de la cadena orig al final de dest, y después
añade el carácter nulo. La longitud de la cadena resultante será strlen(dest) + maxlong.
Valor de retorno:
strncat devuelve un puntero a la cadena concatenada.
Ejemplo:
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char *cadena1 = "Cadena de";
char *cadena2 = " ejemplo";
char cadena3[126];
strcpy(cadena3, cadena1);
cout << strncat(cadena3, cadena2, 5) << endl;
Función strtok()
Busca dentro de una cadena conjuntos de caracteres o símbolos (tokens) separados por
delimitadores.
Sintaxis:
char *strtok(char *s1, const char *s2);
strtok considera la cadena s1como una listade símbolos separados por delimitadores de laforma
de s2.
La primera llamada a strtok devuelve un puntero al primer carácter del primer símbolo de s1 e
inserta un carácter nulo a continuación del símbolo retornado. Las siguientes llamadas,
especificando null como primer argumento, siguen dando símbolos hasta que no quede ninguno.
El separador, s2, puede ser diferente para cada llamada.
Valor de retorno:
strtok devuelve un puntero al símbolo extraído, oNULL cuando no quedan símbolos.
Ejemplo:
#include <cstring>
#include <iostream>
using namespace std;
int main() {
char entrada[32] = "abc,d,efde,ew,231";
char *p;
// La primera llamada con entrada
p = strtok(entrada, ",");
if(p) cout << p << endl;
// Las siguientes llamadas con NULL
while(p) {
p = strtok(NULL, ",");
if(p) cout << p << endl;
}
return 0;
}
Bibliografía
a. http://programacion1-teoria.wikispaces.com/Lenguaje+C
b. http://teoria-de-programacion.globered.com/categoria.asp?idcat=33
c. http://c.conclase.net/curso/?cap=006#inicio
d. http://www.taringa.net/posts/ciencia-educacion/15391497/C---
Declaracion-de-variables.html
e. http://ccodigo.wordpress.com/tag/string-h/
f. http://sopa.dis.ulpgc.es/fso/cpp/intro_c/introc53.htm
g. http://fcqi.tij.uabc.mx/usuarios/cgaxiola/prog_p7.pdf
h. http://es.wikipedia.org/wiki/String.h
i. http://arduino.cc/en/pmwiki.php?n=Tutorial/TextString
j. http://c.conclase.net/curso/?cap=902f

Más contenido relacionado

La actualidad más candente

Problema temperatura dev c++
Problema temperatura dev c++ Problema temperatura dev c++
Problema temperatura dev c++
Eli Diaz
 
Cerradura
CerraduraCerradura
Cerradura
rezzaca
 

La actualidad más candente (20)

Automatas Finitos Deterministicos y No Deterministicos
Automatas Finitos Deterministicos y No DeterministicosAutomatas Finitos Deterministicos y No Deterministicos
Automatas Finitos Deterministicos y No Deterministicos
 
C++ y sus librerias
C++ y sus libreriasC++ y sus librerias
C++ y sus librerias
 
Algebra relacional
Algebra relacionalAlgebra relacional
Algebra relacional
 
Bucles de Control Repetitivo Ciclos For
Bucles de Control Repetitivo  Ciclos ForBucles de Control Repetitivo  Ciclos For
Bucles de Control Repetitivo Ciclos For
 
Programación 3: árboles binarios y ordenados
Programación 3: árboles binarios y ordenadosProgramación 3: árboles binarios y ordenados
Programación 3: árboles binarios y ordenados
 
Unidad2 programas while , do while y for
Unidad2 programas while , do while  y forUnidad2 programas while , do while  y for
Unidad2 programas while , do while y for
 
Librerias Básicas y sus Funciones Lenguaje de Programación C
Librerias Básicas y sus Funciones Lenguaje de Programación CLibrerias Básicas y sus Funciones Lenguaje de Programación C
Librerias Básicas y sus Funciones Lenguaje de Programación C
 
Definiciones y ejemplos de los tipos de datos de powerdesigner
Definiciones y ejemplos de los tipos de datos de powerdesignerDefiniciones y ejemplos de los tipos de datos de powerdesigner
Definiciones y ejemplos de los tipos de datos de powerdesigner
 
Eladoraciòn de un programa en C++ (Cuadro Mágico)
Eladoraciòn de un programa en C++ (Cuadro Mágico)Eladoraciòn de un programa en C++ (Cuadro Mágico)
Eladoraciòn de un programa en C++ (Cuadro Mágico)
 
Sistemas coordenadas (diferenciales, lineales, área y volumen)
Sistemas coordenadas (diferenciales, lineales, área y volumen)Sistemas coordenadas (diferenciales, lineales, área y volumen)
Sistemas coordenadas (diferenciales, lineales, área y volumen)
 
Equivalencia de automatas finitos determinista
Equivalencia de automatas finitos deterministaEquivalencia de automatas finitos determinista
Equivalencia de automatas finitos determinista
 
Clase2
Clase2Clase2
Clase2
 
Autómatas finitos no deterministas
Autómatas finitos no deterministasAutómatas finitos no deterministas
Autómatas finitos no deterministas
 
Representación de limites
Representación de limitesRepresentación de limites
Representación de limites
 
Operador anulador
Operador anuladorOperador anulador
Operador anulador
 
Problema temperatura dev c++
Problema temperatura dev c++ Problema temperatura dev c++
Problema temperatura dev c++
 
Programacion practica prolog
Programacion practica prologProgramacion practica prolog
Programacion practica prolog
 
Ejercicios resueltos de punteros 12a15
Ejercicios resueltos de punteros 12a15Ejercicios resueltos de punteros 12a15
Ejercicios resueltos de punteros 12a15
 
Metodo de eliminacion gaussiana simple
Metodo de eliminacion gaussiana simpleMetodo de eliminacion gaussiana simple
Metodo de eliminacion gaussiana simple
 
Cerradura
CerraduraCerradura
Cerradura
 

Similar a Fundamentos de programación librería string C++

30 Php. Cadenas Alfanumericas
30 Php. Cadenas Alfanumericas30 Php. Cadenas Alfanumericas
30 Php. Cadenas Alfanumericas
José M. Padilla
 
Capitulo 8 Cadenas
Capitulo 8  CadenasCapitulo 8  Cadenas
Capitulo 8 Cadenas
guest506dc9
 

Similar a Fundamentos de programación librería string C++ (20)

Funciones str
Funciones strFunciones str
Funciones str
 
Funciones cadena
Funciones cadenaFunciones cadena
Funciones cadena
 
08 strings o cadenas
08 strings o cadenas08 strings o cadenas
08 strings o cadenas
 
Taller 1 de estructuras
Taller 1 de estructurasTaller 1 de estructuras
Taller 1 de estructuras
 
Cadenas
CadenasCadenas
Cadenas
 
Funciones de Cadenas/ Computación para ingenieros
Funciones de Cadenas/ Computación para ingenierosFunciones de Cadenas/ Computación para ingenieros
Funciones de Cadenas/ Computación para ingenieros
 
Códigos c++
Códigos c++Códigos c++
Códigos c++
 
Investigacion de elementos y codigos de c++
Investigacion de elementos y codigos de c++Investigacion de elementos y codigos de c++
Investigacion de elementos y codigos de c++
 
Tipo de Operadores
Tipo de OperadoresTipo de Operadores
Tipo de Operadores
 
Codigos C+++
Codigos C+++Codigos C+++
Codigos C+++
 
Comandos importantes en c++
Comandos importantes en c++Comandos importantes en c++
Comandos importantes en c++
 
30 Php. Cadenas Alfanumericas
30 Php. Cadenas Alfanumericas30 Php. Cadenas Alfanumericas
30 Php. Cadenas Alfanumericas
 
Libreria c++
Libreria c++Libreria c++
Libreria c++
 
Pe15 cadenacaracteres
Pe15 cadenacaracteresPe15 cadenacaracteres
Pe15 cadenacaracteres
 
Éxito y Fracáso
Éxito y FracásoÉxito y Fracáso
Éxito y Fracáso
 
INVESTIGACIÓN DE LIBRERÍAS
INVESTIGACIÓN DE LIBRERÍAS INVESTIGACIÓN DE LIBRERÍAS
INVESTIGACIÓN DE LIBRERÍAS
 
Cadenas y funciones de cadena
Cadenas y funciones de cadenaCadenas y funciones de cadena
Cadenas y funciones de cadena
 
Cadenas y funciones de cadena
Cadenas y funciones de cadenaCadenas y funciones de cadena
Cadenas y funciones de cadena
 
Capitulo 8 Cadenas
Capitulo 8  CadenasCapitulo 8  Cadenas
Capitulo 8 Cadenas
 
Librerias dee c_
Librerias dee c_Librerias dee c_
Librerias dee c_
 

Último

ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptxACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
zulyvero07
 
Cuaderno de trabajo Matemática 3 tercer grado.pdf
Cuaderno de trabajo Matemática 3 tercer grado.pdfCuaderno de trabajo Matemática 3 tercer grado.pdf
Cuaderno de trabajo Matemática 3 tercer grado.pdf
NancyLoaa
 

Último (20)

plan de capacitacion docente AIP 2024 clllll.pdf
plan de capacitacion docente  AIP 2024          clllll.pdfplan de capacitacion docente  AIP 2024          clllll.pdf
plan de capacitacion docente AIP 2024 clllll.pdf
 
plande accion dl aula de innovación pedagogica 2024.pdf
plande accion dl aula de innovación pedagogica 2024.pdfplande accion dl aula de innovación pedagogica 2024.pdf
plande accion dl aula de innovación pedagogica 2024.pdf
 
Sesión de aprendizaje Planifica Textos argumentativo.docx
Sesión de aprendizaje Planifica Textos argumentativo.docxSesión de aprendizaje Planifica Textos argumentativo.docx
Sesión de aprendizaje Planifica Textos argumentativo.docx
 
Imperialismo informal en Europa y el imperio
Imperialismo informal en Europa y el imperioImperialismo informal en Europa y el imperio
Imperialismo informal en Europa y el imperio
 
Unidad 3 | Metodología de la Investigación
Unidad 3 | Metodología de la InvestigaciónUnidad 3 | Metodología de la Investigación
Unidad 3 | Metodología de la Investigación
 
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptxACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
 
proyecto de mayo inicial 5 añitos aprender es bueno para tu niño
proyecto de mayo inicial 5 añitos aprender es bueno para tu niñoproyecto de mayo inicial 5 añitos aprender es bueno para tu niño
proyecto de mayo inicial 5 añitos aprender es bueno para tu niño
 
Cuaderno de trabajo Matemática 3 tercer grado.pdf
Cuaderno de trabajo Matemática 3 tercer grado.pdfCuaderno de trabajo Matemática 3 tercer grado.pdf
Cuaderno de trabajo Matemática 3 tercer grado.pdf
 
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...
 
SELECCIÓN DE LA MUESTRA Y MUESTREO EN INVESTIGACIÓN CUALITATIVA.pdf
SELECCIÓN DE LA MUESTRA Y MUESTREO EN INVESTIGACIÓN CUALITATIVA.pdfSELECCIÓN DE LA MUESTRA Y MUESTREO EN INVESTIGACIÓN CUALITATIVA.pdf
SELECCIÓN DE LA MUESTRA Y MUESTREO EN INVESTIGACIÓN CUALITATIVA.pdf
 
MAYO 1 PROYECTO día de la madre el amor más grande
MAYO 1 PROYECTO día de la madre el amor más grandeMAYO 1 PROYECTO día de la madre el amor más grande
MAYO 1 PROYECTO día de la madre el amor más grande
 
Registro Auxiliar - Primaria 2024 (1).pptx
Registro Auxiliar - Primaria  2024 (1).pptxRegistro Auxiliar - Primaria  2024 (1).pptx
Registro Auxiliar - Primaria 2024 (1).pptx
 
ORGANIZACIÓN SOCIAL INCA EN EL TAHUANTINSUYO.pptx
ORGANIZACIÓN SOCIAL INCA EN EL TAHUANTINSUYO.pptxORGANIZACIÓN SOCIAL INCA EN EL TAHUANTINSUYO.pptx
ORGANIZACIÓN SOCIAL INCA EN EL TAHUANTINSUYO.pptx
 
Medición del Movimiento Online 2024.pptx
Medición del Movimiento Online 2024.pptxMedición del Movimiento Online 2024.pptx
Medición del Movimiento Online 2024.pptx
 
PIAR v 015. 2024 Plan Individual de ajustes razonables
PIAR v 015. 2024 Plan Individual de ajustes razonablesPIAR v 015. 2024 Plan Individual de ajustes razonables
PIAR v 015. 2024 Plan Individual de ajustes razonables
 
Qué es la Inteligencia artificial generativa
Qué es la Inteligencia artificial generativaQué es la Inteligencia artificial generativa
Qué es la Inteligencia artificial generativa
 
AFICHE EL MANIERISMO HISTORIA DE LA ARQUITECTURA II
AFICHE EL MANIERISMO HISTORIA DE LA ARQUITECTURA IIAFICHE EL MANIERISMO HISTORIA DE LA ARQUITECTURA II
AFICHE EL MANIERISMO HISTORIA DE LA ARQUITECTURA II
 
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICA
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICABIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICA
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICA
 
Tema 8.- PROTECCION DE LOS SISTEMAS DE INFORMACIÓN.pdf
Tema 8.- PROTECCION DE LOS SISTEMAS DE INFORMACIÓN.pdfTema 8.- PROTECCION DE LOS SISTEMAS DE INFORMACIÓN.pdf
Tema 8.- PROTECCION DE LOS SISTEMAS DE INFORMACIÓN.pdf
 
Programacion Anual Matemática4 MPG 2024 Ccesa007.pdf
Programacion Anual Matemática4    MPG 2024  Ccesa007.pdfProgramacion Anual Matemática4    MPG 2024  Ccesa007.pdf
Programacion Anual Matemática4 MPG 2024 Ccesa007.pdf
 

Fundamentos de programación librería string C++

  • 1. NOMBRE: ¿? AULA: BLOQUE C SANGOLQUI C304 FECHA: 28 – Julio – 2014 NRC: 4258 FUNDAMENTOS DE PROGRAMACIÓN TÍTULO: Librería “ string.h “ C pone a nuestra disposición una librería centrada en el tratamiento de cadenas, la librería string.h, es un archivo de la Biblioteca estándar del lenguaje de programación C que contiene las funciones y tipos de utilidad para trabajar con cadenas de caracteres. Con ella podremos realizar prácticamente cualquier tipo de operación con cadenas. También cuenta con procedimientos para manejar memoria. Las funciones declaradas en string.h se han hecho muy populares, por lo que están garantizadas para cualquier plataforma que soporte C. Además, las funciones para cadenas de caracteres sólo trabajan con conjuntos de caracteres ASCII o extensiones ASCII compatibles. Constantes y tipos NOMBRE DESCRIPCIÓN NULL Macro que representa la constante puntero nulo; representa un valor de puntero que no apunta a ninguna dirección válida de objeto alguno en memoria size_t Tipo entero sin signo (positivo); es el tipo devuelto por el operador sizeof
  • 2. Funciones NOMBRES DESCRIPCIÓN memcpy Copia n bytes entre dos áreas de memoria que no deben solaparse memmove Copia n bytes entre dos áreas de memoria; al contrario que memcpy las áreas pueden solaparse memchr Busca un valor a partir de una dirección de memoria dada y devuelve un puntero a la primera ocurrencia del valor buscado o NULL si no se encuentra memcmp Compara los n primeros caracteres de dos áreas de memoria memset Sobre escribe un área de memoria con un patrón de bytes dado strcat Añade una cadena al final de otra strncat Añade los n primeros caracteres de una cadena al final de otra strchr Localiza un carácter en una cadena, buscando desde el principio strrchr Localiza un carácter en una cadena, buscando desde el final strcmp Compara dos cadenas alfabéticamente ('a'!='a') strncmp Compara los n primeros caracteres de dos cadenas numéricamente ('a'!='a') strcoll Compara dos cadenas según la colación actual ('a'=='A') strcpy Copia una cadena en otra
  • 3. strncpy Copia los n primeros caracteres de una cadena en otra strerror Devuelve la cadena con el mensaje de error correspondiente al número de error dado strlen Devuelve la longitud de una cadena strspn Devuelve la posición del primer carácter de una cadena que no coincide con ninguno de los caracteres de otra cadena dada strcspn Devuelve la posición del primer carácter que coincide con alguno de los caracteres de otra cadena dada strpbrk Encuentra la primera ocurrencia de alguno de los caracteres de una cadena dada en otra strstr Busca una cadena dentro de otra strtok Parte una cadena en una secuencia de tokens strxfrm Transforma una cadena en su forma de colación (??) strrev Invierte una cadena Extensiones para C SIO NOMBRE DESCRIPCIÓN ESPECIFICACIÓN strdup Hace un duplicado de la cadena dada reservando dinámicamente la memoria necesaria POSIX; originalmente una extensión BSD
  • 4. strcpy s Variante de strcpy que verifica los límites ISO/IEC WDTR 24731 mempcpy Variante de memcpy que devuelve un puntero al byte siguiente al último byte escrito GNU memccpy Variante de memcpy que para al encontrar un byte determinado UNIX 98? strerror r Análogo a strerror_r(thread-safe) GNU, POSIX strlcpy Variante de strcpy que verifica los límites originalmenteOpenBSD, actualmente tambiénFreeBSD, Solaris, OS X strtok r Versión thread-safe destrtok POSIX strsignal Análogamente a strerror, devuelve la cadena representación de la señalsig (no thread safe) BSDs, Solaris, Linux Cadena de Caracteres Una cadena es un conjunto de caracteres, el cual cada caracter se encuentra en una posición determinada dentro de la cadena. Se puede utilizar una cadena general o una cadena fija de un número determinado de caracteres, estas se declaran en el siguiente formato: Ejemplo: char* var_cadena; // declaración de una cadena de hasta 255 caracteres char cadena[N]; // declaración de una cadena de N caracteres
  • 5. La librería de manejo de cadenas string.h es un conjunto de funciones útiles para manipulación de datos de cadenas, entre ellas tenemos:
  • 6. Ejemplos: #include <stdio.h> #include <string.h> char completo [80]; char nombre[32] = "Pedro"; char apellidos [32] = "Medario Arenas"; main() { /* Construye el nombre completo */ strcpy ( completo, nombre ); /* completo <- "Pedro" */ strcat ( completo, " "); /* completo <- "Pedro " */ strcat ( completo, apellidos ); /* completo <- "Pedro Medario Arenas" */ printf ( "El nombre completo es %sn", completo ); } Función strlen() Calcula la longitud de una cadena. Sintaxis: size_t strlen(const char *s); strlen calcula la longitud de la cadena s. Valor de retorno: strlen devuelve el número de caracteres que hay en s, excluyendo el carácter nulo de terminación de cadena. Ejemplo: #include <iostream> #include <cstring> using namespace std; int main() { char *cadena = "Una cadena C++ termina con cero"; cout << "La cadena: [" << cadena << "] tiene " << {f:strlen}(cadena) << " caracteres" << endl; return 0; }
  • 7. Función strcpy() Copia una cadena en otra. Sintaxis: char *strcpy(char *dest, const char *orig); Copia la cadena orig a dest, la copia de caracteres se detendrá cuando sea copiado el carácter nulo. Valor de retorno: strcpy devuelve el puntero dest. Ejemplo: #include <iostream> #include <cstring> using namespace std; int main() { char *cadena = "Cadena ejemplo"; char cad[32]; cout << strcpy(cad, cadena) << endl; cout << cad << endl; return 0; } Función strcmp() Compara dos cadenas. Sintaxis: int strcmp(char *cad1, const char *cad2); Compara las dos cadenas, si la cad1 es mayor que cad2 el resultado será mayor de 0, si cad1 es menor que cad2, el resultado será menor de 0, si son iguales, el resultado será 0. La comparación se realiza carácter a carácter. Mientras los caracteres comparados sean iguales, secontinúa con el siguientecarácter. Cuando se encuentran caracteres distintos, aquél que tenga un código ASCII menor pertenecerá a la cadena menor. Por supuesto, si las cadenas son iguales hasta que una de ellas se acaba, la más corta es la menor.
  • 8. Ejemplo: #include <iostream> #include <cstring> using namespace std; int main() { char *cadena1 = "Cadena ejemplo 1"; char *cadena2 = "Cadena ejemplo 2"; char *cadena3 = "Cadena"; char *cadena4 = "Cadena"; if(strcmp(cadena1, cadena2) < 0) cout << cadena1 << " es menor que " << cadena2 << endl; else if(strcmp(cadena1, cadena2) > 0) cout << cadena1 << " es menor que " << cadena2 << endl; else cout << cadena1 << " es igual que " << cadena2 << endl; cout << strcmp(cadena3, cadena2) << endl; cout << strcmp(cadena3, cadena4) << endl; return 0; } Función strcat() Añade o concatena una cadena a otra. Sintaxis: char *strcat(char *dest, const char *orig); strcat añade una copia de orig al finalde dest. La longitud de la cadenaresultante será strlen(dest) + strlen(orig). Valor de retorno: strcat devuelve un puntero a la cadena concatenada. Ejemplo: #include <iostream> #include <cstring> using namespace std; int main() { char *cadena1 = "Cadena de"; char *cadena2 = " ejemplo"; char cadena3[126]; strcpy(cadena3, cadena1); cout << strcat(cadena3, cadena2) << endl; return 0; }
  • 9. Función strncpy() Copia un determinado número de caracteres de una cadena en otra. Sintaxis: char *strncpy(char *dest, const char *orig, size_t maxlong); Copia maxlong caracteres de la cadena orig a dest, si hay más caracteres se ignoran, si hay menos se rellenará con caracteres nulos. La cadena dest no se terminará con nulo si la longitud de orig es maxlong o más. Valor de retorno: strncpy devuelve el puntero dest. Ejemplo: #include <iostream> #include <cstring> using namespace std; int main() { char *cadena = "Cadena ejemplo"; char cad[32]; strncpy(cad, cadena, 4); cad[4] = '0'; cout << cad << endl; return 0; } Función strncmp() Compara dos porciones de cadenas. Sintaxis: int strncmp(char *cad1, const char *cad2, size_t maxlong); Compara las dos cadenas igual que strcmp, pero sólo se comparan los primeros maxlong caracteres. Ejemplo: #include <iostream> #include <cstring> using namespace std; int main() { char *cadena1 = "Cadena ejemplo 1"; char *cadena2 = "Cadena ejemplo 2"; char *cadena3 = "Cadena";
  • 10. char *cadena4 = "Cadena"; if(strncmp(cadena1, cadena2, 6) < 0) cout << cadena1 << " es menor que " << cadena2 << endl; else if(strncmp(cadena1, cadena2, 6) > 0) cout << cadena1 << " es menor que " << cadena2 << endl; else cout << cadena1 << " es igual que " << cadena2 << endl; cout << strncmp(cadena3, cadena2, 5) << endl; cout << strncmp(cadena3, cadena4, 4) << endl; return 0; } Función strncat() Añade o concatena una porción de una cadena a otra. Sintaxis: char *strncat(char *dest, const char *orig, size_t maxlong); strncat añade como máximo maxlong caracteres de la cadena orig al final de dest, y después añade el carácter nulo. La longitud de la cadena resultante será strlen(dest) + maxlong. Valor de retorno: strncat devuelve un puntero a la cadena concatenada. Ejemplo: #include <iostream> #include <cstring> using namespace std; int main() { char *cadena1 = "Cadena de"; char *cadena2 = " ejemplo"; char cadena3[126]; strcpy(cadena3, cadena1); cout << strncat(cadena3, cadena2, 5) << endl; Función strtok() Busca dentro de una cadena conjuntos de caracteres o símbolos (tokens) separados por delimitadores. Sintaxis:
  • 11. char *strtok(char *s1, const char *s2); strtok considera la cadena s1como una listade símbolos separados por delimitadores de laforma de s2. La primera llamada a strtok devuelve un puntero al primer carácter del primer símbolo de s1 e inserta un carácter nulo a continuación del símbolo retornado. Las siguientes llamadas, especificando null como primer argumento, siguen dando símbolos hasta que no quede ninguno. El separador, s2, puede ser diferente para cada llamada. Valor de retorno: strtok devuelve un puntero al símbolo extraído, oNULL cuando no quedan símbolos. Ejemplo: #include <cstring> #include <iostream> using namespace std; int main() { char entrada[32] = "abc,d,efde,ew,231"; char *p; // La primera llamada con entrada p = strtok(entrada, ","); if(p) cout << p << endl; // Las siguientes llamadas con NULL while(p) { p = strtok(NULL, ","); if(p) cout << p << endl; } return 0; } Bibliografía a. http://programacion1-teoria.wikispaces.com/Lenguaje+C b. http://teoria-de-programacion.globered.com/categoria.asp?idcat=33 c. http://c.conclase.net/curso/?cap=006#inicio d. http://www.taringa.net/posts/ciencia-educacion/15391497/C--- Declaracion-de-variables.html e. http://ccodigo.wordpress.com/tag/string-h/ f. http://sopa.dis.ulpgc.es/fso/cpp/intro_c/introc53.htm g. http://fcqi.tij.uabc.mx/usuarios/cgaxiola/prog_p7.pdf h. http://es.wikipedia.org/wiki/String.h i. http://arduino.cc/en/pmwiki.php?n=Tutorial/TextString j. http://c.conclase.net/curso/?cap=902f