Главная Случайная страница


Категории:

ДомЗдоровьеЗоологияИнформатикаИскусствоИскусствоКомпьютерыКулинарияМаркетингМатематикаМедицинаМенеджментОбразованиеПедагогикаПитомцыПрограммированиеПроизводствоПромышленностьПсихологияРазноеРелигияСоциологияСпортСтатистикаТранспортФизикаФилософияФинансыХимияХоббиЭкологияЭкономикаЭлектроника






Как зарегистрировать Visual Studio Team System 2008

По истечению 90-дневного срока действия пробной версии Visual Studio запуск будет невозможен. Для регистрации Visual Studio необходимо выполнить следующие шаги:

1. Войти под учётной записью с правами администратора.

2. Открыть "Установка/удаление программ" в панели управления.

3. Выбрать "Microsoft Visual Studio Team System 2008 Team Suite - RUS" и нажать кнопку "Заменить/Удалить".

4. Нажать "Далее".

5. В появившемся окне надо ввести серийный номер: «PYHYP-WXB3B-B2CCM-V9DX9-VDY8T» и нажать "Обновить".

6. После можно запускать Visual Studio под любым пользователем на данном компьютере.

Приложение 8. Печать русских букв в среде Visual C++ 2008

При выводе информации на русском языке Visual C++ некорректно отображает русские символы.

#include <iostream>

using namespace std;

 

int main()

{

cout << "Привет!" << endl;

return 0;

}

Ниже показан результат выполнения этой программы:

Рис. 13. Пример некорректного отображения русских букв

Проблема возникает из-за того, что используются различные кодировки текста для приложений Windows и консольных приложений. В качестве Windows-приложения выступает «Visual Studio», в котором набирается русский текст (слово «Привет»). В качестве консольного приложения выступает программа. В первом случае используется кодировка 1251, во втором – 866.

Есть несколько способов решения данный проблемы.

Способ 1

Не использовать русские буквы, а писать сообщения на транслите (например, «Privet!») или английском языке.

Способ 2

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

#include <iostream>

#include <string>

#include <clocale>

using namespace std;

 

int main()

{

string name;

setlocale(LC_ALL, "rus");

cout << "Введите своё имя: ";

cin >> name;

cout << "Вас зовут " << name << endl;

return 0;

}

Пример выполнения:

Способ 3

Производить ручное преобразование информации с использованием функций «OemToChar» (для вводимых данных) и «CharToOem» (для выводимых данных).

Пример:

#include <iostream>

#include <Windows.h>

using namespace std;

 

int main()

{

char str[100];

CharToOem(L"Привет!", str);

 

cout << str << endl;

return 0;

}

Результат работы:

Способ 4

Ещё одним способом изменения кодировки является использование функций «SetConsoleCP» и «SetConsoleOutputCP», которые изменяют кодировку входных и выходных данных соответственно.

#include <iostream>

#include <string>

#include <Windows.h>

using namespace std;

 

int main()

{

SetConsoleCP(1251);

SetConsoleOutputCP(1251);

 

string name;

cout << "Введите своё имя: ";

cin >> name;

cout << "Вас зовут " << name << endl;

return 0;

}

Однако при запуске данного примера мы увидим следующее:

Некорректное отображение информации связано с тем, что выбран неправильный шрифт. Для того, чтобы изменить шрифт необходимо правой кнопкой мыши нажать на заголовок окна и выбрать меню «Свойства».

Выбрать шрифт «Lucida Console» и нажать «ОК».

 

Теперь те же данные отображаются и обрабатываются корректно.

Выводы

При выполнении лабораторных работ следует использовать способ 2 или 4.

Ниже представлены выводы безотносительно лабораторных работ.

Важно понимать, что для приложений, написанных в Visual Studio, родной является кодировка Windows. Поэтому правильно будет конвертировать входные данные при вводе и обрабатывать в родной кодировке.

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

Наиболее легким и правильным вариантом является использование функций «SetConsoleCP», «SetConsoleOutputCP» и «setlocale». В этом случае ввод и вывод, а также обработка информации производятся автоматически. Недостатком этого способа можно считать ручное установление шрифта консоли.

Если программа обрабатывает только числовые данные, то наиболее простым и подходящим вариантом будет использование «setlocale».

В любом случае ручное преобразование данных не стоит игнорировать. Ниже представлен код файла «russian.h», который позволяет упростить использование функций «OemToChar» и «CharToOem».

#pragma once

 

