1. Es un lenguaje de programación diseñado a
mediados de los años 1980 por Bjarne
Stroustrup. La intención de su creación fue el
extender al exitoso lenguaje de
programación C con mecanismos que
permitan la manipulación de objetos. En ese
sentido, desde el punto de vista de
los lenguajes orientados a objetos, el C++ es
un lenguaje híbrido.
Actualmente existe un estándar, denominado
ISO C++, al que se han adherido la mayoría
de los fabricantes de compiladores más
2. modernos. Existen también algunos
intérpretes, tales como ROOT.
Una particularidad del C++ es la posibilidad
de redefinir los operadores, y de poder crear
nuevos tipos que se comporten como tipos
fundamentales.
El nombre C++ fue propuesto por Rick
Mascitti en el año 1983, cuando el lenguaje
fue utilizado por primera vez fuera de un
laboratorio científico. Antes se había usado
el nombre "C con clases". En C++, la
expresión "C++" significa "incremento de C"
y se refiere a que C++ es una extensión de
C.
Buenos en todo programa de c++ debemos
empezar con una librería
Pues las librerías es una colección
de clases y funciones , escritas en el núcleo
del lenguaje. La biblioteca estándar
proporciona varios contenedores
genéricos, funciones para utilizar y manipular
esos contenedores, funciones objeto,
cadenas y flujos genéricos
3. Tipo de librerías
#include "stdio.h"
Esta librería puede tener diferentes
funciones tales como
fclose Cierra un fichero a través de su puntero.
fopen,
freopen,
fdopen
Abre un fichero para lectura, para
escritura/reescritura o para adición.
remove Elimina un fichero.
rename Cambia al fichero de nombre.
rewind Coloca el indicador de posición de fichero para el
stream apuntado por stream al comienzo del
fichero.
tmpfile Crea y abre un fichero temporal que es borrado
cuando cerramos con la función fclose().
clearerr Despeja los indicadores de final de fichero y de
posición de fichero para el stream apuntado por
stream al comienzo del fichero.
feof Comprueba el indicador de final de fichero.
ferror Comprueba el indicador de errores.
fflush Si stream apunta a un stream de salida o de
actualización cuya operación más reciente no era
de entrada, la función fflush envía cualquier dato
aún sin escribir al entorno local o a ser escrito en el
fichero; si no, entonces el comportamiento no está
definido. Si stream es un puntero nulo, la función
fflush realiza el despeje para todos
los streams cuyo comportamiento está descrito
4. anteriormente.
fgetpos Devuelve la posición actual del fichero.
fgetc Devuelve un carácter de un fichero.
fgets Consigue una cadena de caracteres de un fichero.
fputc Escribe un carácter en un fichero.
fputs Escribe una cadena de caracteres en un fichero.
ftell Devuelve la posición actual del fichero como
número de bytes.
fseek Sitúa el puntero de un fichero en una posición
aleatoria.
fsetpos Cambia la posición actual de un fichero.
fread lee diferentes tamaños de datos de un fichero.
fwrite Envía, desde el array apuntado por puntero,
hasta nmemb de elementos cuyo tamaño es
especificado por tamaño. El indicador de posición
de ficheros es avanzado por el número de
caracteres escritos correctamente. Si existe un
error, el valor resultante del indicador de posición
de ficheros es indeterminado.
getc Devuelve un carácter desde un fichero.
getchar Igual que getc.
gets Lee caracteres de entrada hasta que encuentra un
salto de línea, y los almacena en un único
argumento.
printf,
fprintf,
sprintf
snprintf
Usados para imprimir salidas de datos.
vprintf También utilizado para imprimir salidas.
5. perror Escribe un mensaje de error a stderr.
putc Devuelve un carácter de un fichero.
putchar,
fputchar
Igual que putc(stdout).
scanf,
fscanf,
sscanf
Utilizado para introducir entradas.
vfscanf,
vscanf,
vsscanf
También utilizado para introducir entradas.
setbuf Esta función es equivalente a la función setvbuf
pasando los valores _IOFBF para modo y BUFSIZ
para tamaño, o (si acumulador es un puntero nulo),
con el valor _IONBF para modo.
setvbuf Sólo puede ser usada después de que el stream
apuntado por stream ha sido asociado con un
fichero abierto y antes de otra operación cualquiera
es llevada acabo al stream. El argumento modo
determina cómo stream será almacenado según lo
siguiente: _IOFBF ocasiona la entrada/salida a ser
completamente almacenado; _IOLBF ocasiona la
entrada/salida a almacenar por líneas; _IONBF
ocasiona la entrada/salida a no ser almacenado. Si
acumulador no es un puntero nulo, el array al que
es apuntado puede ser usado en vez de la
acumulación adjudicada por la función setvbuf. El
argumento tamaño especifica el tamaño del array.
tmpnam Genera una cadena de caracteres que es un
nombre válido para ficheros y que no es igual al
nombre de un fichero existente. La función tmpnam
genera una cadena diferente cada vez que es
llamada, hasta un máximo de TMP_MAX veces. Si
6. la función es llamada más veces que TMP_MAX,
entonces el comportamiento de la función está
definido según la implementación del compilador.
puts Imprime una de cadena de caracteres.
#include "stdlib.h"
atof (ascii to float) cadena de caracteres a coma
flotante
atoi cadena de caracteres a entero
atol (C Standard
Library) (ascii to long)
cadena de caracteres a entero
tamaño largo
strtod cadena de caracteres a coma
flotante tamaño doble
strtol cadena de caracteres a entero
largo
strtoul cadena de caracteres a entero
largo sin signo (positivo)
rand Genera un número pseudo-
aleatorio
srand Establece la semilla para el
generador de números pseudo-
aleatorios
malloc, calloc, realloc Reservan memoria dinámica
del heap
free Liberan memoria devolviéndola
al heap
7. abort terminar ejecución anormalmente
atexit registrar una función
callback callback para la salida del
programa
exit terminar ejecución del programa
getenv recuperar una variable de entorno
system ejecutar un comando externo
bsearch búsqueda binaria en un array
qsort ordena un vector usando quicksor
abs, labs valor absoluto
div, ldiv división entera o euclidiana
#include <string.h>
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 deben 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
8. 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
9. 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
#include <ctype.h>
tolower: Convierte un carácter, en un
parámetro entero ch, a minúscula.
toupper: Convierte un carácter, en un
parámetro entero ch, a mayúscula
#include <locale.h>
localeconv: La función localeconv asigna los
componentes de un objeto con tipo struct
lconv con valores apropiados para el
10. formateo de cantidades numéricas
(monetarias y otras) según las reglas de la
localidad actual.
setlocale La función setlocale selecciona la
porción apropiada de la localidad del
programa especificado por los argumentos
categoria y localidad. La función setlocale
puede ser usada para cambiar o preguntar la
localidad actual total del
programa o porciones de ello.
#include <math.h>
acos arcocoseno
asien arcoseno
atan arcotangente
atan2 arcotangente de dos parámetros
ceil menor entero no menor que el parámetro
cos coseno
cosh coseno hiperbólico
exp(double
x)
función exponencial, computa ex
11. abs valor absoluto
floor mayor entero no mayor que el parámetro
fmod residuo de la division de flotantes
frexp fracciona y eleva al cuadrado.
ldexp tamaño del exponente de un valor en punto
flotante
log logaritmo natural
log10 logaritmo en base 10
modf obtiene un valor en punto flotante íntegro y en
partes
pow(x,y) eleva un valor dado a un exponente, xy
sin seno
sinh seno hiperbólico
sqrt raíz cuadrada
tan tangente
tanh tangente hiperbólica
#include <setjmp.h>
longjmp: Restaura el entorno guardado por la invocación
más reciente de la función setjmp en la misma
12. invocación del programa, con el argumento
correspondiente entorno
setjmp: Guarda su entorno de llamadas en
el argumento entorno para uso posterior por
la función longjmp
#include <signal.h>
raise: La función envía la señal señal al
programa en ejecución.
signal:La función signal retorna el valor de
func para la llamada más reciente a signal
para la señal especificada, señal, si la
operación fue realizada con éxito
#include <time.h>
char * asctime(struct tm
*)
Recibe una variable de tipo
puntero a estructura tm (struct
tm*) y devuelve una cadena de
caracteres
clock_t clock (void) Devuelve el número de pulsos de
reloj desde que se inició el
13. proceso
char * ctime(time_t *) Recibe una variable de tipo
puntero a time_t (time t*) y
devuelve una cadena con el
mismo formato que asctime()
double
difftime(time_t, time t)
Recibe dos variables de
tipo time_t, calcula su diferencia
y devuelve el resultado (double)
expresado en segundos.
struct tm
*gmtime(time_t *)
Recibe un puntero a una variable
de tiempo (time_t*) y devuelve su
conversion como fecha/hora
UTC a struct tm a través de un
puntero.
struct tm
*localtime(time_t *)
Similar funcionalidad a gmtime(),
pero devuelve la conversión
como fecha/hora LOCAL.
time_t mktime(struct_tm
*)
Inversamente
a gmtime() y localtime(),l recibe
un puntero a struct tm (struct
tm*) y devuelve su conversión al
tipo time t.
time_t time(time_t *) Devuelve la fecha/hora (time_t)
actual o -1 en caso de no ser
posible. Si el argumento que se
le pasa no es NULL, también
asigna la fecha/hora actual a
dicho argumento.
14. size_t strftime(char
*,size_t,char *,struct tm *)
Formatea la información pasada
mediante la estructura (struct
tm*) mediante el formato
indicado en una cadena (char*) e
imprime el resultado sobre otra
cadena (char*) hasta un límite de
caracteres (size_t).
Otras librerias que no tienen funciones asociadas. Pero tienen
macros constantes y/o estructuras.
#include <assert.h>
#include <errno.h>
#include <float.h>
#include <limits.h>
#include <stdarg.h>
#include <stddef.h>
RESUMEN DE LIBRERIAS
assert.h Contiene una macro para el
diagnóstico dentro de los programas.
ctype.h Contiene varias funciones para
comprobación de tipos y transformación de
caracteres.
15. errno.h Contiene varias macros usadas
para informar de errores.
limits.h Contienen varias macros que
definen constantes para el tamaño de tipo
enteros.
float.h Contienen varias macros que definen
constantes para el tamaño de tipo flotante.
locale.h Contienen varias macros,
funciones y tipos para unidades locales,
como unidad monetaria, tiempo, dígitos, etc.
math.h Contiene un macro y varias
funciones matemáticas.
setjmp.h Contienen declaraciones que
proporcionan una forma de evitar la
secuencia normal de llamada y regreso de
funciones.
signal.h Contiene un tipo, dos funciones y
varias macros para manejar condiciones
excepcionales que aparecen durante la
ejecución, tal como una señal de interrupción
de una fuente externa o un error en la
ejecución.
stdarg.h Contiene un tipo y tres macros que
proporcionan recursos para recorrer una lista
16. de argumentos de función de tamaño y tipo
desconocido.
stddef.h Contiene varios tipos y macros que
también están definidas en otras librerías,
como size_t.
stdio.h Contiene tipos, macros y funciones
para la realización de tareas de E/S.
stdlib.h Contiene tipos, macros y funciones
para la conversión numérica, generación de
números aleatorios, búsquedas y
ordenación, gestión de memoria y tareas
similares.
string.h Contiene tipos, macros y funciones
para la manipulación de cadenas de
caracteres.
time.h Contiene tipos, macros y funciones
para la la manipulación de información sobre
fechas y horas