SlideShare ist ein Scribd-Unternehmen logo
1 von 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

Weitere ähnliche Inhalte

Was ist angesagt?

LENGUAJE DE PROGRAMACION. INVESTIGACION
LENGUAJE DE PROGRAMACION. INVESTIGACIONLENGUAJE DE PROGRAMACION. INVESTIGACION
LENGUAJE DE PROGRAMACION. INVESTIGACIONKathGon1
 
Programación modular en Introducción a la Programación
Programación modular en Introducción a la ProgramaciónProgramación modular en Introducción a la Programación
Programación modular en Introducción a la ProgramaciónFacultad de Ciencias y Sistemas
 
Fundamentos de Programación - Unidad V: Modularidad
Fundamentos de Programación - Unidad V: ModularidadFundamentos de Programación - Unidad V: Modularidad
Fundamentos de Programación - Unidad V: ModularidadJosé Antonio Sandoval Acosta
 
Teoria de Grafos. Conceptos básicos.
Teoria de Grafos. Conceptos básicos.Teoria de Grafos. Conceptos básicos.
Teoria de Grafos. Conceptos básicos.Nabor Chirinos
 
Vectores - Informática
Vectores - InformáticaVectores - Informática
Vectores - Informáticacompumet sac
 
Palabras Reservadas en C++
Palabras Reservadas en C++Palabras Reservadas en C++
Palabras Reservadas en C++ncrmax
 
Algoritmos de busqueda - hash truncamiento
Algoritmos de busqueda - hash truncamientoAlgoritmos de busqueda - hash truncamiento
Algoritmos de busqueda - hash truncamientoLutzo Guzmán
 
Programa en C++ ( escriba 3 números y diga cual es el mayor))
Programa en C++ ( escriba 3 números y diga cual es el mayor))Programa en C++ ( escriba 3 números y diga cual es el mayor))
Programa en C++ ( escriba 3 números y diga cual es el mayor))Alex Penso Romero
 
Estructura de Datos - Unidad 4 Estructuras no lineales
Estructura de Datos - Unidad 4 Estructuras no linealesEstructura de Datos - Unidad 4 Estructuras no lineales
Estructura de Datos - Unidad 4 Estructuras no linealesJosé Antonio Sandoval Acosta
 
Ejemplos Para Dev C++
Ejemplos Para Dev C++Ejemplos Para Dev C++
Ejemplos Para Dev C++cemayoral
 
Programación Orientada a Objetos -Unidad 6 archivos
Programación Orientada a Objetos -Unidad 6 archivosProgramación Orientada a Objetos -Unidad 6 archivos
Programación Orientada a Objetos -Unidad 6 archivosJosé Antonio Sandoval Acosta
 
Ejercicios plano tangente
Ejercicios plano tangenteEjercicios plano tangente
Ejercicios plano tangenteUNEFA
 
curso Pseint 1 (16 ejercicios basicos)
curso Pseint 1 (16 ejercicios basicos)curso Pseint 1 (16 ejercicios basicos)
curso Pseint 1 (16 ejercicios basicos)Luis Ancel
 
Problemas resueltos de c++
Problemas  resueltos de c++Problemas  resueltos de c++
Problemas resueltos de c++johnny herrera
 

Was ist angesagt? (20)

LENGUAJE DE PROGRAMACION. INVESTIGACION
LENGUAJE DE PROGRAMACION. INVESTIGACIONLENGUAJE DE PROGRAMACION. INVESTIGACION
LENGUAJE DE PROGRAMACION. INVESTIGACION
 
Manejo de memoria
Manejo de memoriaManejo de memoria
Manejo de memoria
 
Programación modular en Introducción a la Programación
Programación modular en Introducción a la ProgramaciónProgramación modular en Introducción a la Programación
Programación modular en Introducción a la Programación
 
Fundamentos de Programación - Unidad V: Modularidad
Fundamentos de Programación - Unidad V: ModularidadFundamentos de Programación - Unidad V: Modularidad
Fundamentos de Programación - Unidad V: Modularidad
 
Teoria de Grafos. Conceptos básicos.
Teoria de Grafos. Conceptos básicos.Teoria de Grafos. Conceptos básicos.
Teoria de Grafos. Conceptos básicos.
 
Arboles Binarios
Arboles BinariosArboles Binarios
Arboles Binarios
 
Vectores - Informática
Vectores - InformáticaVectores - Informática
Vectores - Informática
 
