Cin не является однозначным ошибка c

Программа по вычислениям полностью устраивает, она перемножает 2 матрицы указанного размера с рандомными числами, она запускается и правильно считает, но показывает, что есть ошибки типа: cin, cout, system не являются однозначными, всего 17 ошибок, подчеркивает красным эти операторы, как это убрать?

#include <iostream>
#include <ctime>
#include <iomanip>
using namespace std;
int main()
{
setlocale(LC_ALL, "Russian");
int** P1, ** P2, ** P3, n, m;
cout << "Введите кол-во строк матрицы: ";
cin >> n;
cout << "Введите кол-во столбцов матрицы: ";
cin >> m;
P1 = new int* [n];
for (int i = 0; i < n; i++)
    P1[i] = new int[m];
srand(time(0));
for (int i = 0; i < n; i++)
    for (int j = 0; j < m; j++)  //рандом 1 матрицы
        P1[i][j] = rand() % 10;
for (int i = 0; i < n; i++)
{
    cout << endl;                  //вывод 1 матрицы
    for (int j = 0; j < m; j++)
    {
        cout << setw(3) << P1[i][j] << "t";
    }
}
cout << endl;
int k;
cout << "Введите кол-во столбцов 2 матрицы: ";
cin >> k;
P2 = new int* [k];
for (int i = 0; i < m; i++)
    P2[i] = new int[k];
for (int i = 0; i < m; i++)
    for (int j = 0; j < k; j++)  //рандом 2 матрицы
        P2[i][j] = rand() % 10;
for (int i = 0; i < m; i++)
{
    cout << endl;                  //вывод 2 матрицы
    for (int j = 0; j < k; j++)
    {
        cout << setw(3) << P2[i][j] << "t";
    }
}
cout << endl;
P3 = new int* [n];
for (int i = 0; i < n; i++)
    P3[i] = new int[k];
for (int i = 0; i < n; i++)
{
    for (int j = 0; j < k; j++)  //умножение матриц
    {
        P3[i][j] = 0;
        for (int z = 0; z < m; z++)
            P3[i][j] = P3[i][j] + P1[i][z] * P2[z][j];
    }
}
cout << endl << "Результат умножения:" << endl;
for (int i = 0; i < n; i++)                     //вывод результата 
 умножения
{
    cout << endl;
    for (int j = 0; j < k; j++)
        cout << setw(3) << P3[i][j] << "t";
}
cout << endl;
for (int i = 0; i < n; i++)
    delete[] P1[i];
delete[] P1;
for (int i = 0; i < m; i++)
    delete[] P2[i];
delete[] P2;
for (int i = 0; i < n; i++)
    delete[] P3 [i];
delete[] P3;
system("pause");
return 0;
}

Содержание

  1. Cin не является однозначным
  2. Решение
  3. Объект класса string не является однозначным
  4. Решение
  5. Ошибка «переменная не является однозначной»
  6. Как исправить ошибку «cout не является однозначным»?
  7. Поточный ввод-вывод в C++
  8. Ввод информации
  9. Манипуляторы потока

Позвольте мне предвосхитить это, сказав, что я включил (также относится к string, endl, и буквально все не работает); моя IDE не показывает ошибок, насколько синтаксис идет; и я не могу понять, почему эта проблема происходит? Он отлично работает в одном из моих других примеров кода C ++, которые я написал.

Поэтому я пытаюсь сделать небольшую игру, быков и коров. Мой основной код выглядит следующим образом:

Наконец, мой файл BullsAndCows.cpp:

Ошибки, которые я получаю, так как «cout не является членом std», символ cout не может использоваться в объявлении использования. До этого я использовал «использование пространства имен std», и это возвращало бы ошибки, такие как «BullsAndCows» не является пространством имен или классом (если это не класс, то я должен быть марсианином). Также кое-что о пропавшем «;» перед userInput, например, в моем коде main.cpp; что не имеет смысла, так как нет ничего, что не хватает этого. Я использую VS2017. Почему C ++ такой раздражающий язык для работы?

Решение

прежде чем любые другие включают директивы.

Автор Јляп Шляпович задал вопрос в разделе Другие языки и технологии

Помогите пожалуйста исправить ошибку в коде программы (C++). Был бы благодарен. и получил лучший ответ

Ответ от Valrand()[гуру]
Причина: здесь, возможно, компилятором делается попытка интерпретировать «cout

Двоичное дерево поиска
Задание. Построение и обработка двоичных деревьев поиска. Реализовать программу, выполняющую следующий набор операций с деревьями поиска:

поиск вершины с заданным значением ключа с выводом счетчика числа появлений данного ключа
добавление новой вершины в соответствии со значением ее ключа или увеличение счетчика числа появлений
построчный вывод дерева в наглядном виде с помощью обратно-симметричного обхода
вывод всех вершин в одну строку по порядку следования ключей с указанием для каждой вершины значения ее счетчика появлений
удаление вершины с заданным значением ключа

Выдает (в VS 2012) следующие ошибки:

Т. Е. он утв-ет что count не является однозначным и не определен

Источник

Объект класса string не является однозначным

Вот ошибка:
Ошибка 1 error C2872: left: неоднозначный символ c:usersмdesktopdocumentsvisual studio 2013projectsмлитамлитаметод вонга.cpp 33 1 МЛиТА

и таких около 100 штук где используется два объекта left and right. Вчера успешно закрыл программу после тестирования пару примеров. Сегодня открыл вот эта жуть.

как узнать,является данный объект класса А1 наследником класса А2
Всем привет)есть классы S, A1, A2, B1, B2. Иерархия наследования следующая S — Является.

Является ли однозначным небаном то,
Вообщем вопрос такого плана — при добавлении сайта в http://webmaster.yandex.ru/add.xml — выдается.

Является ли отображение взаимно-однозначным.
помогите пожалуйста.. не могу решить. является ли отображение множеств натуральных чисел в.

Является ли натуральное число а однозначным.
Определить, является ли натуральное число а однозначным. Заранее спасибо!

_Valera_, я все подробно выложил, или мне код закинуть?

Добавлено через 8 минут

Решение

в том что кто-то не читает ссылки, которые ему дают.

_Valera_, код ведь понятен, логических ошибок нет, в нем. Можешь проверить функцию где я пробелы убираю, вроде и там все правильно. Он останавливается компилить на 13шаге, я помню точно он компилил его раз 10 вчера

Добавлено через 1 минуту
_Valera_, я не понимаю тебя, до сих пор так подключал пространство и ничего подобного не выводил

Добавлено через 2 минуты
_Valera_, ну я понял твои статьи у меня ведь ничего такого нет, я всегда так и работал!

Добавлено через 3 минуты
_Valera_, и все же я не вижу зависимость между названиями

Источник

Ошибка «переменная не является однозначной»

Глобальная или статическая переменная не может иметь тип управляемый «System::String ^»
Привет, такая проблема, необходимо создать объект типа String в программе вот часть кода.

Синтаксическая ошибка: отсутствие «;» перед «)»
не пойму. где тут ошибка. private: System::Void button2_Click(System::Object^ sender.

Ошибка при запуске приложения под Windows XP: «Не является приложением Win32»
Здравствуйте, написал приложение на Visual Studio Express 2013. У меня ОС Windows 7 x64. Работает.

После запуска среды выскакивает окошечко с ошибкой «Unknown error» или «Неизвестная ошибка»
Доброго времени суток. Возникла проблема. После запуска среды выскакивает окошечко с ошибкой.

В общем-то тоже верно))

В общем, проблему с ошибкой компилятора решил. Для тех, кого интересуют подробности:
В строке public ref class MessageFilter : public IMessageFilter нужно было IMessageFilter записать так: System::Windows::Forms::IMessageFilter
Теперь все собирается и запускается, однако (встал новый вопрос) перехват системных сообщений почему-то не происходит((
Причем не ловит именно сообщение WM_DEVICECHANGE (находится в Dbt.h). Сам алгоритм работает верно, проверил на сообщениях нажатия кнопок мыши (по нажатию проверяемых кнопок, мэсседжбоксы выскакивали стабильно).
У кого-нибудь есть мысли, почему обработчик может не видеть и не обрабатывать сообщения из подключенного файла Dbt.h (в частности хотя бы WM_DEVICECHANGE)??

Кто может помочь с данной проблемой? Может кто сталкивался с подобной обработкой сообщений именно под C++ .NET Windows Forms .

Источник

Как исправить ошибку «cout не является однозначным»?

А так же выдает ошибку ‘эта переменная не содержит класс хранения или спецификатор типа’
В чем проблема?(
Подскажите пожаалулйстааа))))

#include
#include
using namespace std;

country();
country(char* aname , double at_winter, double at_spring,double at_summer,double at_autumn);
country(const country& CONTRY);

char* name;
double t_winter, t_spring, t_summer, t_autumn;

class NewCountry : public country <
public:

NewCountry();
NewCountry(char* aname, double at_winter, double at_spring, double at_summer, double at_autumn, int apolusharie);
NewCountry(const NewCountry& COUNTRY);

unsigned short int gpolusharie() < return polusharie; >;
string sReturnpolusharie();

private:
unsigned short int polusharie;
>;

country::country()
<
name = NULL;
t_winter = NULL;
t_spring = NULL;
t_summer = NULL;
t_autumn = NULL;
>;

country::country(char* aname, double at_winter, double at_spring, double at_summer, double at_autumn) :
name(new char[strlen(aname) + 1])
<
strcpy_s(name, strlen(aname) + 1, aname);
t_winter = at_winter;
t_spring = at_spring;
t_summer = at_summer;
t_autumn = at_autumn;
>;

ostream& operator >(istream& In, country& COUNTRY)
<
char TEMP[123];
In >> TEMP >> COUNTRY.t_winter >> COUNTRY.t_spring >> COUNTRY.t_summer >> COUNTRY.t_autumn;
delete[] COUNTRY.name;
COUNTRY.name = new char[strlen(TEMP) + 1];
strcpy_s(COUNTRY.name, strlen(TEMP) + 1, TEMP);
return In;
>;

