Interesting, I've never noticed that.  (I insist on the parentheses in
  my code, so always use Call.)
   
  You get a syntax error when you compile the two parameter Sub reference.
  However, when you type it in (in 2003), you get "Expected: =".  Looks as
  though it's syntax-checking my "bb(1, 2)" as an index into an array bb,
  even though there isn't one, and there's definitely a Sub bb.
  Interestingly, this happens even if Sub bb appears in the code of the
  module before the call to it.
   
  I changed the statement to "bb(1, 2) = 1" and this generates an
  "Expected Function or variable" error.  So it could also be expecting bb
  to be a Function, returning a Variant or Object, that would allow it to
  be used on the left of the equals.
   
  > Does anyone know why the single argument works
  > with a parentheses?
  
  Or the converse, why you can't do it for multiple arguments ...
   
  Flaky syntax analysis, I suspect.  I wonder if it's fixed in 2007 or
  2010.
   
  ==================================================
   
  Aha ... just found something in
  http://stackoverflow.com/questions/479891/what-does-the-call-keyword-do-
  in-vb6
   
  Try the following code
   
  Option Explicit
   
  Sub tester()
    Dim a As String: a = "Original"
    Call Test(a)
    Dim b As String: b = "Original"
    Test b
    Dim c As String: c = "Original"
    Test (c)
    Range("A1").Value = "a = " & a & ", b = " & b & ", c = " & c
  End Sub
   
  Sub Test(ByRef param As String)
    param = "Test changed it"
  End Sub
  
  Result is: a = Test changed it, b = Test changed it, c = Original
   
  so we have it.
   
  The call with no Call and the single parameter in parentheses is
  evaluating the (c) as a string expression.  The call with a Call passes
  a as a byref variable.  The call with no Call and no parentheses b as a
  byref variable.
   
  So my "bb(1, 2)" fails because it attempts to evaluate "(1, 2)" as a
  string expression, which is bad syntax.  It possibly also attempts to
  interpret "bb(1, 2)" as an array reference and also as a function call,
  but it gives up and can't decide what the problem is ... hence "Syntax
  error".
  
  Regards, Dave S 
  
  ________________________________
  
  From: ExcelVBA@yahoogroups.com [mailto:ExcelVBA@yahoogroups.com] On
  Behalf Of mickey11030
  Sent: Friday, 14 December 2012 13:18
  To: ExcelVBA@yahoogroups.com
  Subject: [ExcelVBA] Using Parentheses in Subroutine Calls
  
  The rule is that if you call a subroutine using the Call keyword, you
  must enclose the argument list in parentheses. That is
  Call Test(a, b)
  is correct. But if you omit Call, you must not use parentheses, so that
  Test a, b
  is also correct. I didn't know these rules, and, from habit, I do not
  use Call and do use parentheses. I got away with that for a long time
  because my subroutines used only 1 argument. Surprisingly,
  Test (c)
  works even though it violates the rule. I got into trouble only when I
  wrote a subroutine that used 2 arguments.
  Test (c, d)
  causes a syntax error. Does anyone know why the single argument works
  with a parentheses?
  
  [Non-text portions of this message have been removed]
  
  ----------
  
  Visit our website at http://www.ubs.com
  
  This message contains confidential information and is intended only 
  for the individual named.  If you are not the named addressee you 
  should not disseminate, distribute or copy this e-mail.  Please 
  notify the sender immediately by e-mail if you have received this 
  e-mail by mistake and delete this e-mail from your system.
  	
  E-mails are not encrypted and cannot be guaranteed to be secure or 
  error-free as information could be intercepted, corrupted, lost, 
  destroyed, arrive late or incomplete, or contain viruses.  The sender 
  therefore does not accept liability for any errors or omissions in the 
  contents of this message which arise as a result of e-mail transmission.  
  If verification is required please request a hard-copy version.  This 
  message is provided for informational purposes and should not be 
  construed as a solicitation or offer to buy or sell any securities 
  or related financial instruments.
  
  UBS reserves the right to retain all messages. Messages are protected
  and accessed only in legally justified cases.
  
  [Non-text portions of this message have been removed]
  
  
| Reply via web post | Reply to sender | Reply to group | Start a New Topic | Messages in this topic (2) | 
Be sure to check out TechTrax Ezine for many, free Excel VBA articles! Go here: http://www.mousetrax.com/techtrax to enter the ezine, then search the ARCHIVES for EXCEL VBA.
----------------------------------
Visit our ExcelVBA group home page for more info and support files:
http://groups.yahoo.com/group/ExcelVBA
----------------------------------
More free tutorials and resources available at:
http://www.mousetrax.com
----------------------------------
 
Tidak ada komentar:
Posting Komentar