Se puede hacer esto ?? .. porque?

Iniciado por ThePinkPanther, 11 Mayo 2013, 00:36 AM

0 Miembros y 3 Visitantes están viendo este tema.

ThePinkPanther


#include <iostream>

using namespace std;

int main()
{
  int var;
    cin>>var;
    int x[var];
for(int i=0;i<var;i++)
{
  cout<<"Elemento " << i + 1 << " : " ; cin>>x[i];
  cout<<endl;
}

for(int i=0;i<var;i++)cout<<x[i]<<endl;

}



No era que para dimensionar un vector en tiempo de ejecución , se necesitaba reservar memoria dinamica ?? , como puede ser que dimensione un vector con una variable.

leogtz

Se puede, pero debería darte un warning.
Código (perl) [Seleccionar]

(( 1 / 0 )) &> /dev/null || {
echo -e "stderrrrrrrrrrrrrrrrrrr";
}

http://leonardogtzr.wordpress.com/
leogutierrezramirez@gmail.com

ThePinkPanther

Cita de: Leo Gutiérrez. en 11 Mayo 2013, 00:46 AM
Se puede, pero debería darte un warning.

no tira nada de warning, yo que usaba new para cuando el usuario ingresaba la cantidad de elementos que el arreglo iva a dimensionar como es que se puede, en el libro que estuve leyendo dice , que para declara un arreglo hay que hacerlo con una constante numerica , q puede ser un numero ej vector[30] , o un #define elementos 255 , y despues vector[elementos]; ... ?

amchacon

En C++ se puede. En C también a partir del estándar C98.

Es un array de tamaño variable. Antiguamente las variables se creaban al principio de cada llave. Por lo que se necesitaba su tamaño antes de entrar.

Ahora cada variable puede crearse en cualquier línea de código y en cualquier momento.

PD: No da warning, a no ser que tengas un compilador obsoleto o tengas activado warnings de C estricto.
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

ThePinkPanther

Cita de: amchacon en 11 Mayo 2013, 01:31 AM
En C++ se puede. En C también a partir del estándar C98.

Es un array de tamaño variable. Antiguamente las variables se creaban al principio de cada llave. Por lo que se necesitaba su tamaño antes de entrar.

Ahora cada variable puede crearse en cualquier línea de código y en cualquier momento.

PD: No da warning, a no ser que tengas un compilador obsoleto o tengas activado warnings de C estricto.

entonces, que sentido tiene new , si se puede declarar dinamicamente un arreglo en cualquier parte del programa utilizando este metodo.

amchacon

Cita de: ThePinkPanther en 11 Mayo 2013, 01:37 AM
entonces, que sentido tiene new , si se puede declarar dinamicamente un arreglo en cualquier parte del programa utilizando este metodo.
No aver, puedes declararlo así. Pero una vez creado no puedes redimensionarlo (con new sí, pero acuerdate antes de borrar los datos anteriores).

Además los array cogen memoria de la pila mientras que new coge memoria de la ram.

Para hacernos una idea, al ejecutar el programa. El SO le asigna un espacio de memoria al programa que se le dedomina "pila", puede ser alrededor de 2-10 mb. Esta memoria se va llenando de forma consecutiva, por lo que se puede crear elementos y borrar elementos de una forma rápida y sencilla. Todos los elementos básicos que crees (hasta los objetos) se meten en la pila.

Evidentemente, es muy probable que con 2 mb te quedes corto. Por lo que puedes pedirle al sistema operativo que te reserve memoria adicional (usando new). El sistema operativo "buscará" celdas sueltas en la memoria y te asignará lo que vayas necesitando. Evidentemente, tendremos que guardar la dirreción de la celda asignada, de ahí que haya que usar punteros.

Para hacernos una idea, prueba la siguiente sentencia:

Código (cpp) [Seleccionar]
int Cosita[1000000];

Esta sentencia probablemente fallará (aunque tengamos 4 gb de ram). En cambio si usamos new:

Código (cpp) [Seleccionar]
int* Cosita = new int[1000000];

Debería funcionar sin problemas.
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

ThePinkPanther

#6
Cita de: amchacon en 11 Mayo 2013, 01:57 AM
No aver, puedes declararlo así. Pero una vez creado no puedes redimensionarlo (con new sí, pero acuerdate antes de borrar los datos anteriores).

Además los array cogen memoria de la pila mientras que new coge memoria de la ram.

Para hacernos una idea, al ejecutar el programa. El SO le asigna un espacio de memoria al programa que se le dedomina "pila", puede ser alrededor de 2-10 mb. Esta memoria se va llenando de forma consecutiva, por lo que se puede crear elementos y borrar elementos de una forma rápida y sencilla. Todos los elementos básicos que crees (hasta los objetos) se meten en la pila.

Evidentemente, es muy probable que con 2 mb te quedes corto. Por lo que puedes pedirle al sistema operativo que te reserve memoria adicional (usando new). El sistema operativo "buscará" celdas sueltas en la memoria y te asignará lo que vayas necesitando. Evidentemente, tendremos que guardar la dirreción de la celda asignada, de ahí que haya que usar punteros.

Para hacernos una idea, prueba la siguiente sentencia:

Código (cpp) [Seleccionar]
int Cosita[1000000];

Esta sentencia probablemente fallará (aunque tengamos 4 gb de ram). En cambio si usamos new:

Código (cpp) [Seleccionar]
int* Cosita = new int[1000000];

Debería funcionar sin problemas.


Muchas gracias, eres un genio , entonces la diferencia es que todas las estructuras de datos ,que no sean declaradas con una función de asignación de memoria dinamica , o un operador que sirva para eso,se guardan en la pila?
y tambien que puedo reasignar el espacio cuando utilizo estas funciones/operadores y en caso contrario no?

Luchoz95

y ademas creo que para asignar la dimension de una variable en tiempo de ejecucion se usa size_t y no int ! S2!

amchacon

Cita de: ThePinkPanther en 11 Mayo 2013, 02:04 AM

Muchas gracias, eres un genio , entonces la diferencia es que todas las estructuras de datos ,que no sean declaradas con una función de asignación de memoria dinamica , o un operador que sirva para eso,se guardan en la pila?
y tambien que puedo reasignar el espacio cuando utilizo estas funciones/operadores y en caso contrario no?
Exacto, la principal diferencia es la localización en memoria. Además tu decides voluntariamente cuando borrarla, lo que es un poder importante (aunque también peligroso porque se te puede olvidar).

Lo de reasignar el vector en realidad es una verdad a medias, lo que en realidad haces es pedirle al sistema operativo que cree otro vector (ojo, como se te olvide borrar el antiguo tendrás dos vectores en memoria).

Cita de: Luchoz95 en 11 Mayo 2013, 02:15 AM
y ademas creo que para asignar la dimension de una variable en tiempo de ejecucion se usa size_t y no int ! S2!
Cualquier variable vale puesto que se hace una conversión implicita a size_t.
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

ThePinkPanther

Muchas gracias a los dos, me aclararón mis dudas ,me estaba volviendo un poco loco .  ;-) Saludos , un moderador puede cerrar este tema.