Ошибка: strcpy не была объявлена в этой области
Я получаю эту проблему в компиляции С++ в Ubuntu g++ версии 4.4.3.
Я не знаю заголовки, чтобы включить, чтобы решить эту проблему. Спасибо.
centro_medico.cpp: In constructor ‘Centro_medico::Centro_medico(char*, char*, int, int, float)’:
centro_medico.cpp:5: error: ‘strcpy’ was not declared in this scope
centro_medico.cpp:13: warning: deprecated conversion from string constant to ‘char*’
centro_medico.cpp:13: warning: deprecated conversion from string constant to ‘char*’
centro_medico.cpp: In member function ‘Centro_medico& Centro_medico::operator=(const Centro_medico&)’:
centro_medico.cpp:26: error: ‘strcpy’ was not declared in this scope
centro_medico.cpp:39: warning: deprecated conversion from string constant to ‘char*’
centro_medico.cpp:39: warning: deprecated conversion from string constant to ‘char*’
centro_medico.cpp: In member function ‘bool Centro_medico::quitar_medico(int)’:
centro_medico.cpp:92: warning: deprecated conversion from string constant to ‘char*’
centro_medico.cpp:92: warning: deprecated conversion from string constant to ‘char*’
centro_medico.cpp: In member function ‘void Centro_medico::mostrar_especialidades(std::ostream&) const’:
centro_medico.cpp:123: error: ‘strcmpi’ was not declared in this scope
centro_medico.cpp: In member function ‘void Centro_medico::mostrar_horarios_consulta(char*) const’:
centro_medico.cpp:162: error: ‘strcmpi’ was not declared in this scope
centro_medico.cpp: In member function ‘void Centro_medico::crea_medicos()’:
centro_medico.cpp:321: warning: deprecated conversion from string constant to ‘char*’
centro_medico.cpp:321: warning: deprecated conversion from string constant to ‘char*’
medico.cpp
#include "medico.h"
#include <cstdlib>
#include <iostream>
#include <stdlib>
#include<cstring>
#include<string>
long Medico::total_consultas=0;
Medico::Medico(char *nom,char * espe,int colegiado,int trabajo)
{
int i;
strcpy(nombre,nom);
strcpy(especialidad,espe);
num_colegiado=colegiado;
num_horas_diarias=trabajo;
citas_medico= new Cita*[5]; // 5 Días de las semana, de Lunes a Viernes.
for (i=0;i<5;i++)
citas_medico[i]=new Cita[num_horas_diarias];
}
Medico::Medico(const Medico &m){
int i;
citas_medico=new Cita*[5];
for (i=0;i<5;i++)
citas_medico[i]=NULL;
(*this) = m;
}
Medico &Medico::operator=(const Medico &m){
int i,j;
if (this != &m) { // Para evitar la asignación de un objeto a sí mismo
strcpy(nombre,m.nombre);
strcpy(especialidad,m.especialidad);
num_colegiado=m.num_colegiado;
num_horas_diarias=m.num_horas_diarias;
for (i=0;i<5;i++){
delete citas_medico[i];
citas_medico[i]=new Cita[num_horas_diarias];
for(j=0;j<num_horas_diarias;j++){
citas_medico[i][j] = m.citas_medico[i][j] ;
}
}
}
return *this;
}
medico.h
#pragma once
#include <cstdlib>
#include <iostream>
using namespace std;
#include "cita.h"
class Medico
{
private:
char nombre[50];
char especialidad[50];
int num_colegiado;
int num_horas_diarias;
Cita **citas_medico;
static long total_consultas;
public:
void mostrar_calendario_citas(ostream &o=cout) const;
bool asignar_cita(int d, int hor,Paciente *p=NULL);
void anular_cita(int d, int hor);
bool consultar_cita(char dni[10], int modificar=0);
void modificar_cita(int d, int hor);
void vaciar_calendario_citas();
void borrar_calendario_citas();
char* get_especialidad(char espec[50]) const;
char* get_nombre(char n[50]) const;
int get_num_colegiado() const;
int get_num_horas() const;
void set_num_horas(int horas);
void mostrar_info(ostream &o=cout) const;
static long get_total_consultas();
Cita* operator[](int dia);
void eliminar_calendario_citas();
void crear_calendario_citas();
Medico(char *nom,char * espe,int colegiado,int trabajo);
Medico(const Medico &m);
Medico &operator=(const Medico &c);
void operator delete(void*);
~Medico();
};
ostream& operator<<(ostream &o, Medico &c);
ofstream& operator<<(ofstream &fichero, Medico &m);
ifstream& operator>>(ifstream &fichero, Medico &m);
Ответы
Ответ 1
замечания:
-
#include <cstring>
следует ввести std:: strcpy().
-
using namespace std;
(как написано в medico.h) вводит любые идентификаторы из std::
в глобальное пространство имен.
Помимо того, что using namespace std;
несколько неуклюжие, когда приложение становится больше (поскольку оно вводит один адский идентификатор в глобальное пространство имен), и что вы должны никогда использовать using
в файл заголовка (см. ниже!), using namespace
не влияет на идентификаторы, введенные после инструкции.
(using namespace std
записывается в заголовок, который включен в medico.cpp, но #include <cstring>
приходит после этого.)
Мой совет: Поместите using namespace std;
в medico.cpp, после того, как он будет включен, и используйте явный std::
в medico.h.
strcmpi()
не является стандартной функцией; в то время как определяется в Windows, вы должны решать нечувствительность к регистру по-разному сравнивать Linux.
(В общих терминах я хотел бы указать на этот ответ относительно "правильной" обработки строк в C и С++, что учитывает Unicode, так как каждый приложение должно. Резюме: стандарт не может правильно обрабатывать эти вещи, используйте ICU.)
warning: deprecated conversion from string constant to ‘char*’
"Строковая константа" - это когда вы пишете строковый литерал (например, "Hello"
) в своем коде. Его тип const char[]
, т.е. Массив постоянных символов (поскольку вы не можете изменить символы). Вы можете назначить массив указателю, но присваивание char *
, т.е. Удаление квалификатора const
, генерирует предупреждение, которое вы видите.
Отказ OT: using
в файле заголовка изменяет видимость идентификаторов для всех, включая этот заголовок, который обычно не соответствует пользователю вашего файла заголовка. Например, я мог бы использовать std::string
и самонаписанный ::string
просто отлично в моем коде, если я не включу ваш medico.h, потому что тогда оба класса будут сталкиваться.
Не используйте using
в файлах заголовков.
Ответ 2
Когда вы говорите:
#include <cstring>
компилятор g++ должен помещать объявления <string.h>
, которые он сам включает в std::
И глобальные пространства имен. По какой-то причине он выглядит так, как будто он этого не делает. Попробуйте заменить один экземпляр strcpy
на std::strcpy
и посмотреть, устраняет ли это проблему.
Ответ 3
Эта ошибка иногда возникает в такой ситуации:
#ifndef NAN
#include <stdlib.h>
#define NAN (strtod("NAN",NULL))
#endif
static void init_random(uint32_t initseed=0)
{
if (initseed==0)
{
struct timeval tv;
gettimeofday(&tv, NULL);
seed=(uint32_t) (4223517*getpid()*tv.tv_sec*tv.tv_usec);
}
else
seed=initseed;
#if !defined(CYGWIN) && !defined(__INTERIX)
//seed=42
//SG_SPRINT("initializing random number generator with %d (seed size %d)\n", seed, RNG_SEED_SIZE)
initstate(seed, CMath::rand_state, RNG_SEED_SIZE);
#endif
}
Если во время выполнения не выполняются следующие строки кода:
#ifndef NAN
#include <stdlib.h>
#define NAN (strtod("NAN",NULL))
#endif
вы столкнетесь с ошибкой в своем коде, как будто: потому что initstate помещается в файл stdlib.h, и он не включается:
In file included from ../../shogun/features/SubsetStack.h:14:0,
from ../../shogun/features/Features.h:21,
from ../../shogun/ui/SGInterface.h:7,
from MatlabInterface.h:15,
from matlabInterface.cpp:7:
../../shogun/mathematics/Math.h: In static member function 'static void shogun::CMath::init_random(uint32_t)':
../../shogun/mathematics/Math.h:459:52: error: 'initstate' was not declared in this scope