Palabras Reservadas en C++
Palabras Reservadas en C++Palabras Reservadas en C++
Palabras Reservadas en C++
 
Algoritmos de busqueda - hash truncamiento
Algoritmos de busqueda - hash truncamientoAlgoritmos de busqueda - hash truncamiento
Algoritmos de busqueda - hash truncamiento
 
Programa en C++ ( escriba 3 números y diga cual es el mayor))
Programa en C++ ( escriba 3 números y diga cual es el mayor))Programa en C++ ( escriba 3 números y diga cual es el mayor))
Programa en C++ ( escriba 3 números y diga cual es el mayor))
 
Estructura de Datos - Unidad 4 Estructuras no lineales
Estructura de Datos - Unidad 4 Estructuras no linealesEstructura de Datos - Unidad 4 Estructuras no lineales
Estructura de Datos - Unidad 4 Estructuras no lineales
 
Ejemplos Para Dev C++
Ejemplos Para Dev C++Ejemplos Para Dev C++
Ejemplos Para Dev C++
 
Programación Orientada a Objetos -Unidad 6 archivos
Programación Orientada a Objetos -Unidad 6 archivosProgramación Orientada a Objetos -Unidad 6 archivos
Programación Orientada a Objetos -Unidad 6 archivos
 
Ejercicios plano tangente
Ejercicios plano tangenteEjercicios plano tangente
Ejercicios plano tangente
 
Tipos De Datos
Tipos De DatosTipos De Datos
Tipos De Datos
 
Estructuras en c++
Estructuras en c++Estructuras en c++
Estructuras en c++
 
curso Pseint 1 (16 ejercicios basicos)
curso Pseint 1 (16 ejercicios basicos)curso Pseint 1 (16 ejercicios basicos)
curso Pseint 1 (16 ejercicios basicos)
 
Grafos
GrafosGrafos
Grafos
 
Problemas resueltos de c++
Problemas  resueltos de c++Problemas  resueltos de c++
Problemas resueltos de c++
 
Comandos java
Comandos javaComandos java
Comandos java
 

Ähnlich wie Fundamentos de programación librería string C++

Ähnlich wie 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_
 

Kürzlich hochgeladen

Posición astronómica y geográfica de Europa.pptx
Posición astronómica y geográfica de Europa.pptxPosición astronómica y geográfica de Europa.pptx
Posición astronómica y geográfica de Europa.pptxBeatrizQuijano2
 
Tema 19. Inmunología y el sistema inmunitario 2024
Tema 19. Inmunología y el sistema inmunitario 2024Tema 19. Inmunología y el sistema inmunitario 2024
Tema 19. Inmunología y el sistema inmunitario 2024IES Vicent Andres Estelles
 
INSTRUCCION PREPARATORIA DE TIRO .pptx
INSTRUCCION PREPARATORIA DE TIRO   .pptxINSTRUCCION PREPARATORIA DE TIRO   .pptx
INSTRUCCION PREPARATORIA DE TIRO .pptxdeimerhdz21
 
Tema 17. Biología de los microorganismos 2024
Tema 17. Biología de los microorganismos 2024Tema 17. Biología de los microorganismos 2024
Tema 17. Biología de los microorganismos 2024IES Vicent Andres Estelles
 
semana 4 9NO Estudios sociales.pptxnnnn
semana 4  9NO Estudios sociales.pptxnnnnsemana 4  9NO Estudios sociales.pptxnnnn
semana 4 9NO Estudios sociales.pptxnnnnlitzyleovaldivieso
 
NUEVAS DIAPOSITIVAS POSGRADO Gestion Publica.pdf
NUEVAS DIAPOSITIVAS POSGRADO Gestion Publica.pdfNUEVAS DIAPOSITIVAS POSGRADO Gestion Publica.pdf
NUEVAS DIAPOSITIVAS POSGRADO Gestion Publica.pdfUPTAIDELTACHIRA
 
Proyecto de aprendizaje dia de la madre MINT.pdf
Proyecto de aprendizaje dia de la madre MINT.pdfProyecto de aprendizaje dia de la madre MINT.pdf
Proyecto de aprendizaje dia de la madre MINT.pdfpatriciaines1993
 
PINTURA DEL RENACIMIENTO EN ESPAÑA (SIGLO XVI).ppt
PINTURA DEL RENACIMIENTO EN ESPAÑA (SIGLO XVI).pptPINTURA DEL RENACIMIENTO EN ESPAÑA (SIGLO XVI).ppt
PINTURA DEL RENACIMIENTO EN ESPAÑA (SIGLO XVI).pptAlberto Rubio
 
