在C ++中,* function(arguments ..)和function(arguments)之间有什么区别?(In C++ what is the difference between *function(arguments..) and function(arguments))
我看到了类型的功能:
data_type *function_name(arguments...)
和:
data_type function_name(arguments...)
我正在努力了解应该使用哪一个。 为什么在下面的例子中完成? (这是来自课程的教科书。)我什么时候应该写这些函数?
struct Tower { string name; Tower *link; }; Tower *createTower(string name, Tower *link);
有人可以澄清一下吗?
Tower* createTower(string name, Tower *link) { Tower* tp = new Tower; tp->name = name; tp->link = link; return tp; } Tower* createBeconsOfGondor(){ Tower *tp = createTower("Rohan", NULL); // Points to nothing tp = createTower("Halifiren", tp); // Still returns pointer? }
在createBeconsOfGondor()函数的第二行,该函数的返回如何仍然是一个指针?
I see functions of the type:
data_type *function_name(arguments...)
and:
data_type function_name(arguments...)
I'm trying to learn when which one should be used. Why is this done in the example below? (This is from a textbook for a course.) When should I write functions like these?
struct Tower { string name; Tower *link; }; Tower *createTower(string name, Tower *link);
Further can someone clarify this?
Tower* createTower(string name, Tower *link) { Tower* tp = new Tower; tp->name = name; tp->link = link; return tp; } Tower* createBeconsOfGondor(){ Tower *tp = createTower("Rohan", NULL); // Points to nothing tp = createTower("Halifiren", tp); // Still returns pointer? }
In the second line of the createBeconsOfGondor() function, how is the return of that function still a pointer?
原文:https://stackoverflow.com/questions/30491666
最满意答案
你说比特币地址不应该被重用是对的。
比特币私钥只有一个公钥,但它可以是不同的格式,压缩或未压缩。 例如,私钥
e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855
有一个相应的未压缩公钥
04a34b99f22c790c4e36b2b3c2c35a36db06226e41c692fc82b8b56ac1c540c5bd5b8dec5235a0fa8722476c7709c02559e3aa73aa03918ba2d492eea75abea235
和压缩的公钥
03a34b99f22c790c4e36b2b3c2c35a36db06226e41c692fc82b8b56ac1c540c5bd
对它们进行散列将分别产生地址
1HZwkjkeaoZfTSaJxDw6aKkxp45agDiEzN
和1F3sAm6ZtwLAUnj7d38pGFxtP3RVEvtsbV
。您应该只使用压缩的公共密钥作为未压缩的公钥,膨胀区块链。 话虽如此,因为您只应将其中一个地址用于私钥,这意味着您还应该为每个事务使用不同的私钥。 现在这会产生许多其他问题,例如密钥管理会变得更加麻烦,因为每次要进行事务时都必须生成新的私钥。 您应该查看分层确定性钱包,因为这是一个旨在处理其中一些问题的建立标准。
You are correct in saying that bitcoin addresses should not be reused.
A bitcoin private key only has one public key, but it can be in different formats, compressed or uncompressed. For example, the private key
e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855
has a corresponding uncompressed public key of
04a34b99f22c790c4e36b2b3c2c35a36db06226e41c692fc82b8b56ac1c540c5bd5b8dec5235a0fa8722476c7709c02559e3aa73aa03918ba2d492eea75abea235
and a compressed public key of
03a34b99f22c790c4e36b2b3c2c35a36db06226e41c692fc82b8b56ac1c540c5bd
Hashing them will result in the address
1HZwkjkeaoZfTSaJxDw6aKkxp45agDiEzN
and1F3sAm6ZtwLAUnj7d38pGFxtP3RVEvtsbV
respectively.You should only use compressed publics keys as uncompressed public keys bloat the blockchain. That being said, since you should only use one of those address for a private key, that means you should also use a different private key for every transaction. Now this creates a host of other problems, like key management becomes a lot more troublesome since you have to generate a new private key every time you want to do a transaction. You should look into hierarchical deterministic wallets as that is an establish standard that is meant to deal with some of these issues.
相关问答
更多-
library(hash) h <- hash(y, 1:11) > h[["0"]] [1] 1 > h["0"]
containing 1 key-value pair(s). 0 : 1 > h$"0" [1] 1 library(hash) h <- hash(y, 1:11) > h[["0"]] [1] 1 > h["0"] containing 1 key-value pair(s). 0 : 1 > h$"0" [1] 1 ... -
你说比特币地址不应该被重用是对的。 比特币私钥只有一个公钥,但它可以是不同的格式,压缩或未压缩。 例如,私钥e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 有一个相应的未压缩公钥04a34b99f22c790c4e36b2b3c2c35a36db06226e41c692fc82b8b56ac1c540c5bd5b8dec5235a0fa8722476c7709c02559e3aa73aa03918ba2d492eea75abe ...
-
似乎,假设我甚至是正确的ECC的这个属性是可能的,互联网的开源角似乎试图说服我是假的,即使我自己使用它,它是可能是专利的,所以我放弃了,只是做了线性扩展。 It seems like, under the assumption that I'm even correct that this property of ECC is possible, which the open-source corner of the internet seems to be trying to convince me is ...
-
这些实际的公钥是: 02:77:83:04:A9:B8:B9:B2:9B:BF:48:71:83:38:64:87 4A:00:23:C5:8A:15:3B:35:1F:3F:D0:AB:29:7A:AB:1C C3 和 02:D4:2B:E4:13:D3:D3:8A:64:FD:1A:2B:EA:E2:06:46 A1:0A:78:1F:1D:C0:8B:5E:47:CA:7F:AF:E3:65:EE:1A A5 这些都不一样,所以没有明显的理由担心这方面。 相同的数据是关键的元数据和编码bumf( ...
-
以最简单的形式,公钥密码被用于单向通信。 如果Alice有一个公钥/私钥对,并且她将公钥发给每个人,那么任何人都可以使用Alice的公钥对消息进行加密,只有Alice可以使用她的私钥解密。 Alice不使用她的私人密钥来加密消息供他人阅读。 对于双向安全通信,公钥密码通常用于传输双方可用于安全通信的会话密钥。 让我们说鲍勃想和爱丽丝谈谈。 通过Alice的公钥,Bob使用它来加密一个密钥并将其发送给Alice。 Alice然后使用她的私钥来解密密钥。 现在秘密密钥只有Alice和Bob知道。 因此,他们都可 ...
-
RSAKeyValue,Modulus和Exponent标签位于那里,因为您使用了方法ToXmlString() 。 RSA公钥由模数和公共指数组成。 分发这两个项目没有安全问题。 但是,您不希望在私钥中分发任何其他项目。 私钥包含以下字段:
… … …
…
… … … 智威汤逊未使用RSA等非对称密码进行签名。 它使用HMAC ,它使用单个密钥。 实际上,这里的重点不是要向其他人证明您签署了令牌。 这是为了向你自己证明你签署了它,并因此禁止任何没有你的密钥修改令牌的人。 The JWT isn't signed using an asymmetric cipher like RSA. It uses a HMAC, which uses a single, secret key. Indeed, the point here is not to prove to some ...在Powershell中对Windows Server 2012 PKI进行身份验证(Authentication in Powershell to windows server 2012 PKI)[2023-06-17]
我解决了直接在服务器上启动脚本的问题。 不是最好的解决方案,但我设法在Powershell中使用远程会话 I solved my issue in launching my script directly on the server. Not the best solution, but I neevr managed to use Remote Session in Powershell看起来local_key假设你的密钥存储在〜/ .ssh中(这是一个合理的假设)。 默认情况下,它假定该文件名为id_rsa.pub,因此如果您重命名该文件,则需要将该名称传递给local_key。 我没有使用过这个软件包但总是记得那些明智的话“Hack-R 查看源代码 ” It looks like local_key is assuming your key is stored in ~/.ssh (which is a reasonable assumption). By default it ass ...为什么Hadoop使用Kerberos而不是PKI / OAuth进行身份验证?(Why Hadoop uses Kerberos instead of PKI/OAuth for authentication?)[2022-03-06]
您可能会发现以下链接很有用: https : //issues.apache.org/jira/secure/attachment/12428537/security-design.pdf 更新:文档说“......我们选择基于SSL的Kerberos,原因如下:1。更好的性能Kerberos使用对称密钥操作,比SSL使用的公钥操作快几个数量级.2。更简单的用户管理例如通过简单地从集中管理的Kerberos KDC(密钥分发中心)删除用户,可以完成撤销用户。而在SSL中,必须生成新的证书撤销列表并将其传播到 ...相关文章
更多- error C2668: 'M' : ambiguous call to overloaded function
- function-Oceanus配置说明
- 两种js function 声明方式
- 《标准C/C++编程系列视频教程》共17天/更新完毕[压缩包]
- 《C/C++图像处理编程》扫描版[PDF]
- 谁给推荐一个C++的JSON库
- 《上海交大C++面向对象》[RMVB]
- 《新版 Visual C++全能速查宝典》扫描版[PDF]
- C++ Hadoop实战备忘
- java server怎样和c++ client实现SSL通信??
最新问答
更多- 您如何使用git diff文件,并将其应用于同一存储库的副本的本地分支?(How do you take a git diff file, and apply it to a local branch that is a copy of the same repository?)
- 将长浮点值剪切为2个小数点并复制到字符数组(Cut Long Float Value to 2 decimal points and copy to Character Array)
- OctoberCMS侧边栏不呈现(OctoberCMS Sidebar not rendering)
- 页面加载后对象是否有资格进行垃圾回收?(Are objects eligible for garbage collection after the page loads?)
- codeigniter中的语言不能按预期工作(language in codeigniter doesn' t work as expected)
- 在计算机拍照在哪里进入
- 使用cin.get()从c ++中的输入流中丢弃不需要的字符(Using cin.get() to discard unwanted characters from the input stream in c++)
- No for循环将在for循环中运行。(No for loop will run inside for loop. Testing for primes)
- 单页应用程序:页面重新加载(Single Page Application: page reload)
- 在循环中选择具有相似模式的列名称(Selecting Column Name With Similar Pattern in a Loop)
- System.StackOverflow错误(System.StackOverflow error)
- KnockoutJS未在嵌套模板上应用beforeRemove和afterAdd(KnockoutJS not applying beforeRemove and afterAdd on nested templates)
- 散列包括方法和/或嵌套属性(Hash include methods and/or nested attributes)
- android - 如何避免使用Samsung RFS文件系统延迟/冻结?(android - how to avoid lag/freezes with Samsung RFS filesystem?)
- TensorFlow:基于索引列表创建新张量(TensorFlow: Create a new tensor based on list of indices)
- 企业安全培训的各项内容
- 错误:RPC失败;(error: RPC failed; curl transfer closed with outstanding read data remaining)
- C#类名中允许哪些字符?(What characters are allowed in C# class name?)
- NumPy:将int64值存储在np.array中并使用dtype float64并将其转换回整数是否安全?(NumPy: Is it safe to store an int64 value in an np.array with dtype float64 and later convert it back to integer?)
- 注销后如何隐藏导航portlet?(How to hide navigation portlet after logout?)
- 将多个行和可变行移动到列(moving multiple and variable rows to columns)
- 提交表单时忽略基础href,而不使用Javascript(ignore base href when submitting form, without using Javascript)
- 对setOnInfoWindowClickListener的意图(Intent on setOnInfoWindowClickListener)
- Angular $资源不会改变方法(Angular $resource doesn't change method)
- 在Angular 5中不是一个函数(is not a function in Angular 5)
- 如何配置Composite C1以将.m和桌面作为同一站点提供服务(How to configure Composite C1 to serve .m and desktop as the same site)
- 不适用:悬停在悬停时:在元素之前[复制](Don't apply :hover when hovering on :before element [duplicate])
- 常见的python rpc和cli接口(Common python rpc and cli interface)
- Mysql DB单个字段匹配多个其他字段(Mysql DB single field matching to multiple other fields)
- 产品页面上的Magento Up出售对齐问题(Magento Up sell alignment issue on the products page)