Основы языка 1С V77

1. Введение
2. Объектная структура 1С
3. Язык 1С. Модульность
4. Общее положения написания модулей
4.1.Коментарии
4.2. Имена переменных, процедур и функций
4.3. Зарезервированные слова
4.4. Структура программного модуля
5. Формат описания виражений и преобразования типов
5.1.Типы данных в выражениях и формат их записи
5.2. Арифметические операции
5.3. Автоматическое преобразование типов
5.4. Логические операторы сравнения
6. Проблемы округления
7. Ограничения системы V77

1. Введение

     Язык программы 1С является структурно-объектным. Этот язык можно назвать как  промежуточный язык между языками высокого уровня и языками скриптов, напрмиер такми как VBA.
       По своей сути приложение 1С работает как бы с двумя модулями. Первый модуль - это ядро или движек. По сути это компилятор, который переводит код а также описание печатных и графических форм на экран или принтер. Второй модуль - база данных, с которой работет первый модуль. Оба модуля взаимосвязаны и работать самомтсоятельно не могут. Второй модуль отвечает за доступ к базе, а также за манипуляцию с ифнормацией в базе.
       В 1С версии 7.7 существет 1 встроенных механизм доступа к базам данных и один механизм, который использует внешний интерфейс доступа к базам данных.
       Первый механизм - доступ к базе формата dbf (по сути доступ не к базе а к каждому отдельному файлу). Используемая версия dbf  - DBASE II, с соответсвующими ограничениями и недостаткатками этой старой версии.
     Второй механизм - доступ к базе в формате MS SQL Server используя соединение через ODBC (так называемый ODBC провайдер доступа к MS SQL Server), который поставляется вместе с MS SQL Server. Изначально версия 7.7 разрабатывалась под SQL Server 6.5 (а точнее она дорабатывалась версии 7.5, которая работала на более ранних версиях SQL Server). На момент написания статьи актуальным релизом 1С (рели 7.70.027) поддерживаются версии SQL Server 6.5, 7.0. SQL2000, про поддержку SQL 2005 информация отсутствует. Но автор провел тест на подключение к SQL Server 2005 релиза 7.70.027 и тест законлился неудачей. Т.е. можно предположить что официально 27 релиз не поддерживает SQL Server 2005 (но эту проблему можно решить почитат здесь: FAQ по администрированию 1С и MS SQL Server).
      Для понимания того как работает 1С рассмотрим как 1С хранит и как запускает код на выполнение. Весь код 1С физически находится или в файле 1Cv7.md, или во внешних отчетах обработках (*.ert) (существует также возможность подгружать модули с внешних файлов, но это частный случай и он рассматриваться не будет). Запускается код на выполнение поэтапно. Это значит что код компилируется и запускается на выполнение по мере необходимости (а точнее тогда, когда осуществляется доступ к объекту или к форме объекта). Исключение составляет лишь глобальный модуль, его компиляция просиходит в момент запуска самой 1С (точнее после инициализации базы данных). Остальные же модули не компилируются в момент запуска 1С, а копмилируются лишь при обращении к этому модулю через форму или объект. Это приводит к тому, что синтаксис контроль надо проверять самому или же смотреть на синтаксические ошибки уже в момент работы приложения.