Feliz Día de la Madre - 5 de Mayo, 2024.pdf
Feliz Día de la Madre - 5 de Mayo, 2024.pdfFeliz Día de la Madre - 5 de Mayo, 2024.pdf
Feliz Día de la Madre - 5 de Mayo, 2024.pdfMercedes Gonzalez
 
Biografía de Charles Coulomb física .pdf
Biografía de Charles Coulomb física .pdfBiografía de Charles Coulomb física .pdf
Biografía de Charles Coulomb física .pdfGruberACaraballo
 
Prueba de evaluación Geografía e Historia Comunidad de Madrid 4ºESO
Prueba de evaluación Geografía e Historia Comunidad de Madrid 4ºESOPrueba de evaluación Geografía e Historia Comunidad de Madrid 4ºESO
Prueba de evaluación Geografía e Historia Comunidad de Madrid 4ºESOluismii249
 
TEMA 14.DERIVACIONES ECONÓMICAS, SOCIALES Y POLÍTICAS DEL PROCESO DE INTEGRAC...
TEMA 14.DERIVACIONES ECONÓMICAS, SOCIALES Y POLÍTICAS DEL PROCESO DE INTEGRAC...TEMA 14.DERIVACIONES ECONÓMICAS, SOCIALES Y POLÍTICAS DEL PROCESO DE INTEGRAC...
TEMA 14.DERIVACIONES ECONÓMICAS, SOCIALES Y POLÍTICAS DEL PROCESO DE INTEGRAC...jlorentemartos
 
origen y desarrollo del ensayo literario
origen y desarrollo del ensayo literarioorigen y desarrollo del ensayo literario
origen y desarrollo del ensayo literarioELIASAURELIOCHAVEZCA1
 
LA LITERATURA DEL BARROCO 2023-2024pptx.pptx
LA LITERATURA DEL BARROCO 2023-2024pptx.pptxLA LITERATURA DEL BARROCO 2023-2024pptx.pptx
LA LITERATURA DEL BARROCO 2023-2024pptx.pptxlclcarmen
 
Tema 10. Dinámica y funciones de la Atmosfera 2024
Tema 10. Dinámica y funciones de la Atmosfera 2024Tema 10. Dinámica y funciones de la Atmosfera 2024
Tema 10. Dinámica y funciones de la Atmosfera 2024IES Vicent Andres Estelles
 
TALLER DE DEMOCRACIA Y GOBIERNO ESCOLAR-COMPETENCIAS N°3.docx
TALLER DE DEMOCRACIA Y GOBIERNO ESCOLAR-COMPETENCIAS N°3.docxTALLER DE DEMOCRACIA Y GOBIERNO ESCOLAR-COMPETENCIAS N°3.docx
TALLER DE DEMOCRACIA Y GOBIERNO ESCOLAR-COMPETENCIAS N°3.docxNadiaMartnez11
 

Kürzlich hochgeladen (20)

Posición astronómica y geográfica de Europa.pptx
Posición astronómica y geográfica de Europa.pptxPosición astronómica y geográfica de Europa.pptx
Posición astronómica y geográfica de Europa.pptx
 
Tema 19. Inmunología y el sistema inmunitario 2024
Tema 19. Inmunología y el sistema inmunitario 2024Tema 19. Inmunología y el sistema inmunitario 2024
Tema 19. Inmunología y el sistema inmunitario 2024
 
INSTRUCCION PREPARATORIA DE TIRO .pptx
INSTRUCCION PREPARATORIA DE TIRO   .pptxINSTRUCCION PREPARATORIA DE TIRO   .pptx
INSTRUCCION PREPARATORIA DE TIRO .pptx
 
Tema 17. Biología de los microorganismos 2024
Tema 17. Biología de los microorganismos 2024Tema 17. Biología de los microorganismos 2024
Tema 17. Biología de los microorganismos 2024
 
semana 4 9NO Estudios sociales.pptxnnnn
semana 4  9NO Estudios sociales.pptxnnnnsemana 4  9NO Estudios sociales.pptxnnnn
semana 4 9NO Estudios sociales.pptxnnnn
 
