gpt4 book ai didi

c - 等价于 Julia 语言中的 C 编程语法 "#define"

转载 作者:太空宇宙 更新时间:2023-11-04 03:21:29 24 4
gpt4 key购买 nike

在 C 编程语言中,#define 指令允许在源代码中定义宏。这些宏定义允许声明常量值以在整个代码中使用。

宏定义不是变量,不能像变量一样被程序代码改变。我们通常在创建表示数字、字符串或表达式的常量时使用此语法。像这样

#include <stdio.h>

#define NAME "Jack"
#define AGE 10

int main()
{
printf("%s is over %d years old.\n", NAME, AGE);
return 0;
}

美妙之处在于,如果我的代码中有多个函数,我不需要将常量变量输入到每个函数中,编译器只需用过程值替换定义的表达式。 p>

现在我的问题是:在 Julia 编程中是否有与此等效的命令?

例如

density = 1 # somehow a defined variabe.
function bar(g)
t = density +g
end
function foo()
r = dencity + 2
end

main()
g = 10;
foo()
bar(g)
end

最佳答案

可以在 Julia 中使用模拟 C #define 行为。

macro NAME()
return :("Jack")
end

macro AGE()
return :(10)
end

在 Julia REPL 中,输入 @NAME 将返回 "Jack"

julia> @NAME
"Jack"

julia> @AGE
10

为了安全起见,请记住将宏调用括在括号中,例如,

julia> println("Hello ", (@NAME))
Hello Jack

julia> println(@NAME * " is " * repr(@AGE) * " years old")
ERROR: syntax: "*" is not a unary operator

julia> println((@NAME) * " is " * repr(@AGE) * " years old")
Jack is 10 years old

但这真的有必要吗? Julia 中惯用的方式是定义全局 const 变量。尽管文档出于性能原因不鼓励使用全局变量,但像这样的宏对性能没有帮助,您可以从 LLVM 代码中看出这一点。

macro NAME()
return :("Jack")
end

const name = "Jack"

function f_hello_global()
println("Hello ", name)
end

function f_hello_macro()
println("Hello ", (@NAME))
end

对于像这样的微不足道的函数,您会发现 LLVM 代码看起来完全一样(太长;此处未显示)。

julia> @code_llvm f_hello_global()
. . .

julia> @code_llvm f_hello_macro()
. . .

编辑:顺便说一下,我认为如果您需要 使用全局变量,那么就使用它。 Julia 文档(当前稳定版本:0.6.2)中的论点是它有时可能会降低性能。然而,想象一下,如果一个常量用于分布在 20 个模块中的 100 个函数中,您是愿意将同一行代码编写 100 次并煞费苦心地检查各个模块中的数字是否一致,还是您会定义一次并在所有模块中使用它地方?我认为正确使用全局常量可以使代码干净且易于维护,而且这种担忧往往会战胜性能上的小幅提升。

关于c - 等价于 Julia 语言中的 C 编程语法 "#define",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45663692/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com