标签: input-parameters

关于输入参数的顺序

对于函数/方法包含许多输入参数,如果以不同的顺序传入它会有所不同吗?如果是,在哪些方面(可读性,效率......)?我更好奇我应该如何为自己的功能/方法做些什么?

在我看来,这:

  1. 通过引用/指针传递的参数通常在通过值传递的参数之前.例如:

    void* memset( void* dest, int ch, std::size_t count ); 
    
    Run Code Online (Sandbox Code Playgroud)
  2. 目标参数通常在源参数之前.例如:

    void* memcpy( void* dest, const void* src, std::size_t count );
    
    Run Code Online (Sandbox Code Playgroud)
  3. 除了一些硬约束之外,即具有默认值的参数必须是最后的.例如:

    size_type find( const basic_string& str, size_type pos = 0 ) const;
    
    Run Code Online (Sandbox Code Playgroud)
  4. 无论他们传递的是什么顺序,它们都是功能等同的(实现相同的目标).

c c++ performance code-readability input-parameters

17
推荐指数
1
解决办法
4065
查看次数

在过程中键入输入参数的datetime

我已经创建了一个具有此结构的过程,但它不适用于datetime输入参数

我执行了这个查询但是

declare @a datetime
declare @b datetime 

set @a='2012/04/06 12:23:45'
set @b='2012/08/06 21:10:12'

exec LogProcedure 'AccountLog', N'test', @a, @b
Run Code Online (Sandbox Code Playgroud)

但是SQL Server让我犯了这个错误

从字符串转换日期和/或时间时转换失败.

但是,当我使用此查询进行测试时,它可以工

  exec LogProcedure 'AccountLog',N'test'
Run Code Online (Sandbox Code Playgroud)

存储过程代码:

alter PROCEDURE LogProcedure
    @TableName VARCHAR(60),
    @SearchString NVARCHAR(50),
    @DateFirst DateTime = '',
    @DateLast DateTime = ''
AS
BEGIN
    SET NOCOUNT ON

    DECLARE @FinalSQL      NVARCHAR(MAX)

    SET @FINALSQL = 'SELECT * FROM [' + @TableName + '] where 1=2  '

    IF @DateFirst <> '' and @DateLast <> ''
       set @FinalSQL  = @FinalSQL + …
Run Code Online (Sandbox Code Playgroud)

datetime stored-procedures sql-server-2008 input-parameters

14
推荐指数
1
解决办法
12万
查看次数

将参数从DbCommand复制到另一个DbCommand

如何将DbCommand参数复制到另一个DbCommand,我想要一个DbCommand与我的上一个参数相同的新参数DbCommand.但现在使用不同的sql字符串.

.net c# enterprise-library dbcommand input-parameters

9
推荐指数
1
解决办法
7754
查看次数

如何将Swift字符串传递给ac函数?

我在将字符串从swift传递到用c编写的函数时遇到了很大的麻烦。

我想在我的快速代码中做到这一点

var address = "192.168.1.2"
var port = 8888

initSocket(address, port)
Run Code Online (Sandbox Code Playgroud)

c函数如下所示:

void initSocket(char *address, int port);
Run Code Online (Sandbox Code Playgroud)

我收到错误消息:无法将'Void'类型的表达式转换为'CMutablePointer'类型

我似乎找不到有效的解决方案。

c xcode input-parameters swift

5
推荐指数
1
解决办法
2197
查看次数

SOAP信封中的WCF和输入参数顺序

我在我的WCF Web服务中使用webHttpBinding(soap 1.1)得到一个Object引用未设置为对象错误的实例我注意到如果你按照特定顺序输入参数,则不会引发错误.

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:not="http://schemas.globalfoundries.com/NotificationService">
   <soapenv:Header/>
   <soapenv:Body>
      <not:NotifyWorkflowItemUpdate>
         <not:userIDs>testUserID</not:userIDs>
         <not:taskID>testTaskID</not:taskID>
         <not:taskType>testTaskType</not:taskType>
         <not:status>testStatus</not:status>
         <not:appID>testAppID</not:appID>
         <not:message>testMessage</not:message>
      </not:NotifyWorkflowItemUpdate>
   </soapenv:Body>
</soapenv:Envelope>
Run Code Online (Sandbox Code Playgroud)

但是,如果我更改请求模板中输入参数的顺序,我会得到上述错误.ie(注意消息和userIDs参数被切换)

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:not="http://schemas.globalfoundries.com/NotificationService">
   <soapenv:Header/>
   <soapenv:Body>
      <not:NotifyWorkflowItemUpdate>
     <not:message>testMessage</not:message>
         <not:taskID>testTaskID</not:taskID>
         <not:taskType>testTaskType</not:taskType>
         <not:status>testStatus</not:status>
         <not:appID>testAppID</not:appID>
         <not:userIDs>testUserID</not:userIDs>
      </not:NotifyWorkflowItemUpdate>
   </soapenv:Body>
</soapenv:Envelope>
Run Code Online (Sandbox Code Playgroud)

为什么会这样?请求参数是否通过订单而不是名称映射到.Net方法参数?是否有必须在服务合同上指定的属性才能使命名参数映射成为可能?

wcf soap request input-parameters

5
推荐指数
2
解决办法
4932
查看次数

How do I use MATLAB's inputParser with optional string inputs? The documentation says "use a validation function" but it's unclear how to do that

I have a MATLAB file that contains a single top-level function, called sandbox. That function in turn contains two nested functions, mysum and myprod, which are identical in functionality and what parameters they allow except that one uses @sum internally and the other uses @prod internally. My goal is to create a wrapper function to use in both mysum and myprod that takes care of all the validation and input parsing. This function is called applyFunc.

Here's …

validation matlab function optional-arguments input-parameters

5
推荐指数
1
解决办法
5019
查看次数

如何测试 PHP 按位函数输入参数

有时在编程中,它们允许将参数链接到单个函数输入变量中,例如下面的第二个输入变量:

define('FLAGA',40);
define('FLAGB',10);
define('FLAGC',3);
function foo($sFile, $vFlags) {
  // do something
}
foo('test.txt',FLAGA | FLAGB | FLAGC);
Run Code Online (Sandbox Code Playgroud)

PHP 将此单个管道字符(|)称为按位OR运算符。我现在如何在里面添加一些东西foo()来测试$vFlags以查看设置了哪些标志?

php bit-manipulation bitwise-operators input-parameters bitwise-or

3
推荐指数
1
解决办法
1000
查看次数

如何传递 ENUM 变量作为 POSTGRESQL 函数的输入

我在 MySQL 中有一个运行良好的函数:

CREATE  PROCEDURE `Accounts_Active`(IN_DeptName VARCHAR(255), IN_Src ENUM('TRAINING','ELZA'))
BEGIN
END$$
DELIMITER ;
Run Code Online (Sandbox Code Playgroud)

但是当转换为 PostgreSQL 时:

CREATE or replace FUNCTION Accounts_Active(IN_DeptName VARCHAR(255), IN_Src ENUM('TRAINING','ELZA'))
RETURNS void
AS
$$
BEGIN
      RAISE INFO '    ';
END;
$$ LANGUAGE plpgsql;
Run Code Online (Sandbox Code Playgroud)

出现以下错误:

ERROR:  type enum does not exist
SQL state: 42704
Run Code Online (Sandbox Code Playgroud)

任何有关如何修复此错误的指导将不胜感激。

postgresql enums function input-parameters

3
推荐指数
1
解决办法
3278
查看次数