NUEVAS DIAPOSITIVAS POSGRADO Gestion Publica.pdf
NUEVAS DIAPOSITIVAS POSGRADO Gestion Publica.pdfNUEVAS DIAPOSITIVAS POSGRADO Gestion Publica.pdf
NUEVAS DIAPOSITIVAS POSGRADO Gestion Publica.pdf
 
Proyecto de aprendizaje dia de la madre MINT.pdf
Proyecto de aprendizaje dia de la madre MINT.pdfProyecto de aprendizaje dia de la madre MINT.pdf
Proyecto de aprendizaje dia de la madre MINT.pdf
 
PINTURA DEL RENACIMIENTO EN ESPAÑA (SIGLO XVI).ppt
PINTURA DEL RENACIMIENTO EN ESPAÑA (SIGLO XVI).pptPINTURA DEL RENACIMIENTO EN ESPAÑA (SIGLO XVI).ppt
PINTURA DEL RENACIMIENTO EN ESPAÑA (SIGLO XVI).ppt
 
Interpretación de cortes geológicos 2024
Interpretación de cortes geológicos 2024Interpretación de cortes geológicos 2024
Interpretación de cortes geológicos 2024
 
Feliz Día de la Madre - 5 de Mayo, 2024.pdf
Feliz Día de la Madre - 5 de Mayo, 2024.pdfFeliz Día de la Madre - 5 de Mayo, 2024.pdf
Feliz Día de la Madre - 5 de Mayo, 2024.pdf
 
Biografía de Charles Coulomb física .pdf
Biografía de Charles Coulomb física .pdfBiografía de Charles Coulomb física .pdf
Biografía de Charles Coulomb física .pdf
 
Lecciones 06 Esc. Sabática. Los dos testigos
Lecciones 06 Esc. Sabática. Los dos testigosLecciones 06 Esc. Sabática. Los dos testigos
Lecciones 06 Esc. Sabática. Los dos testigos
 
Sesión de clase APC: Los dos testigos.pdf
Sesión de clase APC: Los dos testigos.pdfSesión de clase APC: Los dos testigos.pdf
Sesión de clase APC: Los dos testigos.pdf
 
Supuestos_prácticos_funciones.docx
Supuestos_prácticos_funciones.docxSupuestos_prácticos_funciones.docx
Supuestos_prácticos_funciones.docx
 
Prueba de evaluación Geografía e Historia Comunidad de Madrid 4ºESO
Prueba de evaluación Geografía e Historia Comunidad de Madrid 4ºESOPrueba de evaluación Geografía e Historia Comunidad de Madrid 4ºESO
Prueba de evaluación Geografía e Historia Comunidad de Madrid 4ºESO
 
TEMA 14.DERIVACIONES ECONÓMICAS, SOCIALES Y POLÍTICAS DEL PROCESO DE INTEGRAC...
TEMA 14.DERIVACIONES ECONÓMICAS, SOCIALES Y POLÍTICAS DEL PROCESO DE INTEGRAC...TEMA 14.DERIVACIONES ECONÓMICAS, SOCIALES Y POLÍTICAS DEL PROCESO DE INTEGRAC...
TEMA 14.DERIVACIONES ECONÓMICAS, SOCIALES Y POLÍTICAS DEL PROCESO DE INTEGRAC...
 
origen y desarrollo del ensayo literario
origen y desarrollo del ensayo literarioorigen y desarrollo del ensayo literario
origen y desarrollo del ensayo literario
 
LA LITERATURA DEL BARROCO 2023-2024pptx.pptx
LA LITERATURA DEL BARROCO 2023-2024pptx.pptxLA LITERATURA DEL BARROCO 2023-2024pptx.pptx
LA LITERATURA DEL BARROCO 2023-2024pptx.pptx
 
Tema 10. Dinámica y funciones de la Atmosfera 2024
Tema 10. Dinámica y funciones de la Atmosfera 2024Tema 10. Dinámica y funciones de la Atmosfera 2024
Tema 10. Dinámica y funciones de la Atmosfera 2024
 
TALLER DE DEMOCRACIA Y GOBIERNO ESCOLAR-COMPETENCIAS N°3.docx
TALLER DE DEMOCRACIA Y GOBIERNO ESCOLAR-COMPETENCIAS N°3.docxTALLER DE DEMOCRACIA Y GOBIERNO ESCOLAR-COMPETENCIAS N°3.docx
TALLER DE DEMOCRACIA Y GOBIERNO ESCOLAR-COMPETENCIAS N°3.docx
 

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