gpt4 book ai didi

c++ - 错误 : strcpy was not declared in this scope

转载 作者:IT老高 更新时间:2023-10-28 12:56:23 30 4
gpt4 key购买 nike

我在 Ubuntu g++ 版本 4.4.3 中编译的 c++ 问题中遇到了这个问题。我不知道要包含哪些标题来解决这个问题。谢谢

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);

最佳答案

观察:

  • #include <cstring>应该引入 std::strcpy()。
  • using namespace std; (如 medico.h 中所写)引入了来自 std:: 的任何标识符进入全局命名空间。

除了using namespace std;一旦应用程序变大(因为它在全局命名空间中引入了一大堆标识符),就会有点笨拙,你应该永远使用using在头文件中(见下文!),using namespace不影响在声明之后引入的标识符。

(using namespace std 写在 header 中,包含在 medico.cpp 中,但 #include <cstring> 出现在 之后。)

我的建议:using namespace std; (如果您坚持使用它)进入 medico.cpp,在任何包含之后,并使用显式 std::在 medico.h 中。


strcmpi()根本不是标准功能;在 Windows 上定义时,您必须在 Linux 上以不同的方式解决不区分大小写的比较。

(一般来说,我想指出 this answer 关于 C 和 C++ 中“正确”的字符串处理,它考虑了 Unicode,因为每个应用程序都应该考虑到。总结:标准 不能 正确处理这些事情;使用 ICU。)


warning: deprecated conversion from string constant to ‘char*’

“字符串常量”是指您在代码中编写字符串文字(例如 "Hello" )。它的类型是const char[] ,即 constant 字符数组(因为您无法更改字符)。您可以将数组分配给指针,但分配给 char * ,即删除 const限定符,生成您看到的警告。


OT 说明:using在头文件中更改包括该头在内的任何人的标识符的可见性,这通常不是头文件的用户想要的。例如,我可以使用 std::string和一个自写的::string在我的代码中非常完美,除非我包含你的 medico.h,因为这样两个类就会发生冲突。

不要使用 using在头文件中。

即使在实现文件中,它也会引入很多歧义。在实现文件中也可以使用显式命名空间。

关于c++ - 错误 : strcpy was not declared in this scope,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2220795/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com