/*

Версия: 1.0

Автор: ГУАП, Кафедра 43, Суслов М.Н.

Дата: 6.12.2009 г.

 

Данный файл позволяет переконвертировать символы национального алфавита

для корректного отображения в консольных приложениях.

 

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

для приложений Windows (в данном случае «Visual Studio», в котором

набирается русский текст) и консольных приложений (в данном случае

разрабатываемая программа, в которой отображается русский текст,

набранный в другой кодировке).

 

Для решения этой проблемы имеются следующие функции:

const char* dos2winA(const char* cstr);

const wchar_t* dos2winW(const wchar_t* wstr);

const char* win2dosA(const char* cstr);

const wchar_t* win2dosW(const wchar_t* wstr);

 

А также вспомогательные:

const std::string dos2win(const std::string &str);

const std::wstring dos2win(const std::wstring &str);

const std::string win2dos(const std::string &str);

const std::wstring win2dos(const std::wstring &str);

 

Пример:

---------------------------------------------------------

#include <iostream>

using namespace std;

 

#include "russian.h"

 

int main()

{

cout << win2dosA("Привет!") << endl;

win2dosA(NULL);

return 0;

}

---------------------------------------------------------

 

Чтобы освободить занятую память в конце программы следует вызвать

использованные функции с параметром NULL. Поэтому программа может

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

---------------------------------------------------------

#include <iostream>

using namespace std;

 

#include "russian.h"

 

void rus_exit()

{

win2dosA(NULL);

win2dosW(NULL);

dos2winA(NULL);

dos2winA(NULL);

}

 

int main()

{

atexit(rus_exit);

cout << win2dosA("Введите своё имя: ");

return 0;

}

---------------------------------------------------------

*/

 

#include <windows.h>

#include <cstring>

#include <exception>

#include <string>

 

const char* dos2winA(const char* cstr)

{

static char* cbuf = NULL;

 

if (cbuf != NULL)

{

delete [] cbuf;

cbuf = NULL;

}

 

if (cstr != NULL)

{

cbuf = new char[strlen(cstr)+1];

if (!OemToCharA(cstr, cbuf))

throw new exception("russian.h: dos2winA: OemToCharA");

}

 

return cbuf;

}

 

const wchar_t* dos2winW(const wchar_t* wstr)

{

static wchar_t* wbuf = NULL;

 

if (wbuf != NULL)

{

delete [] wbuf;

wbuf = NULL;

}

 

if (wstr != NULL)

{

size_t len = wcslen(wstr) + 1;

char* cbuf = new char[len];

 

size_t num_can;

if (wcstombs_s(&num_can, cbuf, len, wbuf, len-1))

throw new exception("russian.h: dos2winW: wcstombs_s");

if (num_can != len)

throw new exception("russian.h: wcstombs_s");

 

if (!OemToCharW(cbuf, wbuf))

throw new exception("russian.h: dos2winW: OemToCharW");

 

delete [] cbuf;

cbuf = NULL;

}

 

return wbuf;

}

 

const char* win2dosA(const char* cstr)

{

static char* cbuf = NULL;

 

if (cbuf != NULL)

{

delete [] cbuf;

cbuf = NULL;

}

 

if (cstr != NULL)

{

cbuf = new char[strlen(cstr)+1];

if (!CharToOemA(cstr, cbuf))

throw new exception("russian.h: win2dosA: CharToOemA");

}

 

return cbuf;

}

 

const wchar_t* win2dosW(const wchar_t* wstr)

{

static wchar_t* wbuf = NULL;

 

if (wbuf != NULL)

{

delete [] wbuf;

wbuf = NULL;

}

 

if (wstr != NULL)

{

size_t len = wcslen(wstr) + 1;

char* cbuf = new char[len];

 

if (!CharToOemW(wstr, cbuf))

throw new exception("russian.h: win2dosW: CharToOemW");

 

size_t num_can;

if (mbstowcs_s(&num_can, wbuf, len, cbuf, len-1))

throw new exception("russian.h: win2dosW: mbstowcs_s");

if (num_can != len)

throw new exception("russian.h: win2dosW: mbstowcs_s");

 

delete [] cbuf;

cbuf = NULL;

}

 

return wbuf;

}

 

#ifdef UNICODE

#define dos2win dos2winW

#define win2dos win2dosW

#else

#define dos2win dos2winA

#define win2dos win2dosA

#endif

 

const std::string dos2win(const std::string &str)

{

return std::string(dos2winA(str.c_str()));

}

 

const std::wstring dos2win(const std::wstring &str)

{

return std::wstring(dos2winW(str.c_str()));

}

 

const std::string win2dos(const std::string &str)

{

return std::string(win2dosA(str.c_str()));

}

 

const std::wstring win2dos(const std::wstring &str)

{

return std::wstring(win2dosW(str.c_str()));

}

 


[1] Прототипы функций следует описывать, начиная со второй лабораторной работы.

[2] Часто студенты копируют выходные значения из результатов выполнения программы. Если в программе имеется ошибка, то тестовые данные тоже содержат ошибки, что недопустимо. Поэтому их следует вычислять вручную до написания программного кода.

[3] Имеется в виду динамическая память.

Последнее изменение этой страницы: 2016-07-23

lectmania.ru. Все права принадлежат авторам данных материалов. В случае нарушения авторского права напишите нам сюда...