Функции для работы с реестром

7105
знаков
0
таблиц
0
изображений

Разбирался, давеча, с функциями позволяющими работать с реестром Windows. Нашел ряд функций-членов класса CWinApp: SetRegistryKey, GetProfileInt, GetProfileString, WriteProfileInt, WriteProfileString . Если кому интересен перевод MSDN'овского хелпа к этим функциям - то его можно найти здесь.

CWinApp::SetRegistryKey

void SetRegistryKey( LPCTSTR lpszRegistryKey );

void SetRegistryKey( UINT nIDRegistryKey );

Параметры

lpszRegistryKey

Указатель на строку содержащую имя ключа реестра.

nIDRegistryKey

ID/индекс ключа в реестре.

Описание

Заставляет приложение сохранять установки в реестр вместо INI файлов. Эта функция устанавливает m_pszRegistryKey, которая затем используется в следующих функциях-членах CWinApp: GetProfileInt, GetProfileString, WriteProfileInt, and WriteProfileString. Если эта функция была вызвана, список недавно используемых файлов (list of most recently-used - MRU) также сохраняется в реестре. Ключ реестра обычно является именем компании. Ключ реестра имеет следующий вид: HKEY_CURRENT_USERSoftware.

CWinApp::GetProfileInt

UINT GetProfileInt( LPCTSTR lpszSection, LPCTSTR lpszEntry, int nDefault );

Возвращаемое значение

Если функция успешно отработала - целое значение строки определенной записи. Возвращаемое значение - значение параметра nDefault если функция не нашла записи. Возвращаемое значение - 0 если значение которое соответствует заданной записи не целое.

Эта функция поддерживает шестнадцатеричную нотацию для значений в .INI файле. Когда вы получаете знаковое целое, вы должны перевести значение в int.

Параметры

lpszSection

Указатель на строку завершенную нулем которая определяет секцию, содержащую запись в реестре.

lpszEntry

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

nDefault

Определяет значение по умолчанию для возвращения, если система не сможет найти запись. Это значение может быть беззнаковым целым (unsigned) в диапазоне от 0 до 65,535 или знаковым (signed) в диапазоне от -32,768 до 32,767.

Описание

Вызывайте эту функцию для получения целого значения записи из определенной секции из реестра или .INI файла.

Записи сохраняются следующим образом:

В Windows NT, значение сохраняется в ключ реестра.

В Windows 3.x, значение сохраняется в WIN.INI файл.

В Windows 95, значение сохраняется в скрытую версию WIN.INI файла.

Эта функция не чувствительна к регистру букв, таким образом, строки в параметрах lpszSection и lpszEntry могут использовать буквы разного регистра.

CWinApp::GetProfileString

CString GetProfileString( LPCTSTR lpszSection, LPCTSTR lpszEntry, LPCTSTR lpszDefault = NULL );

Возвращаемое значение

Возвращаемое значение - строка из.INI файла приложения или lpszDefault если строка не найдена. Максимальная длинна строки, которую поддерживает система, определена в _MAX_PATH. Если lpszDefault равно NULL, возвращаемое значение - пустая строка.

Параметры

lpszSection

Указатель на строку завершенную нулем которая определяет секцию содержащую запись в реестре.

lpszEntry

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

lpszDefault

Указатель на значение строки по умолчанию для заданной записи если запись не найдена в инициализирующем (INI) файле.

Описание

Вызывайте эту функцию для получения строки связанной с записью в заданной секции реестра приложения или .INI файла.

Записи сохраняются следующим образом:

В Windows NT, значение сохраняется в ключ реестра.

В Windows 3.x, значение сохраняется в WIN.INI файл.

В Windows 95, значение сохраняется в скрытую версию WIN.INI файла.

Пример

CString strSection = "Моя секция";

CString strStringItem = "Мой строковый элемент";

CString strIntItem = "Мой целый элемент";

CWinApp* pApp = AfxGetApp();

pApp->WriteProfileString(strSection, strStringItem, "test");

CString strValue;

strValue = pApp->GetProfileString(strSection, strStringItem);

ASSERT(strValue == "test");

pApp->WriteProfileInt(strSection, strIntItem, 1234);

int nValue;

nValue = pApp->GetProfileInt(strSection, strIntItem, 0);

ASSERT(nValue == 1234);

CWinApp::WriteProfileInt

BOOL WriteProfileInt( LPCTSTR lpszSection, LPCTSTR lpszEntry, int nValue );

Возвращаемое значение