2. Объектная структура 1С

      Логически код 1С хранится в модулях (модуль в понимании языка 1С - код, который запускается на выполнение). В 1С все модули можно разделить на 3 большие категории: 1 - глобальный модуль, модули обьектов 1С, модули обработок и отчетов. С точки зрения 1С под объектом понимается часть общего набора сущностей, что есть в конкретной базе данных, которые обладают одинаковыми свойствами, имеют одинаковый набор методов и выполняют однотипные функции с информацией или с базой данных. Следует отметить, что не все объекты 1С имеют модули, но в то же время некоторые объекты имеют более одного модуля. Обычно модули привязываются к формам. Форма с точки зрения 1С - это окно с набором своих атрибутов и реквизитов. Не все объекты имеют свои формы, в тоже время некоторые объекты имеют несколько форм. Обычно это форма конкртеного элемента или же форма списка элементов.
      Следует учесть, что 1С работает с базой данных, в то же время некоторые объекты не хранятся в базе данных.
      Т.е. первая классификация объектов может быть по тому, информация по объектам хранится в базе или не в базе, назовем первый тип обьектов Информационные, а второй тип - Неинформационные. Все информационные объекты хранятся в базе данных, в одной или нескольких таблицах. Работа с инофрмационными объектами всегда предполагает позиционирование на конкретную запись в таблице, которая идентифицирует объект. Это значит, что для обращения к такому объекту надо каким то образом перейти на требуемую запись в базе данных. Обычно для такого переходя используются методи 1С.
      Очень хорошей особенностью 1С является то, что часть вновь созданных объектов могут иметь тип уже существующего объекта. Такие объекты называются типообразующие. Те типы, которые не образуют данных для вновь созданных объектов - нетипообразующие. Все типообразующие объекты есть информационными, т.е. они хранятся в базе данных. В понимании 1С типообразующие объекты - это агрегатные объекты.
       В то же время, в 1С есть базовые типы, которые существуеют независимо от создаваемых объектов. Эти типы также хранятся в базе, но эти данные не есть объектами с точки зрения 1С, а они есть атрибутами информационных обьектов.
       Также, важной классификацией объектов есть их типизация по тем признакам, по которым они делятся в самом описании базы данных. Вот эти объекты:
  • Константы.
  • Справочники.
  • Документы.
  • Журналы документов.
  • Перечисдения.
  • Отчеты.
  • Обработки.
  • Планы счетов.
  • Виды субконто.
  • Операция.
  • Проводка.
  • Регистры.
  • Журналы расчетов.
  • Виды расчетов.
  • Группы расчетов.
  • Календари.

Кроме этого существуют нетипизирующие объекты, которые не являются информационными и которые не присутствуют в дереве настройки конфигурации:
  • Текст.
  • XBase.
  • БухгалтерскиеИтоги.
  • КорректныеПроводки.
  • ПравилоПерерасчета.
  • Последовательность.
  • Периодический.
  • СписокЗначений.
  • ТаблицаЗначений.
  • Таблица.
  • Запрос.
  • Картинка.
  • ФС (Файловая система).
    Почти ко всем с перечисленных типов объектов можно получить доступ в модулях посредством функции создания объектов СоздатьОбъект().Общаю структуру описаных классификаций объектов можно представить в виде такой матрицы:
Типы объектов Информационные Типообразующие СоздатьОбъект() Наличие модулей
Константы
Справочники + + + +
Документы + + + +
Журналы документов +
Перечисдения +
Отчеты +
Обработки +
Планы счетов + + + +
Виды субконто +
Операция + + +
Проводка + +
Регистры +
Журналы расчетов + +
Виды расчетов + +
Группы расчетов
Календари +
Текст +
XBase +
БухгалтерскиеИтоги +
КорректныеПроводки + +
ПравилоПерерасчета +
Последовательность + +
Периодический +
СписокЗначений +
ТаблицаЗначений +
Таблица +
Запрос +
Картинка +
ФС (Файловая система) +
Число +
Строка +
Дата +

3. Язык 1С. Модульность

    Как уже было сказано весь текст программного кода делится по модулям.
