Autor
|
Tema: Se puede hacer esto ?? .. porque? (Leído 6,117 veces)
|
ThePinkPanther
Desconectado
Mensajes: 82
|
#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.
|
|
|
En línea
|
|
|
|
leogtz
. . .. ... ..... ........ ............. .....................
Colaborador
Desconectado
Mensajes: 3.069
/^$/
|
Se puede, pero debería darte un warning.
|
|
|
En línea
|
|
|
|
ThePinkPanther
Desconectado
Mensajes: 82
|
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]; ... ?
|
|
|
En línea
|
|
|
|
amchacon
Desconectado
Mensajes: 1.211
|
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.
|
|
|
En línea
|
|
|
|
ThePinkPanther
Desconectado
Mensajes: 82
|
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.
|
|
|
En línea
|
|
|
|
amchacon
Desconectado
Mensajes: 1.211
|
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: int Cosita[1000000];
Esta sentencia probablemente fallará (aunque tengamos 4 gb de ram). En cambio si usamos new: int* Cosita = new int[1000000];
Debería funcionar sin problemas.
|
|
|
En línea
|
|
|
|
ThePinkPanther
Desconectado
Mensajes: 82
|
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: int Cosita[1000000];
Esta sentencia probablemente fallará (aunque tengamos 4 gb de ram). En cambio si usamos new: 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?
|
|
« Última modificación: 11 Mayo 2013, 02:12 am por ThePinkPanther »
|
En línea
|
|
|
|
Luchoz95
Desconectado
Mensajes: 58
|
y ademas creo que para asignar la dimension de una variable en tiempo de ejecucion se usa size_t y no int ! S2!
|
|
|
En línea
|
|
|
|
amchacon
Desconectado
Mensajes: 1.211
|
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). 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.
|
|
|
En línea
|
|
|
|
ThePinkPanther
Desconectado
Mensajes: 82
|
Muchas gracias a los dos, me aclararón mis dudas ,me estaba volviendo un poco loco . Saludos , un moderador puede cerrar este tema.
|
|
|
En línea
|
|
|
|
|
|