Autor
|
Tema: operador new para doble char (Leído 3,852 veces)
|
neo_from_cs_matrix
Desconectado
Mensajes: 35
|
tengo asi: dentro de la clase, y en el constructor necesito asignarle las dimensiones a esta matriz charesca. iba a hacerlo con malloc que es coo yo se hacerlo pero me dijeron que sea hecho con new y delete, pero para vector de int sabia como usarlo pero para este caso no. ocea necesitaria un new y un delete para esa matriz de char, si alguno sabe
|
|
|
En línea
|
|
|
|
escabe
Desconectado
Mensajes: 34
|
Con esto creas un array de tres punteros a punteros tipo char: char **A = new char*[3]; A[0] = "uno"; A[1] = "dos"; A[2] = "tres"; delete [] A;
Si cada elemento lo quieres crear dinámicamente tendras que volver a usar el operador new: No te olvides de su destrucción. La forma estática es simple: Saludos.
|
|
|
En línea
|
|
|
|
neo_from_cs_matrix
Desconectado
Mensajes: 35
|
este es una demostrasion de mi clase que estoy haciendo esto compila bien, pero decime si asi esta bien asignado con new y borrado con delete class Producto { private: int cantidad_items; char** items_de_descripcion; char descripcion[1000]; public: Producto(int cantidad_items); ~Producto();// no pueden tener argumentos };
Producto::Producto(int items=5) { cantidad_items = items;
int capacidad = 1000/cantidad_items; //items_de_descripcion = (char**) new char[cantidad_items][capacidad]; items_de_descripcion = new char*[cantidad_items];
int a=0; while(a<cantidad_items) { items_de_descripcion[a]=new char[capacidad]; a++; } }
Producto::~Producto() { for(int i = 0; i < cantidad_items; i++) // Paso 1: Borrar columnas delete [] items_de_descripcion[i]; delete [] items_de_descripcion; // paso 2: borrar filas }
|
|
|
En línea
|
|
|
|
escabe
Desconectado
Mensajes: 34
|
La filosofía es correcta pero me llama la atención esto: int capacidad = 1000/cantidad_items; Si por defecto cantidad_items es 5 las cadenas van a tener longitud cero... ¿Quizás querías decir? int capacidad = 1000*cantidad_items; Saludos.
|
|
|
En línea
|
|
|
|
neo_from_cs_matrix
Desconectado
Mensajes: 35
|
no, las cadenas van a tener longitud 1000/la cantidad de cadenas. como por defecto la cantidad es 5, entonces 1000 dividido 5 = 200 yo lo que quisiera saber es porque siendo memoria dinamica no permite usar asi items_de_descripcion = (char**) new char[cantidad_items][capacidad]; porque tira errores de que las dimensiones no son constantes. pero asiendo eso con malloc si lo acepta. pero porque con new no?
|
|
|
En línea
|
|
|
|
escabe
Desconectado
Mensajes: 34
|
yo lo que quisiera saber es porque siendo memoria dinamica no permite usar asi items_de_descripcion = (char**) new char[cantidad_items][capacidad]; porque tira errores de que las dimensiones no son constantes. pero asiendo eso con malloc si lo acepta. pero porque con new no? Esa sintaxis no es válida. Al asignar primero espacio para los punteros a las cadenas, la memoria no va a ser contínua y debes asignar espacio, despues, para cada cadena. Puedes realizar una reserva global con new, igual que con malloc. items_de_descripcion = (char**) new char[cantidad_items * capacidad + cantidad_items * sizeof(char*)]; Luego asignas los valores de los punteros (al inicio del espacio de la memoria localizada) a la dirección de las cadenas que vendrán una detrás de otra en la posición items_de_descripcion + cantidad_items * sizeof(char*); Esto se puede hacer pero es mas lioso, difícil de entender y de leer mas adelante... Saludos.
|
|
|
En línea
|
|
|
|
neo_from_cs_matrix
Desconectado
Mensajes: 35
|
Esa sintaxis no es válida. Al asignar primero espacio para los punteros a las cadenas, la memoria no va a ser contínua y debes asignar espacio, despues, para cada cadena. Puedes realizar una reserva global con new, igual que con malloc. items_de_descripcion = (char**) new char[cantidad_items * capacidad + cantidad_items * sizeof(char*)]; Luego asignas los valores de los punteros (al inicio del espacio de la memoria localizada) a la dirección de las cadenas que vendrán una detrás de otra en la posición items_de_descripcion + cantidad_items * sizeof(char*); Esto se puede hacer pero es mas lioso, difícil de entender y de leer mas adelante... Saludos. osea lo que hacia con malloc si se que era una asignacion global, osea el tamanio total de la matriz. pero pense que con esa forma de new (la que no compila) era tambien asignacion global PARA una matriz. pero ahora segun observo items_de_descripcion = (char**) new char[cantidad_items * capacidad + cantidad_items * sizeof(char*)]; esto asignaria el tamaño total de la matriz pero de forma contigua, es esto asi ? y explicame otra cosa, esto .... Al asignar primero espacio para los punteros a las cadenas, la memoria no va a ser contínua y debes asignar espacio, despues, para cada cadena. .....
entiendo que inclusive el compilador no acepta de otra forma, pero porque esa necesidad de hacerlo asi, osea primero los 5 punteros y despues los vectores de cada uno si puedes contestarme esas dos preguntas te lo agradeceria me has ayudado a entender, gracias
|
|
|
En línea
|
|
|
|
escabe
Desconectado
Mensajes: 34
|
osea lo que hacia con malloc si se que era una asignacion global, osea el tamanio total de la matriz. pero pense que con esa forma de new (la que no compila) era tambien asignacion global PARA una matriz. pero ahora segun observo items_de_descripcion = (char**) new char[cantidad_items * capacidad + cantidad_items * sizeof(char*)]; esto asignaria el tamaño total de la matriz pero de forma contigua, es esto asi ? Eso asigna tamaño para los puteros y la matriz en memoria contigua. y explicame otra cosa, esto .... Al asignar primero espacio para los punteros a las cadenas, la memoria no va a ser contínua y debes asignar espacio, despues, para cada cadena. ..... entiendo que inclusive el compilador no acepta de otra forma, pero porque esa necesidad de hacerlo asi, osea primero los 5 punteros y despues los vectores de cada uno si puedes contestarme esas dos preguntas te lo agradeceria me has ayudado a entender, gracias El uso de new tal como se muestra mas arriba es equivalente a el uso de cualquier función que localice memoria. Una vez obtenido el bloque de memoria necesario, somos nosotros los que vamos a decidir donde estarán los punteros a las cadenas y donde estarán éstas. Como es mas fácil definir que tenemos todos los punteros al principio, así lo propongo. De ese modo al referirnos a un puntero que apunte al principio del bloque, su contenido será el primer puntero... Por similitud al significado de un array en C ( un array se define por un puntero al primer elemento del mismo). Pero en esto no tiene nada que ver el compilador, aunque si la convención de C/C++. Tu puedes hacerlo de otra forma, incluso sin pos punteros a las cadenas, pues si todas ellas tienen el mismo tamaño, las puedes localizar sin necesidad de una tabla o array de punteros previo. En esto del manejo de la memoria y punteros el C/C++ es un campeón No se si me explico o te lío mas. Saludos.
|
|
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
Convertir char[] a char *[] ?
Programación C/C++
|
Sanlegas
|
2
|
4,968
|
11 Julio 2010, 01:01 am
por leogtz
|
|
|
martiz de char doble puntero
Programación C/C++
|
neo_from_cs_matrix
|
2
|
6,604
|
15 Julio 2011, 00:05 am
por rir3760
|
|
|
duda doble puntero char a matriz de char
Programación C/C++
|
neo_from_cs_matrix
|
3
|
6,265
|
5 Septiembre 2011, 03:53 am
por rir3760
|
|
|
Unsigned char y operador complemento a1(~) en c
Programación C/C++
|
fafafa01
|
2
|
2,929
|
12 Enero 2017, 15:31 pm
por engel lex
|
|
|
R se convierte en operador para toda España: ¿quinto operador a la vista?
Noticias
|
wolfbcn
|
0
|
2,848
|
26 Abril 2019, 14:30 pm
por wolfbcn
|
|