Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/41: Рейтинг темы: голосов - 41, средняя оценка - 4.76
26 / 26 / 10
Регистрация: 30.10.2011
Сообщений: 68
1

invalid qualifier при попытке определить длину массива внутри функции

22.12.2011, 22:32. Показов 7370. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Задача не суть важна. При попытке нажать кнопку, программа исправно работает до вызова функции, после чего выдаёт ошибку "invalid qualifier", и выделяет переменную m в 5 строке кода. Пробовал исправлять разными способами, в том числе статическими массивами вместо динамических, и параметром length вместо getlength(0) - результат одинаковый.

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

Да, код сделан не в чистом VB, а в макросах MS Excel 2003/2007, надеюсь, я не ошибся с разделом.
+ проверялось на двух разных компах в разных версиях excel - сомневаюсь, что ошибка в ПО или железе.

Заранее спасибо.

Visual Basic
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
Public Function f(ByRef m() As Double) As Integer
Dim n As Integer
Dim i As Integer
Dim s As Integer
n = m.getlength(0)
s = 0
For i = 1 To n
 If m(i) < 0 Then
  s = s + 1
 End If
Next i
f = s
End Function
 
Sub Command1_Click()
Randomize
Dim n As Integer
Dim m1() As Double
Dim m2() As Double
Dim i As Integer
 
n = InputBox("n1")
ReDim m1(n)
 
For i = 1 To n
 m1(i) = Rnd() - 0.5
 Cells(i, 1) = m1(i)
Next i
 
n = InputBox("n2")
ReDim m2(n)
For i = 1 To n
 m2(i) = Rnd() - 0.5
 Cells(i, 2) = m2(i)
Next i
 
If f(m1) < f(m2) Then
 MsgBox ("m2")
Else
 MsgBox ("m1")
End If
End Sub
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.12.2011, 22:32
Ответы с готовыми решениями:

При попытке отобразить список выдает Invalid namespace
Здравствуйте!Вывожу в combobox список сетевых устройств на ПК таким обрзом: ...

Invalid filename при попытке записать в текстовый файл
procedure TForm7.btn1Click(Sender: TObject); var fg:TextFile; Str,str1:WideString; begin...

Invalid floating point operation при попытке нарисовать график
Возникла следующая проблема: По непонятной мне причине на строке ...

Ошибка Invalid NSF version при попытке переименовать пользователя
Коллеги, что-то произошло, и с сегодняшнего дня при попытке Change Common Name через CA появилась...

2
Заблокирован
22.12.2011, 22:41 2
lbound(m) - нижняя граница массива
ubound(m) - верхняя граница массива
Соответственно
Цитата Сообщение от EMKorD Посмотреть сообщение
n = m.getlength(0)
s = 0
For i = 1 To n
If m(i) < 0 Then
s = s + 1
End If
Next i
f = s
следует писать так

Visual Basic
1
2
3
4
5
6
7
8
'n = m.getlength(0)
s = 0
For i = lbound(m) To ubound(m)
 If m(i) < 0 Then
  s = s + 1
 End If
Next i
f = s
0
26 / 26 / 10
Регистрация: 30.10.2011
Сообщений: 68
22.12.2011, 22:46  [ТС] 3
Огромное спасибо, так заработало. И всё же, почему не срабатывает m.length? В литературе я нашёл указание на этот параметр и несколько удивлён, что оно не работает.
0
22.12.2011, 22:46
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.12.2011, 22:46
Помогаю со студенческими работами здесь

Invalid object name при попытке создания представления на несколько таблиц
Пример на МСДН: CREATE VIEW Customers AS --Select from local member table. SELECT * FROM...

При попытке вычислить длину строки стандартной функцией strlen возникает ошибка
Есть код, в котором объявлена volatile-переменная c_buf, представляющая собой массив символов: ...

При попытке создать отчет "Error in process (0): OLE object is invalid or corrupted"
Добрый день, при Remote view Wizard в конце создания при предпросмотре выдает ошибку: &quot;Error 1420...

Эксепшн при попытке определить, пустая ли строка
char c1 = '0'; string cout = &quot;0&quot;; int count = 0; int Bdigl = Bdig.Length; ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru