C#中的“定义字符串变量”是啥意思。
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#中的“定义字符串变量”是啥意思。相关的知识,希望对你有一定的参考价值。
请懂的高手以通俗易懂的方法说明一下。
还有什么是全局变量和局部变量。
变量表示数值或字符串值或类的对象。变量存储的值可能会发生更改,但名称保持不变。
再要了解C#中变量的声明方式:
在 C# 中,变量是使用特定数据类型和标签声明的。您必须指定变量是一个 int、一个 float、一个 byte、一个 short 、一个 string等等多种不同数据类型中的任何一种类型。类型可指定应用程序运行时必须分配用于存储值的精确内存量,以及其他信息。
这样你就会明白以下方式声明的变量str就是“字符串变量”:
string str = "";//不管这里的值是什么,str都是字符串变量,这是由string类型决定的
其它类型变量你也需要知道:
int i = 1; //这里的i是整形变量
float f = 0.1f; //这里的f是浮点型变量
byte b = 1; //这里的b是字节变量
short s = 1;//这里的s是短整形变量
其中的int/byte/short三种变量的区别除了定义用的关键字不同外,主要就是取值范围不同
再说全局变量与局部变量,在C/C++等语言中会有这样的“说法”,不过到了C#严格说应该不存在真正的全局变量的,因为C#是完全的面向对象语言,所有定义变量的代码都写在类或结构等中,如果非要分出全局变量与局部变量,你可以按以下代码理解:
class Test
private int globalVar=0;//这个可以认为是这个类的全局变量,因为在这个类的所有方法或属性中都能使用它
public void TestMothed()
int localVar = 0;//这个可以认为是局部变量,因为它只有在TestMothed这个方法内使用
在Asp.net有个“全局”对象Application,实际上这Application本身就是一个类对象,也就是说它也是某个类中的一个变量(C#中又叫属性) 参考技术A 这个问题还真不好怎么回答,因为这已经是最易懂的了。
定义字符串变量 就是
string aaa="My name is vince";
aaa 就是字符串变量名了,属于字符串类型(属于引用类型而不是数值类型)。
全局和局部就是相对的了
比如在一个循环体内部定义的变量只在这个循环内有效,属于局部变量。
而全局变量定义好后,在这个循环体内还可以用。甚至多个循环体内都可以用。 参考技术B string text="字符窜变量";
public int pub=0; //全局变量
class test
int inside=1; //局部变量
全局变量就是 程序里面都可以访问的!
局部变量就是在 某一部分程序里可以用,其它地方用不了!
是啥? JavaScript 中的语法是啥意思?
【中文标题】是啥? JavaScript 中的语法是啥意思?【英文标题】:What does the ?. syntax mean in JavaScript?是什么? JavaScript 中的语法是什么意思? 【发布时间】:2020-06-01 12:11:41 【问题描述】:我在一个 React 项目中遇到了类似 C# 的代码。我无法确认此语法是否正确。我没有找到任何支持这种语法的最新 ES 版本。在当前情况下,我无权执行和检查此代码。
我尝试在浏览控制台中测试此语法并遇到错误:
cart?.widgets?.items.map(widget => (
<div className="billing-details__box" key=widget.id>
<p className="m-0">widget.name</p>
<p className="my-0">widget.value $</p>
</div>
))
我对上述代码的担忧是cart?.widgets?.items
是否会引发任何错误。
【问题讨论】:
Optional chaining 这能回答你的问题吗? Does Typescript support the ?. operator? (And, what's it called?) 这段代码在一个javascript文件中。 你怎么可能修改你无法执行的代码? 【参考方案1】:我无法确认此语法是否正确。
它是正确的 TypeScript 代码,并且是正确的 JavaScript,具体取决于您运行它的引擎。Chrome (V8) 已经支持这种语法(请参阅 caniuse.com)。
您可以在此处阅读更多关于 proposal to add this syntax 未来 JS 规范的信息。
这是什么?
这种语法称为可选链接运算符,它允许您访问对象上可能存在或不存在的属性而无需检查属性是否存在,无论多深属性访问表达式是。
例如,假设我们有这样的对象:
const user =
details:
name: "SpongeBob SquarePants"
,
repo: null
;
我们想得到他们的名字,如果存在的话,还有一些属性user.repo.url
。我们可以使用可选的链接运算符来获取两者,而不必担心repo
是否是一个对象:
console.log(user.details.name) //=> "SpongeBob SquarePants"
console.log(user.repo.url) //=> undefined
它也适用于函数调用。例如,假设user.repo
有一个值,我们知道它将是一个返回字符串的函数。但是,有时,如上所述,它可能不是一个函数。如果函数存在,我们可以执行以下操作来调用该函数,但如果user.repo.url
处的值不是函数,则代码不会抛出错误:
console.log(user.repo?.url()) //=> undefined
没有可选的链接运算符?
您可以通过显式检查您正在访问的属性链中每个对象属性的真实性来实现与可选链接运算符类似的行为。
这可以通过利用 JavaScript 的 short-circuit evaluation 行为来完成,或者更明显的是使用 ternary operator。
看起来像这样:
function getItems_shortCircuit(obj)
return obj && obj.widgets && obj.widgets.items
function getItems_ternary(obj)
return obj
? obj.widgets
? obj.widgets.items
? obj.widgets.items
: null
: null
: null
let cart =
widgets: null
console.log(getItems_shortCircuit(cart)) //=> null
cart.widgets =
items: ["a", "b"]
console.log(getItems_ternary(cart)) //=> ["a", "b"]
我对上述代码的担忧是
cart?.widgets?.items
是否会引发任何错误。
这取决于项目是否使用 TypeScript,它支持开箱即用的optional chaining (?.
)。你可以在TypeScript documentation阅读它。
如果你不使用 TypeScript,那么你必须使用一些 ESNext 编译器来编译你的应用程序,比如 Babel,它有 @babel/plugin-proposal-optional-chaining
plugin。
【讨论】:
你有点错了,可选链实际上已经是正确的 JavaScript 并且在 Chrome 80+(目前是默认版本)和 Firefox 74+(目前是开发版本)中有效现在。但是,如果您针对其他浏览器,您仍然需要进行转译。 caniuse.com/#search=optional%20chaining 是的,我很高兴看到它在本月初在 Chrome 中上线。很好的答案! 我猜对于其他浏览器,babel 会将此代码转换为支持的 javascript 代码 @VirajSingh 这是正确的——只要你使用答案中链接的插件,一旦它被 Babel 编译,你就可以在任何地方使用这个语法。 如果您不知道,nullish coalescing operator??
现在也在 Chome 80+ 和常规 Firefox (72+) 中使用!现在我们只需要 Safari 和 Edge 即可使用该程序!【参考方案2】:
可选链是JS的新特性。
基本上是一样的:
cart && cart.widgets && cart.widgets.items.map(widget => (
<div className="billing-details__box" key=widget.id>
<p className="m-0">widget.name</p>
<p className="my-0">widget.value $</p>
</div>
))
欲了解更多详情,请务必访问V8 guide。
【讨论】:
【参考方案3】:它将由 Babel 编译并且可以工作。 https://babeljs.io/docs/en/babel-plugin-proposal-optional-chaining
【讨论】:
【参考方案4】:这可能是来自 Typescript 的 optional chaining。
【讨论】:
... 和 JavaScript! caniuse.com/#search=optional%20chaining【参考方案5】:它是可选链接,如果您使用 polyfill,它不会导致任何错误。 “?。” - 默认还不支持
【讨论】:
本月起在 Chrome (80+) 和 Firefox Developer Edition (74+) 中支持! caniuse.com/#search=optional%20chaining以上是关于C#中的“定义字符串变量”是啥意思。的主要内容,如果未能解决你的问题,请参考以下文章