country& country::operator=(const country& COUNTRY) <
if (this == &COUNTRY) return *this;
delete[] name;
name = new char[strlen(COUNTRY.name) + 1];
strcpy_s(name, strlen(COUNTRY.name) + 1, COUNTRY.name);
name = COUNTRY.name;
t_winter = COUNTRY.t_winter;
t_spring = COUNTRY.t_spring;
t_summer = COUNTRY.t_summer;
t_autumn = COUNTRY.t_autumn;
return *this;
>;

NewCountry::NewCountry() :
country()
<
polusharie = NULL;
>;

NewCountry::NewCountry(char* aname, double at_winter, double at_spring, double at_summer, double at_autumn, int apolusharie) :
country(aname,at_winter, at_spring, at_summer, at_autumn)
<
polusharie = apolusharie;
>;

string NewCountry::sReturnpolusharie() <
if (polusharie == 1) return «северное»;
if (polusharie == 2) return «южное»;
if (polusharie == 3) return «по обе стороны экватора»;
return «. ОШИБКА:данные отсутствуют. «;
>;

ostream& operator >(istream& In, NewCountry& COUNTRY)
<
char TEMP[123];
In >> TEMP >> COUNTRY.t_winter >> COUNTRY.t_spring >> COUNTRY.t_summer >> COUNTRY.t_autumn >> COUNTRY.polusharie;
delete[] COUNTRY.name;
COUNTRY.name = new char[strlen(TEMP) + 1];
strcpy_s(COUNTRY.name, strlen(TEMP) + 1, TEMP);
return In;
>;

NewCountry& NewCountry::operator=(const NewCountry& COUNTRY) <
if (this == &COUNTRY) return *this;
delete[] name;
name = new char[strlen(COUNTRY.name) + 1];
strcpy_s(name, strlen(COUNTRY.name) + 1, COUNTRY.name);
t_winter = COUNTRY.t_winter;
t_spring = COUNTRY.t_spring;
t_summer = COUNTRY.t_summer;
t_autumn = COUNTRY.t_autumn;
polusharie = COUNTRY.polusharie;
return *this;
>;