Вцелом модули можно структурировать так:
       Отдельная база данных
           Глобальный модуль.
                Модули Справочников.
                    Модули Форм списков справочников.
                    Модуль элемента справочников.
                    Модуль группы справочников
                Модули документов.
                    Модуль формы документов.
                    Модуль документов.
                Модули журналов документов.
                    Модуль форми журналов документов.
                Модули плана счетов.
                    Модуль формы счета.
                    Модули форм списков планов счетов.
                Модули операции.
                    Модуль операции.
                    Модули форм списков операции.
                Модули проводки.
                    Модули форм списков журналов проводок.
                Модули журналов расчетов.
                    Модули форм списков журналов расчетов.
                Модули видов расчетов.
                    Модули расчетов.
                Модули отчетов.
                    Модуль формы отчетов.
                Модули обработок.
                    Модуль формы обработки.
    Т.е. в пределах одной базы, с каждого модуля объекта доступен только глобальный модуль. Все остальные модули изолированные и их взаимосвязь без обращений к конкретному спозиционированному объекту невозможна. Но в тож время с каждого модуля доступны атрибуты (и часть методов, которые определены как системные функции) верхнего уровня. Следует отметить, что написанные пользовательские функции и процедуры не есть методами объектов и их вызов как методов невозможен.
    Уровень изоляции атрибутов и переменных идет снизу вверх. Так переменные глобального модуля доступны во всех модулях, точно так же и функции и процедуры глобального модуля. В то же время атрибуты объектов доступны во всех модулях этих объектов, а вот методы делятся на те что доступны и недоступны.

4. Общее положения написания модулей

    Семантика языка 1С такова что весь текст модуля делится на операторы и коментарии. Концом оператора является символ ";". Операторы состоят с выражений.

4.1.Коментарии

    Коментарии в 1С только построчные (поблочных нет). комментарий начинается с двух символов "//" и заканчивается символом конца строки (т.е. до конца строки).

4.2. Имена переменных, процедур и функций

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

4.3. Зарезервированные слова

Приведенные далее ключевые слова являются зарезервированными и не могут использоваться в качестве создаваемых имен переменных и объявляемых процедур и функций. В данном варианте языка каждое из ключевых слов имеет два представления — русское и английское. Английское представление является традиционным для языков программирования. Ключевые слова в русском и английском представлении могут свободно смешиваться в одном исходном тексте. Регистр букв ключевых слов не имеет значения. Ниже приведен список ключевых слов в обоих вариантах представления.

Если

If

He

Not

Дата

Date

Тогда

Then

Знач

Val

Формат

Format

ИначеЕсли

Elsif

СтрДлина

StrLen

Разм

Dim

Иначе

Else

СокрЛ

TrimL

Вопрос

Do Query Box

КонецЕсли

Endlf

СокрП

TrimR

Контекст

Context

Цикл

Do

Лев

Left

Перем

Var

Для

For

Прав

Right

Перейти

Goto

По

To

Сред

Mid

Возврат

Return

Пока

While

Цел

Int

Продолжить

Continue

Функция

Function

Окр

Round

Прервать

Break

КонецПроцедуры

EndProcedure

Число

Number

И

And

КонецФункции

EndFunction

Строка

String

Или

Or

Предупреждение

DoMessageBox

КонецЦикла

EndDo

Процедура

Procedure

4.4. Структура программного модуля

Структуру программного модуля можно подразделить на следующие разделы:

  • раздел определения переменных;
  • раздел процедур и функций;
  • раздел основной программы.

В конкретном программном модуле любой из разделов может отсутствовать.

Раздел определения переменных размещается от начала текста модуля до первого оператора Процедура или оператора Функция или любого исполняемого оператора. В этом разделе могут находиться только операторы объявления переменных Перем.

Раздел процедур и функций размещается от первого оператора Процедура или оператора Функция до любого исполняемого оператора вне тела описания процедур или функций.

Раздел основной программы размещается от первого исполняемого оператора вне тела процедур или функций до конца модуля. В этом разделе могут находиться только исполняемые операторы. Раздел основной программы исполняется в момент запуска модуля на выполнение (см. «Виды программных модулей»). Обычно в разделе основной программы имеет смысл размещать операторы инициализации переменных какими-либо конкретными значениями, которые необходимо провести до первого вызова любой из процедур или функций модуля.

5. Формат описания виражений и преобразования типов

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

5.1.Типы данных в выражениях и формат их записи.

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

Числа

Числа записываются цифрами от 0 до 9; при необходимости записать дробное число целая часть отделяется от дробной части точкой ".".
Например:
45 – положительное целое число
-12 - целое отрицательное число
16.67 – дробное положительное число.

Для работы с числамиможно использовать предусмотренные арифметические операции (см. ниже).

Даты

Даты записываются в виде последовательности символов такого формата:
'ДД.ММ.ГГ'
или
'ДД.ММ.ГГГГ' ,
где:
ДД – число месяца. Обязательно записывается двумя цифрами: если число месяца меньше 9, впереди ставится 0, например «02»;
ММ – номер месяца, также записывается двумя цифрами;
ГГ (ГГГГ) - год, может записываться двумя или четырьмя цифрами.

Например: '01.01.2007'

Необходимо обратить внимание, что даты указываются только в одинарных кавычках. При такой записи последовательность символом вида '01.01.2007' будет восприниматься и обрабатываться системой 1С:Предприятие как дата, а не как последовательность символов, "изображающих" дату. Почему это важно – мы расскажем чуть ниже.

Кроме конкретных дат, во встроенном языке существует такое понятие как «пустая дата». Пустая дата задается последовательностью '00.00.00'. Обычно, пустая дата используется для сравнения. Получить пустую дату можно также при помощи метода преобразования Дата(0).

Примечание.

Типа Время в 1С нет, точно так же как и нет типа ДатаВремя.

Строковые величины

Строковые величины представляют собой последовательности символов, заключенных в двойные или одинарные кавычки. Пример:  "Пример строки ".

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

"Пример строки ""строка в кавычках"""

сформирует в содержании операции строку

Пример строки "строка в кавычках"

В рассмотренном примере в строковой величине:
первый символ кавычек – это открывающая кавычка строковой величины в целом;
2 символа кавычек подряд - это открывающая кавычка и в результирующей строке они заменены одним символом кавычек;
3 символа кавычек подряд – это группа, состоящая из: 2-х кавычек – закрывающей кавычки, которые в результирующей строке заменены одним символом кавычек, и одной кавычки – закрывающей кавычки строковой величины в целом.

Как показывает практика, почему-то именно указание кавычек в строковых величинах вызывает некоторые трудности. Хотя ничего сложного в этом нет, нужно только помнить простое правило: первая и последняя кавычка – по одному символу, а все кавычки внутри них - по два символа.

У строковых величин существует понятие "пустая строка". Пустая строка задается парой кавычек: "". Пустая строка обладает всеми свойствами "нормальной" строковой величины, однако не имеет длины.

5.2. Арифметические операции 

Теперь рассмотрим арифметически операции, используемые в языке 1С (Оп – "операнд"):
сложение (Оп1 + Оп2)
вычитание (Оп1 - Оп2)
умножение (Оп1 * Оп2)
деление (Оп1 / Оп2)
остаток от деления (Оп1 % Оп2)
унарный минус (-Оп1)

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

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

Для строковых величин допустима только операция "+", которая в этом случае называется операцией конкатенации (присоединения). Эта операция присоединяет одну строковую величину к другой.

Например, результатом выражения:

"Пример строки " + "январь 2007 года"

будет строка

Пример строки январь 2007 года

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

Операцией конкатенации можно соединять более двух строковых величин одновременно. Например, допустимо такое выражение:

"Иванов" + " " + "Иван" +" " + "Иванович"

Результатом будет строка

Иванов Иван Иванович

Для величин типа "дата" допустимы операции сложения и вычитания, однако правила использования этих операций немного сложнее, чем для чисел и строк.

К дате можно прибавить число, например:

'02.08.2000'+2

и результатом выражения будет дата, более поздняя, чем первое слагаемое, на количество дней, равных второму слагаемому. В данном случае результатом будет 04.08.2000, или 4 августа 2000 г.

Точно также из даты можно вычитать число, например:

'02.03.2000'-2

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

Даты можно вычитать одну из другой:

'02.10.2000' - '02.08.2000'

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

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