Не 0 в случае удачного вызова функции, иначе 0.

Параметры

lpszSection

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

lpszEntry

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

nValue

Содержит значение для записи.

Описание

Вызывайте эту функцию для записи заданного значения в заданную секцию реестра или .INI файл.

Записи сохраняются следующим образом:

В Windows NT, значение сохраняется в ключ реестра.

В Windows 3.x, значение сохраняется в WIN.INI файл.

В Windows 95, значение сохраняется в скрытую версию WIN.INI файла.

Пример

CString strSection = "Моя секция";

CString strStringItem = "Мой строковый элемент";

CString strIntItem = "Мой целый элемент";

CWinApp* pApp = AfxGetApp();

pApp->WriteProfileString(strSection, strStringItem, "test");

CString strValue;

strValue = pApp->GetProfileString(strSection, strStringItem);

ASSERT(strValue == "test");

pApp->WriteProfileInt(strSection, strIntItem, 1234);

int nValue;

nValue = pApp->GetProfileInt(strSection, strIntItem, 0);

ASSERT(nValue == 1234);

CWinApp::WriteProfileString

BOOL WriteProfileString( LPCTSTR lpszSection, LPCTSTR lpszEntry, LPCTSTR lpszValue );

Возвращаемое значение

Не 0 в случае удачного вызова функции, иначе 0.

Параметры

lpszSection

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

lpszEntry

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

lpszValue

Указатель на строку, предназначенную для записи. Если этот параметр NULL, запись определенная параметром lpszEntry удаляется.

Описание

Вызывайте эту функцию для записи заданной строки в заданную секцию реестра или .INI файл.

Записи сохраняются следующим образом:

В Windows NT, значение сохраняется в ключ реестра.

В Windows 3.x, значение сохраняется в WIN.INI файл.

В Windows 95, значение сохраняется в скрытую версию WIN.INI файла.

Пример

CString strSection = "Моя секция";

CString strStringItem = "Мой строковый элемент";

CString strIntItem = "Мой целый элемент";

CWinApp* pApp = AfxGetApp();

pApp->WriteProfileString(strSection, strStringItem, "test");

CString strValue;

strValue = pApp->GetProfileString(strSection, strStringItem);

ASSERT(strValue == "test");

pApp->WriteProfileInt(strSection, strIntItem, 1234);

int nValue;

nValue = pApp->GetProfileInt(strSection, strIntItem, 0);

ASSERT(nValue == 1234);

Ну вот в общем и все. Если есть какие-нибудь замечание и пожелания - пишите - dmweb@newmai


Информация о работе «Функции для работы с реестром»
Раздел: Информатика, программирование
Количество знаков с пробелами: 7105
Количество таблиц: 0
Количество изображений: 0

Похожие работы

Скачать
4436
0
0

... программу, а затем выйдите из неё и посмотрите в реестре (с помощью программы regedit) раздел HKEY_CURRENT_USERSoftwarereg_test там и будут наши данные. Теперь нам надо считывать данные из реестра и соответственно изменять размеры и положение формы. Напишем обработчик события на создание формы: procedure TForm1.FormCreate(Sender: TObject); var reg:TRegistry; begin reg:=TRegistry.Create; reg ...

Скачать
12827
0
0

... не нужно ничего менять. Существует ещё много подобных задач. Ассоциативные массивы – универсальное средство. Но как реализовать их в C++? Реализация ассоциативных массивов в C++ Builder Для реализации класса ассоциативного массива, я использовал несколько стандартных классов: во-первых, Variant – мультитип. В переменной типа Variant может хранится значение любого из стандартных типов. Во-вторых, ...

Скачать
71957
0
0

... реализации   2.1 Описание структуры программы   2.1.1 Диаграмма взаимодействия модулей Программа реализована на 2х модулях, один из которых базируясь на API-функциях Windows осуществляет взаимодействие с системным реестром, а второй предоставляет информацию пользователю о текущих значениях предопределенных параметров, и заносит сделанные пользователем изменения параметров в системный реестр. ...

Скачать
67200
0
2

... нужно привести к типу System.Int32, чтобы поместить его в реестр. После чтения из реестра с помощью GetDef() значение должно быть преобразовано обратно к типу AcedCompressionMode. Описание демонстрационного проектаа Чтобы проиллюстрировать различные способы работы с бинарными данными с помощью рассмотренных выше классов, разработано небольшое приложение, которое представляет собой примитивный ...

0 комментариев


Наверх