void main() <
setlocale(LC_ALL, «Russian»);
SetConsoleCP(1251);
SetConsoleOutputCP(1251);
int N;
double winter = lol[0].ReturnT_Winter;
double summer = lol[0].ReturnT_Summer;
NewCountry* lol;
cout > N;
lol = new NewCountry[N];
cout > lol[i];
for ( int i = 0; i lol[i].ReturnT_Summer ())
summer = lol[i].ReturnT_Summer();
>
>;
cout Вопрос задан более двух лет назад

  • 2516 просмотров
  • Источник

    Поточный ввод-вывод в C++

    Поточный ввод-вывод в C++ выполняется с помощью функций сторонних библиотек. В С++, как и в С, нет встроенных в язык средств ввода-вывода.

    В С для этих целей используется библиотека stdio.h .
    В С++ разработана новая библиотека ввода-вывода iostream , использующая концепцию объектно-ориентированного программирования:

    Библиотека iostream определяет три стандартных потока:

    • cin стандартный входной поток ( stdin в С)
    • cout стандартный выходной поток ( stdout в С)
    • cerr стандартный поток вывода сообщений об ошибках ( stderr в С)

    Для их использования в Microsoft Visual Studio необходимо прописать строку:

    Для выполнения операций ввода-вывода переопределены две операции поразрядного сдвига:

    • >> получить из входного потока
    • cout

    Возможно многократное назначение потоков:
    cout

    Ввод информации

    При этом из входного потока читается последовательность символов до пробела, затем эта последовательность преобразуется к типу идентификатора, и получаемое значение помещается в идентификатор:

    Возможно многократное назначение потоков:
    cin >> переменная1 >> переменная2 >>. >> переменнаяn;

    При наборе данных на клавиатуре значения для такого оператора должны быть разделены символами (пробел, n, t ).

    Особого внимания заслуживает ввод символьных строк. По умолчанию потоковый ввод cin вводит строку до пробела, символа табуляции или перевода строки.

    Результат выполнения

    Для ввода текста до символа перевода строки используется манипулятор потока getline() :

    Результат выполнения

    Манипуляторы потока

    Функцию — манипулятор потока можно включать в операции помещения в поток и извлечения из потока ( >).

    В С++ имеется ряд манипуляторов. Рассмотрим основные:

    Манипулятор Описание
    endl Помещение в выходной поток символа конца строки ‘n’
    dec Установка основания 10-ой системы счисления
    oct Установка основания 8-ой системы счисления
    hex Установка основания 16-ой системы счисления
    setbase Вывод базовой системы счисления
    width(ширина) Устанавливает ширину поля вывода
    fill(‘символ’) Заполняет пустые знакоместа значением символа
    precision(точность) Устанавливает количество значащих цифр в числе (или после запятой) в зависимости от использования fixed
    fixed Показывает, что установленная точность относится к количеству знаков после запятой
    showpos Показывает знак + для положительных чисел
    scientific Выводит число в экспоненциальной форме
    get() Ожидает ввода символа
    getline(указатель, количество) Ожидает ввода строки символов. Максимальное количество символов ограничено полем количество

    Пример Программа ввода-вывода значения переменной в C++

    Та же программа, написанная на языке Си

    Пример Использование форматированного вывода

    Результат выполнения

    Еще один пример использования форматированного вывода: для t∈[0;3] с шагом 0,5 вычислить значение y=cos(t).

    Результат выполнения

    Источник

    Неоднозначный Синтаксис

    Почему последние две строки в основной функции перед закрывающей скобкой дают ошибку? Почему выражение MYINT() трактуется по-разному в разных контекстах? Любая стандартная ссылка будет полезна.

    5 Ответов

    MYINT() может, в зависимости от контекста, интерпретироваться как выражение типа MYINT или спецификатор типа функции, не принимающий аргументов и возвращающий MYINT . В некоторых ситуациях, когда допустимо выражение или спецификатор типа, это дает неоднозначность; это разрешается путем интерпретации его как спецификатора типа, если это возможно ( EDIT: C++03 8.2/2, если требуется стандартная ссылка).

    sizeof может принимать либо выражение, либо заключенный в скобки спецификатор типа, как это аргумент, давая эту двусмысленность. Таким образом, здесь MYINT() интерпретируется как спецификатор типа; затем вы получаете ошибку, так как sizeof не может быть применен к типу функции.

    EDIT: вы можете исправить ошибку, удалив скобки, чтобы она интерпретировалась как выражение ( sizeof MYINT() ), добавив дополнительные скобки, чтобы она не была допустимым спецификатором типа ( sizeof((MYINT())) ), или изменив ее на правильный тип ( sizeof(MYINT) ).

    cout является однозначным, поэтому ошибки быть не должно, и действительно нет на моем компиляторе. Что такое ошибка, и что такое ваш компилятор?

    Если ваш MINTINT — это typedef int MYINT , то MYINT() -это не функция, а int() , которая является инициализацией по умолчанию, равнозначной int y = 0 или int y = int(0) .

    Ваша вторая строка, т. е. cout компилируется правильно для меня с g++ -Wall -ansi -pedantic по той же причине.

    Но g++ будет жаловаться на sizeof со следующей ошибкой error: invalid application of «sizeof» to a function type , потому что он интерпретирует MYINT() как «a call to a default constructor for int» ( EDIT : это неверно) «a function type returning MYINT which is not allowed» ( EDIT : это правильный ответ, см. Майка). Но это не имеет ничего общего с typedef .

    Редактировать (снова)

    Как сказано в комментарии, строки cout не работают для вас, это потому, что вы, вероятно, забыли include .

    Edit Посмотрите также ответ Майка Сеймура для объяснения двусмысленности с sizeof .

    Почему последние две строки в основной функции перед закрывающей скобкой дают ошибку?

    cout не работает, потому что cout не определен. Как только вы сделаете #include и using std::cout , он будет работать нормально.

    sizeof(MYINT()) действительно не работает, но sizeof(int()) тоже не работает, так что этого следует ожидать. sizeof(MYINT) будет работать просто отлично.

    Почему выражение MYINT() трактуется по-разному в разных контекстах?

    Это не. В каждом случае MYINT() ведет себя точно так же, как int() .

    Я не вижу никакой ошибки для строки cout . Однако я вижу invalid application of ‘sizeof’ to a function type для строки cout . Проблема заключается в () вокруг MYINT() . Стандарт C++ говорит Это О sizeof и о том, как он анализируется:

    Существует неоднозначность синтаксического анализа между sizeof unary-expression и sizeof ( type-id ) . Он решается с помощью более длинного матча. Он анализирует sizeof (MYINT()) как sizeof ( type-id ) , MYINT() -это тип функции, и таким образом вы видите ошибку.

    Похожие вопросы:

    Как исправить эту ошибку? ошибка C2668: ‘std::_Tree :: end’: неоднозначный вызов перегруженной функции Мой код выглядит так: typedef map my_map_t; my_map_t.

    Я создаю новый проект, и я добавляю существующую ссылку на проект и вызываю один класс из существующего. Я получаю ниже ошибку — — — Ошибка c2872: неоднозначный символ

    Я читаю следующий документ о функциональных зависимостях. На странице 5 он описывает неоднозначный тип: Во-первых, пустая функция имеет неоднозначный тип: empty :: Collects e ce ⇒ ce. Под.

    Предположим, у меня есть такой запрос select id, company_id, name, type, number from people as p inner join company c on c.id = p.company_id limit 10 и здесь обе таблицы имеют столбец name, и name.

    У меня есть внутреннее соединение двух таблиц и дисплей. Я попробовал приведенный ниже код. Но он генерирует на ошибке неоднозначный столбец site_name’ SELECT site_name, Mains_Run_Hrs.

    Неоднозначный grammar определяется как, Неоднозначный grammar-это контекстно-свободный grammar, для которого существует строка, которая может иметь более одного крайнего левого вывода или дерева.

    Скажи, что у меня есть: @Given(first name is $firstName) @Given(first name is $firstName and last name is $lastName) Следующий шаг будет помечен как неоднозначный: Given first name is John and last.

    Я предоставлю этих двух конструкторов. BigUnsigned(int value) :BigUnsigned(static_cast (value)) < >BigUnsigned(unsigned long long value); Проблема в том, что вызов.

    То, что я часто вижу в интернете, когда тема переворачивается, — это такой синтаксис *(_WORD *)(a1 + 6) = *(_WORD *)(a2 + 2); Я думаю, что этот код от плагина IDA (верно?), но я не могу этого понять.

    NOTICE: этот вопрос не о Java do not have pointers В языке C код identifier1 * identifier2 неоднозначен для двух возможных значений: Если identifier1 является типом, то это может быть объявление.

    C++ для людей

    std::cout

    Часто встречающиеся ошибки стадии компиляции

    Очень часто начинающие программисты впадают в суеверный ужас, когда видят, что компилятор нашел в тексте программы ошибку, но не понимают, в чем она заключается.

    А если помножить этот факт на незнание английского языка («чего там ему не нравится. ») и слабое владение синтаксисом C++ («хм, а может, тут нужна точка с запятой…»), то проблема принимает масштаб катастрофы.

    Тот факт, что компилятор в силу своих ограниченных возможностей изо всех сил старается объяснить, что конкретно неверно, не спасает ситуацию. Как быть, если гуглить неохота, а спросить не у кого?

    В этом посте на правах копипаста с последующим переводом, дополнениями и исправлениями приведу описание наиболее распространенных сообщений об ошибках и предупреждений компилятора. Неприятность кроется в том факте, что разные компиляторы ругаются на одинаковые ошибки по-разному, а некоторые даже не замечают то, что другие принимают за ошибку. Все зависит от совести разработчиков компилятора, даты его выпуска, и др.

    В качестве компилятора возьмем g++, который, в частности, может использоваться в среде Code::Blocks. Версия gcc (куда входит g++) для ОС Windows зовется MinGW. По ходу я буду давать аналоги ошибок из лексикона русскоязычной Microsoft Visual C++.

    Итак, частые ошибки:

    undeclared identifier

    doy.cpp: In function ‘int main()’:
    doy.cpp:25: ‘DayOfYear’ undeclared (first use this function)
    doy.cpp:25: (Each undeclared identifier is reported only once for each function it appears in.)
    doy.cpp:25: parse error before ‘;’ token

    2) Смысл
    Использован идентификатор DayOfYear , но компилятор не нашел его объявления. Он не знает, что такое DayOfYear .

    • Вы забыли включить какой-то заголовочный файл ( #include. )
    • Вы где-то ошиблись в написании идентификатора (при объявлении или использовании)
    • Вы вообще забыли, что эту переменную надо объявить

    Попытавшись скомпилировать это в Microsoft Visual C++, вы увидите:

    error C2065: DayOfYear: необъявленный идентификатор

    cout undeclared

    xyz.cpp: In function ‘int main()’:
    xyz.cpp:6: ‘cout’ undeclared (first use this function)
    xyz.cpp:6: (Each undeclared identifier is reported only once for each function it appears in.)

    2) Смысл
    Суперклассика. Без комментариев.

    • Вы забыли включить
    • Вы забыли написать using namespace std;

    jump to case label

    switch.cpp: In function ‘int main()’:
    switch.cpp:14: jump to case label
    switch.cpp:11: crosses initialization of ‘int y’

    2) Смысл
    Смысл туманен

    3) Когда бывает
    Вы попытались объявить и инициализировать переменную (объект, указатель и т.п.) в метке case оператора выбора switch. Правилами C++ это запрещено.

    В Microsoft Visual C++ эта ошибка зовется

    error C2360: пропуск инициализации ‘y’ из-за метки ‘case’

    Выход: заключите операторы этого case’а в фигурные скобки <>.

    multi-line string / unterminated string

    using namespace std;

    вызовет бурную реакцию компилятора:

    string.cpp:7:12: warning: multi-line string literals are deprecated
    string.cpp: In function ‘int main()’:
    string.cpp:7: ‘so’ undeclared (first use this function)
    string.cpp:7: (Each undeclared identifier is reported only once for each function it appears in.)
    string.cpp:7: parse error before ‘Mary’
    string.cpp:8:28: warning: multi-line string literals are deprecated
    string.cpp:8:28: missing terminating » character
    string.cpp:7:12: possible start of unterminated string literal

    2) Смысл
    Компилятор думает, что мы хотим создать строковую константу с содержащимся в ней переносом строки, что-то типа

    что не поддерживается языком. Также делается предположение о том, что мы, возможно, забыли поставить кавычки в конце первой строки. Собственно, так оно и есть.

    3) Когда бывает
    Когда не соблюдается правильное количество и положение кавычек в строковых литералах. Надо быть внимательнее.

    Microsoft Visual C++ со свойственной ему детской непосредственностью, отметит, что нельзя делать переносы в строках и возмутится, где точка с запятой:

    error C2001: newline в константе
    error C2146: синтаксическая ошибка: отсутствие «;» перед идентификатором «cout»

    comparison between signed and unsigned integer expressions

    xyz.cpp: In function ‘int main()’:
    xyz.cpp:54: warning: comparison between signed and unsigned integer expressions

    2) Смысл
    Это — предупреждение компилятора, которое говорит о том, что мы пытаемся сравнить (==, и т.д.) целочисленное выражение (может принимать положительные, отрицательные значения и 0) и беззнаковое целочисленное выражение (может быть только положительным, либо 0).

    3) Когда бывает
    Собственно, тогда и бывает. Напомню, что тип int по умолчанию знаковый, а некоторые функции (например, vector::size() ) возвращают unsigned int .
    К примеру, следующий на первый взгляд безобидный код вызовет описываемое предупреждение:

    Следует помнить, что в памяти знаковые и беззнаковые типы имеют разные внутренние представления, поэтому надо быть чертовски осторожными с указателями.

    В Microsoft Visual C++ предупреждение выглядит так:

    suggest parentheses around assignment used as truth value

    xyz.cpp: In function `int main()’:
    xyz.cpp:54: warning: suggest parentheses around assignment used as truth value

    2) Смысл
    Тоже классика. Компилятор предполагает (и в 99% случаев прав), что вы по ошибке включили в скобки в качестве условия для if/while/for вместо условного выражения выражение присваивания.

    3) Когда бывает
    Чаще всего — в if ‘ах, когда вместо «==» используется «=»

    if (length = maxLength)

    if (length == maxLength)

    Заминка в том, что это не ошибка, т.к. в скомпилированной программе (если мы проигнорируем предупреждение) выражение присваивания (которое возвращает значение правого аргумента) во всех случаях, кроме тех, когда оно вернет 0 , будет преобразовано к true .

    Обзор средств ввода-вывода в C++

    Приложение, написанное на любом языке программирования, должно взаимодействовать с окружающим миром. Иначе пользы от него не будет. Как правило, такое взаимодействие осуществляется посредством ввода-вывода информации на монитор или в файл. Правда, есть некоторое множество программ, которые не используют файловый или консольный ввод-вывод: это программы, осуществляющие низкоуровневое взаимодействие с аппаратной частью компьютера и периферией (ядро ОС, драйверы и пр.), но это уже экзотика.

    В стандартном C++ существует два основных пути ввода-вывода информации: с помощью потоков, реализованных в STL (Standard Template Library) и посредством традиционной системы ввода-вывода, унаследованной от C. Если копнуть немного глубже, то окажется, что и потоки, и традиционная система ввода-вывода для осуществления необходимых действий используют вызовы операционной системы. И это правильно.

    Дальнейшее изложение не претендует на полноту, но описывает основные принципы использования библиотек. Подробности использования можно посмотреть в многочисленной литературе по C++ и STL, в MSDN и пр.

    Традиционный ввод-вывод

    Для использования традиционного ввода-вывода в духе C, в программу необходимо включить заголовочный файл . (Разумеется, компилятор должен иметь доступ к соответствующей объектной библиотеке для правильной сборки исполняемого файла.)

    Библиотека stdio предоставляет необходимый набор функций для ввода и вывода информации как в текстовом, так и в двоичном представлении. Следует отметить, что в отличие от классической C‑библиотеки, в современных библиотеках имеются более безопасные аналоги «классических» функций. Как правило, они имеют такое же имя, к которому добавлен суффикс _s. Рекомендуется использовать именно эти, безопасные функции.

    Самая Первая Программа с использованием библиотеки stdio выглядит так:

    При запуске консольного приложения неявно открываются три потока: stdin — для ввода с клавиатуры, stdout — для буферизованного вывода на монитор и stderr — для небуферизованного вывода на монитор сообщений об ошибках. Эти три символа определены посредством .

    В stdio для консольного ввода-вывода предусмотрена отдельная группа функций. Однако эти функции, как правило, являются обёртками для аналогичных функций файлового ввода-вывода, для которых аргумент типа FILE задан по умолчанию.

    Самая Первая Программа с использование файлового вывода из библиотеки stdio выглядит так:

    Некоторые популярные функции из stdio:

    Сущность FILE представляет собой структуру, в которой хранится вся информация для управления потоком ввода-вывода.

    Файл открывается функцией fopen(), которой передаются два параметра. Первый параметр определяет имя файла. Второй — определяет режим открытия файла: чтение, запись, произвольный доступ и т.п., а также указание на то, как работать с данными: в текстовом или двоичном режиме. Подробности — см. в документации.

    Пример использования stdio

    Следует отметить, что существует еще одна библиотека, ориентированная исключительно на консольный ввод-вывод — .

    Ввод-вывод с помощью потоков STL

    Для использования объектно-ориентированного консольного ввода-вывода с помощью потоков (stream) STL в программу необходимо включить заголовочный файл , а для файлового ещё и . (Разумеется, компилятор должен иметь доступ к соответствующей объектной библиотеке для правильной сборки исполняемого файла.)

    Самая Первая Программа с использованием потоков STL выглядит так:

    При запуске консольного приложения неявно открываются четыре потока: сin — для ввода с клавиатуры, сout — для буферизованного вывода на монитор, сerr — для небуферизованного вывода на монитор сообщений об ошибках и clog — буферизованный аналог cerr. Эти четыре символа определены посредством .

    Потоки cin, cout и cerr соответствуют потокам stdin, stdout и stderr соответственно.

    Иерархия классов ввода-вывода STL достаточно сложна. Любители тонких ощущений могут найти её описание в литературе. Впрочем, остальных также не минует чаша сия, но только позже, когда потребуются знания чуть повыше того базового уровня, который описывается здесь.

    Для ввода-вывода сначала необходимо создать поток — экземпляр соответствующего класса STL, а затем связать его с файлом. Для потока вывода используется класс ofstream, для потока ввода — ifstream, для потока ввода-вывода — fstream. В каждом из этих классов есть метод open(), который связывает поток с файлом. Проще говоря, открывает файл. Методу передаются два параметра: имя файла и режим открытия файла. Второй параметр представляет собой набор битовых флагов, определяющих режим открытия файла (чтение, запись и пр.) и способ работы с данными (текстовый или двоичный режим). Второй параметр опционален, т.е. имеет значение по умолчанию, соответствующее классу.

    Вышеупомянутые классы имеют также конструкторы, позволяющие открыть файл сразу при создании потока. Параметры этих конструкторов полностью совпадают с параметрами метода open().

    При ошибке открытия файла (в контексте логического выражения) поток получает значение false.

    Файл закрывается методом close(). Этот метод также вызывается при разрушении экземпляров классов потоков.

    Операции чтения и записи в поток, связанный с файлом, осуществляются либо с помощью операторов >, перегруженных для классов потоков ввода-вывода, либо с помощью любых других методов классов потоков ввода-вывода.

    Некоторые наиболее употребляемые методы:

    Пример использования потоков STL

    Взаимодействие потокового и традиционного ввода-вывода

    Апологеты C++ рекомендуют использовать для ввода-вывода только потоки STL и отказаться от использования традиционного ввода-вывода в духе C. Однако, ничто не мешает, по крайней мере пока, использовать традиционную систему ввода-вывода. Более того, предусмотрена специальная функция для синхронизации ввода-вывода, выполненного посредством потоков и посредством старых функций.

    Заключение

    Какой механизм использовать — вопрос предпочтений программиста, если работодателем явно не предписано использование конкретного механизма. В любом случае для физического ввода-вывода используются вызовы операционной системы. Всё остальное — обёртка, набор более или менее удобных функций или классов для взаимодействия с ОС.

    Использование механизма потоков считается более безопасным. Но, как известно, плохую программу можно написать на любом языке программирования. Это также относится и к использованию библиотек. Автор статьи: Череп.

    C++ — Урок 011. Исключения

    Что такое исключение? Это ситуация, которая не предусмотрена стандартным поведением программы. Например, попытка доступа к элементу в классе Vector (который мы разбирали в статье про классы ), который не существует. То есть происходит выход за пределы вектора. В данном случае можно воспользоваться исключениями, чтобы прервать выполнение программы. Это необходимо потому, что

    • Как правило в таких случаях, автор класса Vector не знает, как пользователь захочет использовать его класс, а также не знает в какой программе этот класс будет использоваться.
    • Пользователь класса Vector не может всегда контролировать правильность работы этого класса, поэтому ему нужно сообщить о том, что что-то пошло не так.

    Для разрешения таких ситуация в C++ можно использовать технику исключений.

    Рассмотрим, как написать вызов исключения в случае попытки доступа к элементу по индексу, который не существует в классе Vector.

    Здесь применяется исключение out_of_range. Данное исключение определено в заголовочном файле .

    Оператор throw передаёт контроль обработчику для исключений типа out_of_range в некоторой функции, которая прямо или косвенно вызывает Vector::operator[]() . Для того, чтобы обработать исключения необходимо воспользоваться блоком операторов try catch.

    Инварианты

    Также блоки try catch позволяют производить обработку нескольких различных исключений, что вносит инвариантность в работу механизма исключений C++.

    Например, класс вектор при создании может получить неправильный размер вектора или не найти свободную память для элементов, которые он будет содержать.

    Данный конструктор может выбросить исключение в двух случаях:

    • Если в качестве аргумента size будет передано отрицательное значение
    • Если оператор new не сможет выделить память

    length_error — это стандартный оператор исключений, поскольку библиотека std часто использует данные исключения при своей работе.

    Обработка исключений будет выглядеть следующим образом:

    Также можно выделить свои собственные исключения.

    Виды исключений

    Все исключения стандартной библиотеки наследуются от std::exception.

    На данный момент существуют следующие виды исключений:

    • logic_error
      • invalid_argument
      • domain_error
      • length_error
      • out_of_range
      • future_error (C++11)
    • runtime_error
      • range_error
      • overflow_error
      • underflow_error
      • system_error (C++11)
        • ios_base::failure (начиная с C++11)
    • bad_typeid
    • bad_cast
    • bad_weak_ptr (C++11)
    • bad_function_call (C++11)
    • bad_alloc
      • bad_array_new_length (C++11)
    • bad_exception
    • ios_base::failure (до C++11)

    std::logic_error

    Исключение определено в заголовочном файле

    Определяет тип объекта, который будет брошен как исключение. Он сообщает об ошибках, которые являются следствием неправильной логики в рамках программы, такие как нарушение логической предпосылки или класс инвариантов, которые возможно предотвратить.

    Этот класс используется как основа для ошибок, которые могут быть определены только во время выполнения программы.

    std::invalid_argument

    Исключение определено в заголовочном файле

    Наследован от std::logic_error. Определяет исключение, которое должно быть брошено в случае неправильного аргумента.

    Например, на MSDN приведён пример, когда в объект класса bitset из стандартной библиотеки

    В данном примере передаётся неправильная строка, внутри которой имеется символ ‘b’, который будет ошибочным.

    std::domain_error

    Исключение определено в заголовочном файле

    Наследован от std::logic_error. Определяет исключение, которое должно быть брошено в случае если математическая функция не определена для того аргумента, который ей передаётся, например:

    std::length_error

    Исключение определено в заголовочном файле

    Наследован от std::logic_error. Определяет исключение, которое должно быть броше в том случае, когда осуществляется попытка реализации превышения допустим пределов для объекта. Как это было показано для размера вектора в начале статьи.

    std::out_of_range

    Исключение определено в заголовочном файле

    Наследован от std::logic_error. Определяет исключение, которое должно быть брошено в том случае, когда происходит выход за пределы допустимого диапазона значений объекта. Как это было показано для диапазона значений ветора в начале статьи.

    std::future_error

    Исключение определено в заголовочном файле

    Наследован от std::logic_error. Данное исключение может быть выброшено в том случае, если не удалось выполнить функцию, которая работает в асинхронном режиме и зависит от библиотеки потоков. Это исключение несет код ошибки совместимый с std::error_code .

    std::runtime_error

    Исключение определено в заголовочном файле

    Является базовым исключением для исключений, которые не могут быть легко предсказаны и должны быть брошены во время выполнения программы.

    std::range_error

    Исключение определено в заголовочном файле

    Исключение используется при ошибках при вычислении значений с плавающей запятой, когда компьютер не может обработать значение, поскольку оно является либо слишком большим, либо слишком маленьким. Если значение является значение интегрального типа, то должны использоваться исключения underflow_error или overflow_error .

    std::overflow_error

    Исключение определено в заголовочном файле

    Исключение используется при ошибках при вычислении значений с плавающей запятой интегрального типа, когда число имеет слишком большое положительное значение, положительную бесконечность, при которой происходит потеря точности, т.е. результат настолько большой, что не может быть представлен числом в формате IEEE754.

    std::underflow_error

    Исключение определено в заголовочном файле

    Исключение используется при ошибках при вычислении значений с плавающей запятой интегрального типа, при которой происходит потеря точности, т.е. результат настолько мал, что не может быть представлен числом в формате IEEE754.

    std::system_error

    Исключение определено в заголовочном файле

    std::system_error — это тип исключения, которое вызывается различными функциями стандартной библиотеки (как правило, функции, которые взаимодействуют с операционной системой, например, конструктор std::thread ), при этом исключение имеет соответствующий std::error_code .

    std::ios_base::failure

    Исключение определено в заголовочном файле

    Отвечает за исключения, которые выбрасываются при ошибках функций ввода вывода.

    std::bad_typeid

    Исключение определено в заголовочном файле

    Исключение этого типа возникает, когда оператор typeid применяется к нулевому указателю полиморфного типа.

    std::bad_cast

    Исключение определено в заголовочном файле

    Данное исключение возникает в том случае, когда производится попытка каста объекта в тот тип объекта, который не входит с ним отношения наследования.

    std::bad_weak_ptr

    Исключение определено в заголовочном файле

    std::bad_weak_ptr – тип объекта, генерируемый в качестве исключения конструкторами std::shared_ptr , которые принимают std::weak_ptr в качестве аргумента, когда std::weak_ptr ссылается на уже удаленный объект.

    std::bad_function_call

    Исключение определено в заголовочном файле

    Данное исключение генерируется в том случае, если был вызван метод std::function::operator() объекта std::function , который не получил объекта функции, то есть ему был передан в качестве инициализатора nullptr, например, а объект функции так и не был передан.

    std::bad_alloc

    Исключение определено в заголовочном файле

    Вызывается в том случае, когда не удаётся выделить память.

    std::bad_array_new_length

    Исключение определено в заголовочном файле

    Исключение вызывается в следующих случаях:

    1. Массив имеет отрицательный размер
    2. Общий размер нового массива превысил максимальное значение, определяемое реализацией
    3. Количество элементов инициализации превышает предлагаемое количество инициализирующих элементов

    std::bad_exception

    Исключение определено в заголовочном файле

    std::bad_exception — это тип исключения в C++, которое выполняется в следующих ситуациях:

    1. Если нарушается динамическая спецификация исключений
    2. Если std::exception_ptr хранит копию пойманного исключения, и если конструктор копирования объекта исключения поймал current_exception, тогда генерируется исключение захваченных исключений.

    Рекомендуем хостинг TIMEWEB

    Рекомендуемые статьи по этой тематике

    По статье задано1 вопрос(ов)

    Дополнительные возможности cin и cout в C++

    ЧТО ВНУТРИ iostream.h

    Каждая написанная вами на C++ программа включала заголовочный файл iostream.h. Этот файл содержит определения, позволяющие вашим программам использовать cout для выполнения вывода и cin для выполнения ввода. Более точно, этот файл определяет классы istream и ostream (входной поток и выходной поток), a cin и соut являются переменными (объектами) этих классов. Выберите время, чтобы напечатать файл iostream.h. Он находится в подкаталоге INCLUDE. Определения в этом файле достаточно сложны. Однако если вы пройдете по файлу медленно, то обнаружите, что большинство определений являются просто определениями классов и констант. Внутри файла вы найдете объявления переменных cin и cout.

    ИСПОЛЬЗОВАНИЕ cout

    Как вы уже знаете, cout представляет собой класс, который содержит несколько разных методов. Следующие программы иллюстрируют использование некоторых методов, которые ваши программы могут применять для форматирования вывода. Из урока 3 вы узнали, что манипулятор setw позволяет вашим программам указать минимальное количество символов, которое может занять следующее выходное значение:

    Подобным образом метод cout.width позволяет вам указать минимальное количество символов, которое будет использовать сои/для вывода следующего значения. Следующая программа COUTWIDT.CPP использует функцию cout.width для выполнения работы, аналогичной той, которую выполняет setw, что и показано ниже:

    <
    int i;
    for (i = 3; i

    Если вы откомпилируете и запустите вашу программу, на экране дисплея появится следующий вывод:

    Мое любимое число1001

    Мое любимое число 1001

    Мое любимое число 1001

    Мое любимое число 1001

    Подобно манипулятору setw, ширина, выбираемая с помощью функции cout.width, действует только для следующего выходного значения.

    Использование символа-заполнителя

    Если вы используете манипулятор setw или функцию cout.width для управления шириной вывода, cout будет помещать пробелы до (или после для выровненных влево) значений, как это и требуется. В зависимости от назначения вашей программы вы, возможно, захотите использовать символ, отличный от пробела. Предположим, например, что ваша программа создает такую таблицу:

    Таблица информации
    Профиль компании. 10
    Доходы и убытки компании. 11
    Члены правления компании. 13

    В данном случае вывод предваряет номера страниц точками. Функция cout.fill позволяет вам указать символ, который cout будет использовать для заполнения пустого пространства. Следующая программа COUTFILL.CPP создает таблицу, подобную приведенной выше:

    Если вы однажды выбрали символ-заполнитель с помощью cout.fill, он будет оставаться действительным, пока вы не измените его повторным вызовом cout.fill.

    Управление цифрами значений с плавающей точкой

    Если вы используете cout для вывода значения с плавающей точкой, то обычно не можете сделать каких-либо предположений о том, сколько цифр будет выводить cout no умолчанию. Однако, используя манипулятор setprecision, вы можете указать количество требуемых цифр- Следующая программа SETPREC.CPP использует манипулятор setprecision для управления количеством цифр, которые появятся справа от десятичной точки:

    <
    float value = 1.23456;
    int i;
    for (i = 1; i

    Когда вы откомпилируете и запустите эту программу, на экране дисплея появится следующий вывод:

    Если вы используете манипулятор setprecision для изменения точности, ваша установка действует до тех пор, пока программа повторно не использует setprecision.

    ВЫВОД И ВВОД ОДНОГО СИМВОЛА ЗА ОДИН РАЗ

    В зависимости от назначения вашей программы вам, возможно, потребуется выводить символы на дисплей или читать с клавиатуры по одному символу за один раз. Для вывода одного символа за один раз ваши программы могут использовать функцию cout.put. Следующая программа COUTPUT.CPP использует эту функцию для вывода на экран сообщения Учимся программировать на языке C++! по одному символу за раз:

    <
    char string[] = «Учимся программировать на языке C++!»;
    int i;
    for (i = 0; string[i]; i++) cout.put(string[i]) ;
    >

    Библиотека этапа выполнения предоставляет функцию с именем toupper, которая возвращает заглавный эквивалент строчной буквы. Следующая программа COUTUPPR.CPP использует функцию toupper для преобразования символа в верхний регистр, а затем выводит эту букву с помощью cout.put.

    #include // прототип toupper

    <
    char string[] = «C++ language»;
    int i;
    for (i = 0; string[i]; i++) cout.put(toupper(string[i]));
    cout

    Если вы откомпилируете и запустите эту программу, на экране дисплея появится следующий вывод*:

    Результирующая строка: C++ language

    * К сожалению, функция toupper применима только к английским буквам. Прим. перев.

    ЧТЕНИЕ ВВОДА С КЛАВИАТУРЫ ПО ОДНОМУ СИМВОЛУ ЗА РАЗ

    Точно так же, как cout предоставляет функцию cout.put для вывода символа, cin предоставляет функцию cin.get, которая позволяет вам читать один символ данных. Чтобы воспользоваться функцией cin.get, вы просто присваиваете переменной возвращаемый этой функцией символ, как показано ниже:

    Следующая программа CIN_GET.CPP выводит сообщение, в ответ на которое вам необходимо ввести Y или N. Затем она повторяет в цикле вызов cin.get для чтения символов, пока не получит Y или N:

    ЧТЕНИЕ С КЛАВИАТУРЫ ЦЕЛОЙ СТРОКИ

    Как вы уже знаете, при использовании cin для выполнения ввода с клавиатуры, cin использует пустые символы, такие как пробел, табуляция или возврат каретки, для определения, где заканчивается одно значение и начинается другое. Во многих случаях вы захотите, чтобы ваши программы считывали целую строку данных в символьную строку. Для этого программы могут использовать функцию cin.getline. Для использования cin.getline вам необходимо указать символьную строку, в которую будут помещаться символы, а также размер строки, как показано ниже:

    Когда cin.get читает символы с клавиатуры, она не будет читать символов больше, чем может вместить строка. Удобным способом определить размер массива является использование оператора C++ sizeof, как показано ниже:

    Если позже вы измените размер массива, то вам не нужно будет искать и изменять каждый оператор с cin.get, встречающийся в вашей программе. Вместо этого оператор sizeof » будет использовать корректный размер массива. Следующая программа GETLINE.CPP использует функцию cin.getline для чтения с клавиатуры строки текста:

    <
    char string[128];
    cout

    Когда вы читаете символы с клавиатуры, то, возможно, вам понадобится читать символы вплоть до и включая определенный символ. Когда такой символ будет прочитан, возможно, вы захотите завершить операцию ввода. Для выполнения подобной операции ваша программа может передать искомый символ в cin.getline. Например, следующий вызов заставляет функцию cin.getline читать строку текста, пока не встретится возврат каретки, или пока не будут прочитаны 64 символа, или пока не встретится буква Я:

    cin.getline(string, 64, «Я»);

    Следующая программа UNTIL_Z.CPP использует cin.getline для чтения строки текста или символов вплоть до появления буквы Я (включая и эту букву):

    <
    char string[128];
    cout

    Откомпилируйте и запустите эту программу. Экспериментируйте с различными строками текста. Некоторые из них начинайте с буквы Я, некоторые заканчивайте буквой Я, а некоторые пусть вообще не содержат букву Я.

    ЧТО ВАМ НЕОБХОДИМО ЗНАТЬ

    Каждая созданная вами на C++ программа будет, вероятно, использовать cin или cout для выполнения операций ввода и вывода. Этот урок посвящен некоторым манипуляторам В/В и функциям, которые вы можете использовать с потоками cin и cout. По мере усложнения ваших программ они часто будут сохранять информацию в файлах. Из урока 34 вы узнаете, как в C++ выполнять операции файлового ввода и вывода. Прежде чем приступить к изучению урока 34, убедитесь, что вы освоили следующие основные концепции:

    Дополнительные сведения о: Ошибка компилятора C2065

    Решение

    Поместите директиву

    #include “stdafx.h”

    прежде чем любые другие включают директивы.

    7

    Решение

    прежде чем любые другие включают директивы.

    Я только начал разбираться с плюсами. И тут же воткнулся в какой-то непонятный для меня косяк.

    Вроде все верно. Но при компиляции ошибка:

    Я почитал у вас тут похожие темы. Пишут, что область имен надо объявить, она есть. Вроде вообще все как надо. Я использую VS 2017 для написания кода. Объясните, пожалуйста, что не так.

    Двоичное дерево поиска
    Задание. Построение и обработка двоичных деревьев поиска. Реализовать программу, выполняющую следующий набор операций с деревьями поиска:

    поиск вершины с заданным значением ключа с выводом счетчика числа появлений данного ключа
    добавление новой вершины в соответствии со значением ее ключа или увеличение счетчика числа появлений
    построчный вывод дерева в наглядном виде с помощью обратно-симметричного обхода
    вывод всех вершин в одну строку по порядку следования ключей с указанием для каждой вершины значения ее счетчика появлений
    удаление вершины с заданным значением ключа

    Выдает (в VS 2012) следующие ошибки:

    ca7debe68da19d4d9be8f77ae809d608_i-99.jpg

    Т. Е. он утв-ет что count не является однозначным и не определен

    Идентификатор не объявленThe identifier is undeclared

    Если идентификатор является переменной или именем функции, его необходимо объявить перед тем, как его можно будет использовать.If the identifier is a variable or a function name, you must declare it before it can be used. Перед использованием функции в объявлении функции также должны быть включены типы его параметров.A function declaration must also include the types of its parameters before the function can be used. Если переменная объявлена с помощью auto , компилятор должен иметь возможность определить тип из его инициализатора.If the variable is declared using auto, the compiler must be able to infer the type from its initializer.

    Если идентификатор является членом класса или структуры или объявлен в пространстве имен, он должен уточняться именем класса или структуры или именем пространства имен при использовании вне структуры, класса или области пространства имен.If the identifier is a member of a class or struct, or declared in a namespace, it must be qualified by the class or struct name, or the namespace name, when used outside the struct, class, or namespace scope. Кроме того, пространство имен должно быть помещено в область с помощью using директивы, такой как using namespace std; , или имя члена должно быть помещено в область с помощью using объявления, такого как using std::string; .Alternatively, the namespace must be brought into scope by a using directive such as using namespace std;, or the member name must be brought into scope by a using declaration, such as using std::string;. В противном случае неполное имя считается необъявленным идентификатором в текущей области.Otherwise, the unqualified name is considered to be an undeclared identifier in the current scope.

    Если идентификатор является тегом для определяемого пользователем типа, например, class или struct , тип тега должен быть объявлен до его использования.If the identifier is the tag for a user-defined type, for example, a class or struct, the type of the tag must be declared before it can be used. Например, объявление struct SomeStruct { /*…*/ }; должно существовать, прежде чем можно будет объявить переменную SomeStruct myStruct; в коде.For example, the declaration struct SomeStruct { /*…*/ }; must exist before you can declare a variable SomeStruct myStruct; in your code.

    Если идентификатор является псевдонимом типа, тип должен быть объявлен с помощью using объявления или typedef перед тем, как его можно будет использовать.If the identifier is a type alias, the type must be declared by using a using declaration or typedef before it can be used. Например, необходимо объявить, using my_flags = std::ios_base::fmtflags; прежде чем можно будет использовать my_flags в качестве псевдонима типа для std::ios_base::fmtflags .For example, you must declare using my_flags = std::ios_base::fmtflags; before you can use my_flags as a type alias for std::ios_base::fmtflags.

    1. Статическая инициализация

    При создании статической переменной, возникает вопрос, когда эта переменная будет инициализирована, сколько времени она проживёт и когда будет уничтожена? Статическая инициализация позволяет нам создать переменную, которая будет инициализирована до запуска программы со временем жизни в течение всей программы и уничтожении после завершения. Такие константные переменные не зависят от исполнения — они всегда существуют, создаются во время компиляции и располагаются в исполнимом файле (в бинарнике). Как результат: нулевые накладные расходы, ранняя диагностика проблем и безопасность. Вопрос об использовании статической инициализации напрямую зависит от предметной области разрабатываемого проекта — чем ниже уровень, тем соблазн использования выше, а иногда и критичен, тут скорость решает всё.

    Как пример:

    const std :: size_t tabsize = 64 ;int tab [ tabsize ] ;

    Логические операторы

    В то время как операторы сравнения используются для проверки конкретного условия: ложное оно или истинное, они могут проверить только одно условие за определенный промежуток времени. Но бывают ситуации, когда нужно протестировать сразу несколько условий. Например, чтобы узнать, выиграли ли мы в лотерею, нам нужно сравнить все цифры купленного билета с выигрышными. Если в лотерее 6 цифр, то нужно выполнить 6 сравнений, все из которых должны быть true.

    Также иногда нам нужно знать, является ли хоть одно из нескольких условий истинным. Например, мы не пойдем сегодня на работу, если больны или слишком устали, или если выиграли в лотерею. Нам нужно проверить, является ли хоть одно из этих 3-х условий истинным. Как это сделать? С помощью логических операторов! Они позволяют проверить сразу несколько условий за раз.

    В языке C++ есть 3 логических оператора:

    Оператор Символ Пример Операция
    Логическое НЕ ! !x true, если x — false и false, если x — true
    Логическое И && x && y true, если x и y — true, в противном случае — false
    Логическое ИЛИ || x || y true, если x или y — true, в противном случае — false

    Короткий цикл вычислений

    Для того, чтобы логическое И возвращало true, оба операнда должны быть истинными. Если первый операнд вычисляется как false, то оператор И должен сразу возвращать false независимо от результата второго операнда (даже без его обработки). Это называется коротким циклом вычисления (англ. «short circuit evaluation») и выполняется он, в первую очередь, в целях оптимизации.

    Аналогично, если первый операнд логического ИЛИ является true, то и всё условие будет true (даже без обработки второго операнда).

    Как и в случае с оператором ИЛИ, новички иногда путают логическое И (&&) с побитовым И (&).

    Пример: сбой выведения типа C++/CLIExample: C++/CLI type deduction failure

    Эта ошибка может возникать при вызове универсальной функции, если аргумент предполагаемого типа не может быть выведен из используемых параметров.This error can occur when calling a generic function, if the intended type argument cannot be deduced from the parameters used. Дополнительные сведения см. в разделе универсальные функции (C++/CLI).For more information, see Generic Functions (C++/CLI).

    // C2065_b.cpp// compile with: cl /clr C2065_b.cppgeneric <typename ItemType>void G(int i) {}int main() { // global generic function call G<T>(10); // C2065 G<int>(10); // OK – fix with a specific type argument}

    А где же побитовое исключающее ИЛИ (XOR)?

    Побитовое исключающее ИЛИ (XOR) — это логический оператор, который используется в некоторых языках программирования для проверки на истинность нечётного количества условий.

    Побитовое исключающее ИЛИ (XOR)
    Левый операнд Правый операнд Результат
    false false false
    false true true
    true false true
    true true false

    В языке C++ нет такого оператора. В отличии от логических И/ИЛИ, к XOR не применяется короткий цикл вычислений. Однако его легко можно сымитировать, используя оператор неравенства (!=):

    if(a!=b)...// a XOR b (предполагается, что a и b имеют тип bool)

    Можно также расширить количество операндов:

    if(a!=b!=c!=d)...// a XOR b XOR c XOR d (предполагается, что a, b, c и d имеют тип bool)

    Следует отметить, что вышеприведенные шаблоны XOR работают только, если операнды имеют логический (а не целочисленный) тип данных. Если вы хотите, чтобы это работало и с целыми числами, то используйте оператор static_cast.

    Форма XOR, которая работает и с другими типами данных (с помощью оператора static_cast мы можем конвертировать любой тип данных в тип bool):

    if(static_cast<bool>(a)!=static_cast<bool>(b)!=static_cast<bool>(c)!=static_cast<bool>(d))...// a XOR b XOR c XOR d, для любого типа, который может быть конвертирован в тип bool

    Содержание

    1. Cin не является однозначным
    2. Решение
    3. Объект класса string не является однозначным
    4. Решение
    5. Ошибка «переменная не является однозначной»
    6. Как исправить ошибку «cout не является однозначным»?
    7. Поточный ввод-вывод в C++
    8. Ввод информации
    9. Манипуляторы потока

    Cin не является однозначным

    Позвольте мне предвосхитить это, сказав, что я включил (также относится к string, endl, и буквально все не работает); моя IDE не показывает ошибок, насколько синтаксис идет; и я не могу понять, почему эта проблема происходит? Он отлично работает в одном из моих других примеров кода C ++, которые я написал.

    Поэтому я пытаюсь сделать небольшую игру, быков и коров. Мой основной код выглядит следующим образом:

    Наконец, мой файл BullsAndCows.cpp:

    Ошибки, которые я получаю, так как «cout не является членом std», символ cout не может использоваться в объявлении использования. До этого я использовал «использование пространства имен std», и это возвращало бы ошибки, такие как «BullsAndCows» не является пространством имен или классом (если это не класс, то я должен быть марсианином). Также кое-что о пропавшем «;» перед userInput, например, в моем коде main.cpp; что не имеет смысла, так как нет ничего, что не хватает этого. Я использую VS2017. Почему C ++ такой раздражающий язык для работы?

    Решение

    прежде чем любые другие включают директивы.

    Автор Јляп Шляпович задал вопрос в разделе Другие языки и технологии

    Помогите пожалуйста исправить ошибку в коде программы (C++). Был бы благодарен. и получил лучший ответ

    Ответ от Valrand()[гуру]
    Причина: здесь, возможно, компилятором делается попытка интерпретировать «cout

    Двоичное дерево поиска
    Задание. Построение и обработка двоичных деревьев поиска. Реализовать программу, выполняющую следующий набор операций с деревьями поиска:

    поиск вершины с заданным значением ключа с выводом счетчика числа появлений данного ключа
    добавление новой вершины в соответствии со значением ее ключа или увеличение счетчика числа появлений
    построчный вывод дерева в наглядном виде с помощью обратно-симметричного обхода
    вывод всех вершин в одну строку по порядку следования ключей с указанием для каждой вершины значения ее счетчика появлений
    удаление вершины с заданным значением ключа

    Выдает (в VS 2012) следующие ошибки:

    Т. Е. он утв-ет что count не является однозначным и не определен

    Источник

    Объект класса string не является однозначным

    Вот ошибка:
    Ошибка 1 error C2872: left: неоднозначный символ c:usersмdesktopdocumentsvisual studio 2013projectsмлитамлитаметод вонга.cpp 33 1 МЛиТА

    и таких около 100 штук где используется два объекта left and right. Вчера успешно закрыл программу после тестирования пару примеров. Сегодня открыл вот эта жуть.

    как узнать,является данный объект класса А1 наследником класса А2
    Всем привет)есть классы S, A1, A2, B1, B2. Иерархия наследования следующая S — Является.

    Является ли однозначным небаном то,
    Вообщем вопрос такого плана — при добавлении сайта в http://webmaster.yandex.ru/add.xml — выдается.

    Является ли отображение взаимно-однозначным.
    помогите пожалуйста.. не могу решить. является ли отображение множеств натуральных чисел в.

    Является ли натуральное число а однозначным.
    Определить, является ли натуральное число а однозначным. Заранее спасибо!

    _Valera_, я все подробно выложил, или мне код закинуть?

    Добавлено через 8 минут

    Решение

    в том что кто-то не читает ссылки, которые ему дают.

    _Valera_, код ведь понятен, логических ошибок нет, в нем. Можешь проверить функцию где я пробелы убираю, вроде и там все правильно. Он останавливается компилить на 13шаге, я помню точно он компилил его раз 10 вчера

    Добавлено через 1 минуту
    _Valera_, я не понимаю тебя, до сих пор так подключал пространство и ничего подобного не выводил

    Добавлено через 2 минуты
    _Valera_, ну я понял твои статьи у меня ведь ничего такого нет, я всегда так и работал!

    Добавлено через 3 минуты
    _Valera_, и все же я не вижу зависимость между названиями

    Источник

    Ошибка «переменная не является однозначной»

    Глобальная или статическая переменная не может иметь тип управляемый «System::String ^»
    Привет, такая проблема, необходимо создать объект типа String в программе вот часть кода.

    Синтаксическая ошибка: отсутствие «;» перед «)»
    не пойму. где тут ошибка. private: System::Void button2_Click(System::Object^ sender.

    Ошибка при запуске приложения под Windows XP: «Не является приложением Win32»
    Здравствуйте, написал приложение на Visual Studio Express 2013. У меня ОС Windows 7 x64. Работает.

    После запуска среды выскакивает окошечко с ошибкой «Unknown error» или «Неизвестная ошибка»
    Доброго времени суток. Возникла проблема. После запуска среды выскакивает окошечко с ошибкой.

    В общем-то тоже верно))

    В общем, проблему с ошибкой компилятора решил. Для тех, кого интересуют подробности:
    В строке public ref class MessageFilter : public IMessageFilter нужно было IMessageFilter записать так: System::Windows::Forms::IMessageFilter
    Теперь все собирается и запускается, однако (встал новый вопрос) перехват системных сообщений почему-то не происходит((
    Причем не ловит именно сообщение WM_DEVICECHANGE (находится в Dbt.h). Сам алгоритм работает верно, проверил на сообщениях нажатия кнопок мыши (по нажатию проверяемых кнопок, мэсседжбоксы выскакивали стабильно).
    У кого-нибудь есть мысли, почему обработчик может не видеть и не обрабатывать сообщения из подключенного файла Dbt.h (в частности хотя бы WM_DEVICECHANGE)??

    Кто может помочь с данной проблемой? Может кто сталкивался с подобной обработкой сообщений именно под C++ .NET Windows Forms .

    Источник

    Как исправить ошибку «cout не является однозначным»?

    А так же выдает ошибку ‘эта переменная не содержит класс хранения или спецификатор типа’
    В чем проблема?(
    Подскажите пожаалулйстааа))))

    #include
    #include
    using namespace std;

    country();
    country(char* aname , double at_winter, double at_spring,double at_summer,double at_autumn);
    country(const country& CONTRY);

    char* name;
    double t_winter, t_spring, t_summer, t_autumn;

    class NewCountry : public country <
    public:

    NewCountry();
    NewCountry(char* aname, double at_winter, double at_spring, double at_summer, double at_autumn, int apolusharie);
    NewCountry(const NewCountry& COUNTRY);

    unsigned short int gpolusharie() < return polusharie; >;
    string sReturnpolusharie();

    private:
    unsigned short int polusharie;
    >;

    country::country()
    <
    name = NULL;
    t_winter = NULL;
    t_spring = NULL;
    t_summer = NULL;
    t_autumn = NULL;
    >;

    country::country(char* aname, double at_winter, double at_spring, double at_summer, double at_autumn) :
    name(new char[strlen(aname) + 1])
    <
    strcpy_s(name, strlen(aname) + 1, aname);
    t_winter = at_winter;
    t_spring = at_spring;
    t_summer = at_summer;
    t_autumn = at_autumn;
    >;

    ostream& operator >(istream& In, country& COUNTRY)
    <
    char TEMP[123];
    In >> TEMP >> COUNTRY.t_winter >> COUNTRY.t_spring >> COUNTRY.t_summer >> COUNTRY.t_autumn;
    delete[] COUNTRY.name;
    COUNTRY.name = new char[strlen(TEMP) + 1];
    strcpy_s(COUNTRY.name, strlen(TEMP) + 1, TEMP);
    return In;
    >;

    country& country::operator=(const country& COUNTRY) <
    if (this == &COUNTRY) return *this;
    delete[] name;
    name = new char[strlen(COUNTRY.name) + 1];
    strcpy_s(name, strlen(COUNTRY.name) + 1, COUNTRY.name);
    name = COUNTRY.name;
    t_winter = COUNTRY.t_winter;
    t_spring = COUNTRY.t_spring;
    t_summer = COUNTRY.t_summer;
    t_autumn = COUNTRY.t_autumn;
    return *this;
    >;

    NewCountry::NewCountry() :
    country()
    <
    polusharie = NULL;
    >;

    NewCountry::NewCountry(char* aname, double at_winter, double at_spring, double at_summer, double at_autumn, int apolusharie) :
    country(aname,at_winter, at_spring, at_summer, at_autumn)
    <
    polusharie = apolusharie;
    >;

    string NewCountry::sReturnpolusharie() <
    if (polusharie == 1) return «северное»;
    if (polusharie == 2) return «южное»;
    if (polusharie == 3) return «по обе стороны экватора»;
    return «. ОШИБКА:данные отсутствуют. «;
    >;

    ostream& operator >(istream& In, NewCountry& COUNTRY)
    <
    char TEMP[123];
    In >> TEMP >> COUNTRY.t_winter >> COUNTRY.t_spring >> COUNTRY.t_summer >> COUNTRY.t_autumn >> COUNTRY.polusharie;
    delete[] COUNTRY.name;
    COUNTRY.name = new char[strlen(TEMP) + 1];
    strcpy_s(COUNTRY.name, strlen(TEMP) + 1, TEMP);
    return In;
    >;

    NewCountry& NewCountry::operator=(const NewCountry& COUNTRY) <
    if (this == &COUNTRY) return *this;
    delete[] name;
    name = new char[strlen(COUNTRY.name) + 1];
    strcpy_s(name, strlen(COUNTRY.name) + 1, COUNTRY.name);
    t_winter = COUNTRY.t_winter;
    t_spring = COUNTRY.t_spring;
    t_summer = COUNTRY.t_summer;
    t_autumn = COUNTRY.t_autumn;
    polusharie = COUNTRY.polusharie;
    return *this;
    >;

    void main() <
    setlocale(LC_ALL, «Russian»);
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    int N;
    double winter = lol[0].ReturnT_Winter;
    double summer = lol[0].ReturnT_Summer;
    NewCountry* lol;
    cout > N;
    lol = new NewCountry[N];
    cout > lol[i];
    for ( int i = 0; i lol[i].ReturnT_Summer ())
    summer = lol[i].ReturnT_Summer();
    >
    >;
    cout Вопрос задан более двух лет назад

  • 2516 просмотров
  • Источник

    Поточный ввод-вывод в C++

    Поточный ввод-вывод в C++ выполняется с помощью функций сторонних библиотек. В С++, как и в С, нет встроенных в язык средств ввода-вывода.

    В С для этих целей используется библиотека stdio.h .
    В С++ разработана новая библиотека ввода-вывода iostream , использующая концепцию объектно-ориентированного программирования:

    Библиотека iostream определяет три стандартных потока:

    • cin стандартный входной поток ( stdin в С)
    • cout стандартный выходной поток ( stdout в С)
    • cerr стандартный поток вывода сообщений об ошибках ( stderr в С)

    Для их использования в Microsoft Visual Studio необходимо прописать строку:

    Для выполнения операций ввода-вывода переопределены две операции поразрядного сдвига:

    • >> получить из входного потока
    • cout

    Возможно многократное назначение потоков:
    cout

    Ввод информации

    При этом из входного потока читается последовательность символов до пробела, затем эта последовательность преобразуется к типу идентификатора, и получаемое значение помещается в идентификатор:

    Возможно многократное назначение потоков:
    cin >> переменная1 >> переменная2 >>. >> переменнаяn;

    При наборе данных на клавиатуре значения для такого оператора должны быть разделены символами (пробел, n, t ).

    Особого внимания заслуживает ввод символьных строк. По умолчанию потоковый ввод cin вводит строку до пробела, символа табуляции или перевода строки.

    Результат выполнения

    Для ввода текста до символа перевода строки используется манипулятор потока getline() :

    Результат выполнения

    Манипуляторы потока

    Функцию — манипулятор потока можно включать в операции помещения в поток и извлечения из потока ( >).

    В С++ имеется ряд манипуляторов. Рассмотрим основные:

    Манипулятор Описание
    endl Помещение в выходной поток символа конца строки ‘n’
    dec Установка основания 10-ой системы счисления
    oct Установка основания 8-ой системы счисления
    hex Установка основания 16-ой системы счисления
    setbase Вывод базовой системы счисления
    width(ширина) Устанавливает ширину поля вывода
    fill(‘символ’) Заполняет пустые знакоместа значением символа
    precision(точность) Устанавливает количество значащих цифр в числе (или после запятой) в зависимости от использования fixed
    fixed Показывает, что установленная точность относится к количеству знаков после запятой
    showpos Показывает знак + для положительных чисел
    scientific Выводит число в экспоненциальной форме
    get() Ожидает ввода символа
    getline(указатель, количество) Ожидает ввода строки символов. Максимальное количество символов ограничено полем количество

    Пример Программа ввода-вывода значения переменной в C++

    Та же программа, написанная на языке Си

    Пример Использование форматированного вывода

    Результат выполнения

    Еще один пример использования форматированного вывода: для t∈[0;3] с шагом 0,5 вычислить значение y=cos(t).

    Результат выполнения

    Источник

    0 / 0 / 0

    Регистрация: 07.01.2023

    Сообщений: 6

    1

    23.03.2023, 13:30. Показов 1560. Ответов 14


    Студворк — интернет-сервис помощи студентам

    Написала код, всё работает прекрасно, но через какое-то время появляется 90+ ошибок «cout не является однозначным» и код не компилируется (using namespace std есть, да и код работал), раньше эту проблему удавалось решить переписав строку «using namespace std» или просто убрав «;» и вернув её обратно, но сейчас это уже не помогает. Поискала решение, некоторые перезапускают VS, это помогло, но ошибка появляется очень часто и постоянно перезапускать программу неудобно. Подскажите, может есть ещё какие-то способы это решить.



    0



    Лежебока

    296 / 215 / 92

    Регистрация: 12.05.2021

    Сообщений: 1,261

    23.03.2023, 13:31

    2

    moolingtoon, предоставьте пример и проблемы, а там будет видно,наверно



    0



    Нарушитель

    8593 / 4598 / 1060

    Регистрация: 12.03.2015

    Сообщений: 21,586

    23.03.2023, 13:33

    3

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    Подскажите, может есть ещё какие-то способы это решить.

    Что за программного монстра ты рожаешь? Для этого использование MSVC необходимо?



    0



    moolingtoon

    0 / 0 / 0

    Регистрация: 07.01.2023

    Сообщений: 6

    23.03.2023, 13:56

     [ТС]

    4

    C++
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    
    #include <iostream>
    #include <Windows.h>
    #include <string>
    #include <fstream> 
    #include <stdlib.h>
    #include <conio.h>
    using namespace std;
     
    HANDLE color;
    void white ();
    void red();
    void green();
     
    void white()
    {SetConsoleTextAttribute(color, 7);}
    void red()
    {SetConsoleTextAttribute(color, 12);}
    void green()
    {SetConsoleTextAttribute(color, 10);}
     
    void MainMenu();
     
    void MainMenu()
    {
        system("cls");
        green(); cout << "tГлавное меню" << endl;
        cout << "[1] ";
        white(); cout << "Войти в личный кабинет" << endl;
        green(); cout << "[2] ";
        white(); cout << "Регистрация" << endl;
        green(); cout << "[3] ";
        white(); cout << "Войти от имени администратора" << endl;
        red(); cout << "[Esc] ";
        white(); cout<<"Выход" << endl << endl;
    }
    int main()
    {
        SetConsoleCP(1251);
        SetConsoleOutputCP(1251);
        color = GetStdHandle(STD_OUTPUT_HANDLE);
        MainMenu();
    }

    вот небольшой кусочек, ошибка выделяет все строчки там где есть cout



    0



    Нарушитель

    8593 / 4598 / 1060

    Регистрация: 12.03.2015

    Сообщений: 21,586

    23.03.2023, 14:04

    5

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    вот небольшой кусочек, ошибка выделяет все строчки там где есть cout

    Проблема явно в самой IDE и/или в мокрософтовском компиляторе.
    У меня компилится прям в консоли и работает.

    cout не является однозначным



    0



    0 / 0 / 0

    Регистрация: 07.01.2023

    Сообщений: 6

    23.03.2023, 14:06

     [ТС]

    6

    у меня тоже работает, до определенного момента, через какое-то время появляется ошибка, раньше чинить её получалось а вот сейчас никак



    0



    Нарушитель

    8593 / 4598 / 1060

    Регистрация: 12.03.2015

    Сообщений: 21,586

    23.03.2023, 14:08

    7

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    у меня тоже работает, до определенного момента, через какое-то время появляется ошибка, раньше чинить её получалось а вот сейчас никак

    Я просил:

    Цитата
    Сообщение от Verevkin
    Посмотреть сообщение

    Для этого использование MSVC необходимо?



    0



    0 / 0 / 0

    Регистрация: 07.01.2023

    Сообщений: 6

    23.03.2023, 14:12

     [ТС]

    8

    курсовая по с++, начала работу естественно в VS, не думаю что переходить на новую среду будет удобно



    0



    Нарушитель

    8593 / 4598 / 1060

    Регистрация: 12.03.2015

    Сообщений: 21,586

    23.03.2023, 14:14

    9

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    курсовая по с++, начала работу естественно в VS

    Почему естественно?

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    не думаю что переходить на новую среду будет удобно

    Почему?



    0



    Нарушитель

    8593 / 4598 / 1060

    Регистрация: 12.03.2015

    Сообщений: 21,586

    23.03.2023, 14:19

    10

    MSVC — это не для курсовых и лаб, а для чего-то грандиозного, с окошками, например. Для мелких консольных проектов можно юзать и что-то попроще.

    cout не является однозначным



    0



    0 / 0 / 0

    Регистрация: 07.01.2023

    Сообщений: 6

    23.03.2023, 14:26

     [ТС]

    11

    изначально изучение языка начали в VS и постоянно работали в нём



    0



    Нарушитель

    8593 / 4598 / 1060

    Регистрация: 12.03.2015

    Сообщений: 21,586

    23.03.2023, 14:32

    12

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    изначально изучение языка начали в VS и постоянно работали в нём

    А, ну это другое дело!
    Тогда страдай.
    ——
    Я-то, честно говоря, думал, что цель —

    сдать курсач

    научиться кодить, а тут вон оно чо, Михалыч!



    0



    фрилансер

    4792 / 4392 / 935

    Регистрация: 11.10.2019

    Сообщений: 11,568

    23.03.2023, 14:40

    13

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    using namespace std есть

    вот и плохо. Убирай его и везде к его идентификаторам приписывай std::. Почти уверен, что проблема в этом

    Добавлено через 1 минуту
    что-то мне ещё подсказывает, что это вообще не компилятор ругается, а intellisence подчёркивает. В последнем случае можно просто не обращать внимания

    Добавлено через 1 минуту

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    но через какое-то время появляется 90+ ошибок

    точно



    0



    Лежебока

    296 / 215 / 92

    Регистрация: 12.05.2021

    Сообщений: 1,261

    23.03.2023, 15:00

    14

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    курсовая по с++, начала работу естественно в VS, не думаю что переходить на новую среду будет удобно

    Если там нет ничего супер-пупер навороченного, то попробуй другую среду(dev-c++, codeblocks),на крайняк можно онлайн компилятор
    Dev и Codebloks довольно удобны, быстро освоишься



    0



    Вездепух

    Эксперт CЭксперт С++

    10908 / 5905 / 1613

    Регистрация: 18.10.2014

    Сообщений: 14,839

    23.03.2023, 17:32

    15

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    у меня тоже работает, до определенного момента, через какое-то время появляется ошибка, раньше чинить её получалось а вот сейчас никак

    Так не бывает и вы что-то выдумываете.

    Разумеется, если ошибка есть, то никакие «переходы на другую IDE» тут не помогут.

    Цитата
    Сообщение от moolingtoon
    Посмотреть сообщение

    ошибка выделяет все строчки там где есть cout

    «Выделяет»? Что значит «выделяет»?



    0



    IT_Exp

    Эксперт

    87844 / 49110 / 22898

    Регистрация: 17.06.2006

    Сообщений: 92,604

    23.03.2023, 17:32

    Помогаю со студенческими работами здесь

    Ошибка компиляции: «ref» не является однозначным
    Двадцать ошибок и все как одна — &quot;ref&quot; не является однозначным. Помогите, мне эту красоту ещё…

    «count» не является однозначным, проблема в коде
    Всем привет, возникла проблема при написании кода , помогите пожалуйста решить , спасибо.
    #include…

    Ошибка компиляции «Е0266, х не является однозначным»
    Здравствуйте!

    Есть класс Tank, являющийся наследником Rectangle, который, в свою очередь,…

    Странная ошибка volatile int count — count не является однозначным. Ещё про CloseHandle — для чего это?
    Странная ошибка volatile int count — count не является однозначным. Ещё про CloseHandle — для чего…

    Найти причины ошибки: cout не является членом std
    Пример из учебника, пишет что cin, cout — необъявленные идентификаторы, пыталась кажый прописать…

    Искать еще темы с ответами

    Или воспользуйтесь поиском по форуму:

    15

    This kind of thing doesn’t just magically happen on its own; you changed something! In industry we use version control to make regular savepoints, so when something goes wrong we can trace back the specific changes we made that resulted in that problem.

    Since you haven’t done that here, we can only really guess. In Visual Studio, Intellisense (the technology that gives you auto-complete dropdowns and those squiggly red lines) works separately from the actual C++ compiler under the bonnet, and sometimes gets things a bit wrong.

    In this case I’d ask why you’re including both cstdlib and stdlib.h; you should only use one of them, and I recommend the former. They are basically the same header, a C header, but cstdlib puts them in the namespace std in order to «C++-ise» them. In theory, including both wouldn’t conflict but, well, this is Microsoft we’re talking about. Their C++ toolchain sometimes leaves something to be desired. Any time the Intellisense disagrees with the compiler has to be considered a bug, whichever way you look at it!

    Anyway, your use of using namespace std (which I would recommend against, in future) means that std::system from cstdlib now conflicts with system from stdlib.h. I can’t explain what’s going on with std::cout and std::cin.

    Try removing #include <stdlib.h> and see what happens.

    If your program is building successfully then you don’t need to worry too much about this, but I can imagine the false positives being annoying when you’re working in your IDE.

    Понравилась статья? Поделить с друзьями:
  • Ci ошибка 04 cck не выполнено на openbox
  • Chrome не скачивает файлы ошибка сети
  • Chrome журнал ошибок
  • Chrome выскакивает ошибка
  • Chrome remote desktop host ошибка