Складывать две даты не рекомендуется. Можно написать, например, такое выражение:

'02.08.2000' + '02.10.2000'

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

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

Например, в выражении

«Амортизация за » + Формат(РабочаяДата(), «Д ММММГГГГ»)

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

5.3. Автоматическое преобразование типов 

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

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

"Амортизация за " + Формат(РабочаяДата(), "Д ММММГГГГ")

В этом выражении второй операнд РабочаяДата(), имеющий тип "дата", преобразуется к типу "строка" при помощи функции Формат().

Однако, система 1С:Предприятие перед вычислением выражений "умеет" автоматически преобразовывать операнды разных типов к одному типу, руководствуясь при этом правилами преобразования типов

Для базовых типов определены следующие правила преобразования:

Число -> Строка

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

Дата -> Строка

Дата преобразованная к строковому типу имеет вид ДД.ММ.ГГ, где ГГ — две цифры года, ММ — числовое обозначение месяца (01, ..., 12), ДД — день месяца.

Строка -> Число

Строка преобразуется в число пока это возможно. Получившееся число считается результатом преобразования. (Например, строка "1.22 Glass" будет преобразована к числу 1.22). Если в начале строки не имеется ничего, что могло бы быть проинтерпретировано как число, то результат равен 0.

Дата -> Число

Результатом данного преобразования является численное представление даты.

Строка -> Дата

Если в начале строки содержится что-то, что может быть проинтерпретировано как строковое представление даты в виде ДД.ММ.ГГ, где ГГ — две цифры года, ММ — числовое обозначение месяца (01, ..., 12), ДД — день месяца, то будет произведено соответствующее преобразование. В противном случае значение даты будет нулевым.

Число -> Дата

    Делается попытка взять целую часть Числа и проинтерпретировать как численное представление даты. Если число отрицательно, то итогом является нулевая дата.

    Итак, прежде всего, следует помнить, что тип результат выражения определяется по типу первого операнда этого выражения. К типу первого операнда приводятся остальные операнды. Зная это правило, можно и предвидеть тип результата выражения в целом, и управлять типом результата.

Например, результатом выражения

2+"А"

будет число 2, потому что первый операнд выражения имеет числовой тип, а второй операнд, в соответствии с правила преобразования типов, стал равен 0.

Однако, стоит немного изменить выражение, написав так:

""+ 2+"А"

как его результат радикально поменяется: результатом выражения станет строка "2А".

Почему так произошло? Выше мы рассказывали про понятие "пустой строки", которая обладает всеми свойствами строковой величины, в том числе и типом "строка". В нашем примере пустая строка является первым операндом выражения, и при вычислении выражения все его операнды были преобразованы к типу "строка" в соответствии с правилами преобразования типов.

Еще один пример. Выше мы подчеркивали, что величина типа "дата" задается символьной строкой в одинарных кавычках, а такая же последовательность символов, но уже в двойных кавычках, является строкой. Теперь мы это проиллюстрируем на примерах.

Как мы уже говорили, результатом выражения '02.08.2000'+2 будет дата 04.08.2000. Но, указав первый операнд в двойных кавычках:

"02.08.2000"+2

мы получим совершенно иной результат – строку "02.08.20002".

Подитожим. управлять типом результата всего выражения можно, ставя первым операндом пустую величину соответствующего типа. Преимущество такого метода состоит в том, что пустая величина не изменяет результата выражения. Например, поставив 0 в начале выражения:

0+ "23"+45

мы получим в результате число 68, потому что выражение в целом имеет тип "число", а символьная строка в соответствии с правилами преобразования типов, была успешно преобразована в число 45.

Тут уместно вспомнить и про пустую дату. Что будет результатом выражения '00.00.00'+ 2+'02.08.2000'? Конечно же, дата 04.08.2000 (4 августа 2000 года), потому что первым операндом выражения была величина типа "дата".

Наоборот, убрав пустую дату

2+'02.08.2000'

мы получим в результате 2451761 – это число дней с нулевой даты до 2 августа 2000 года, плюс еще 2 дня.

5.4. Логические операторы сравнения

В 1С существуют такие логические выражения для базовых типов данных.

> Больше

< Меньше

<> Не равно

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

По отношению с числовим типом данных - проблем не возникает, сравнивается стандартное число (целое или дробное).

Для строковых величин сравнение происходит ко их так назЫваемым "scan-кодам" (в понимании 1С такой код можно получить с помощью метода КодСимв()). Сравнение производится посимвольно. Так если сравниваются строки равной длины, то сравниваются последовательно коды соотвествующих символов. Сравнение происходит до первого неравенства в строке (если строка состоит больще чем с одного символа). Если сравниваются строки разной длины, то недостающие значение в операторе дополняются символами пустой строки (не с символом пробел (Код= 32)). Т.е. значение пробела (КодСимв(32)) больше значения  пустой строки.

Для типов дата сраванивается сама дата (но не исключено что 1С перед сравнением дату переводит в число, которе равно количеству дней от Дата(0)).

6. Проблемы округления

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

Например, такая ситуация:
Приходуется 16 единиц товара по цене (включая НДС) 110,50 грн.
- общая стоимость составляет 110,50 * 16 = 1768 грн.
- НДС (по ставке 20%, в том числе) составляет 1768 * 20 / 120 = 294,67 грн.

Если теперь этот товар продать "поштучно" без всякой наценки, НДС будет другим:
- НДС одной единицы товара составит 110,50 * 20 / 120 = 18,42 грн.
- НДС всех 16 единиц составит 18,42 * 16 = 294,72 грн.

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

Заметим, что, приходуя товар, мы не могли считать НДС "поштучно" - вычисляя размер налога в стоимости одной единицы товара и умножая на количество товара. В этом случае могут быть еще большие потери округления. Например, если цена одной единицы товара 3 копейки, то чему равен НДС?

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

В типовых конфигурациях "1С:Предприятия", где это возможно, учитываются и корректно обрабатываются подобные ситуации. Например, если оприходованы 3 единицы товара общей стоимостью 1 гривня, то первые две единицы спишутся по себестоимости 33 копейки, а последняя - 34 копейки. Но не все случаи округлений можно учесть в алгоритмах, в том числе нельзя корректно обработать в программе вышеприведенный пример с пятью копейками НДС.
В некоторых случаях избежать подобных ошибок можно, назначая "подходящую" цену товара, - чтобы от нее нацело, без остатка, вычислялся НДС. Но это правило применимо только продажным ценам - закупочные же цены выбирать не приходится. В остальных случаях пользователям программы необходимо проанализировать, откуда возникли "зависающие копейки" и принять решение, как с ними следует поступить.

7. Ограничения системы V77


Дата
Дата - корректно работает в диапазоне дат от 01.01.0000 до 31.12.9999
Дата(0) соответствует 1721061 дню от даты 01.01.0000
При попытке уйти в минусовые даты - 31.12.0001 система работает некорректно, так как работает с 0 даты, т.е.: Дата("01.01.0000")-1 = 00.01.00. Функция формата для таких дат вообще не работает.

Число
максимальное количество значений = 64 (64 знака).

Строка
Максимальное количество значений = ограничивается свободной физической памятью (без файла подкачки), Предполагается что знаков не может быть больше 2^32-1.
 
Документ
Документ - может быть создано 9999 видов документов.
Документ может иметь и корректно работать имея не больше 9999 строк.
Максимальная длина кода - 20, т.е. может быть теоретически создано всего (27+33+10)^20 документов (70^20 = 7,9792266297612001e+36).
Всего в системе может быть не больше (длина ID кода в журнале=9), практически длина ID в 6 символов (3 на УРИБ) 36^6 = 2176782336 документов.
Количество введенных документ с одинаковым временем ограничивается 36^4 = 1679616
© pvase 2007