顶层const、底层const,URL,Exception

本文介绍了C++中的顶层const和底层const概念,顶层const表示指针本身不可变,底层const表示指针指向的对象不可修改。接着讲解了URL的构成和示例,并探讨了Java异常处理中Exception与IOException的区别,强调了捕获异常的顺序重要性。

69.顶层const、底层const

顶层const:表示指针本身是常量。
底层const:表示指针所指对象是常量。

70.URL

URL的格式:由4部分组成:协议、主机、端口、路径

URL的一般语法格式为:
带方括号[]的为可选项:
protocol :// hostname[:port] / path / [;parameters][?query]#fragment

举个例子:
String url =“jdbc:mysql://localhost:3306/stu”;
为了防治出现字符编码问题:改为:
String url =“jdbc:mysql://localhost:3306/stu?useUnicode=true&characterEncoding=UTF8”;

71.Exception

使用Exception可以保证捕获异常后能继续维持JVM的运行
如果Exception换成IOException后,一旦出现IO异常,便会捕获停止运行.

“IoException“(流异常,通常用在文件读取中)是”Exception”(用在所有的异常处理中)的一个分支,也就是说“Exception”的范围更大。

解释:通过java中在捕获异常的时候需要先捕获“子异常”(范围小,如流异常),之后在进行捕获总的异常定义“Exception”,如果在此过程中先捕获“Exception”,那么“IoException”将永远执行不到的,所以捕获异常的优先级就是先捕获“IoException”,如果此异常不存在,在捕获“Exception”

``` exec::task<void> net_block_extra_const_process() try { DEBUG_TIME_TRACE_SCOPE(utils::TRACE_TIER::INNER_PROCESS, __FUNCTION__); DEBUG_CAM_TRACE_ASYNC_SCOPE(__FUNCTION__, utils::DEFAULT_TRACE_ID); auto batch_num = fx::capn_algo_settings(e_)->getNet().getGenerateCfg().getPatchNum(); if (!net_cfg_params_.hasModelName()) { throw invalid_params{EXCEPTION_POINT}; } auto &extra_consts = rpr_.extra_net_params->extra_consts; if (patch_buffers_->extra_const_buffer == nullptr) { CAM_LOG_WARNING(__FUNCTION__ << " extra_const_buffer is null"); throw invalid_params{EXCEPTION_POINT}; } if (rpr_.extra_net_params->is_not_extra_const == false) { auto size = extra_consts.size(); if (batch_num <= 0 || size == 0) { throw invalid_params{EXCEPTION_POINT}; } if (net_cfg_params_.getIsQualcommFp16() == false) { auto ecb = static_cast<__fp16 *>(patch_buffers_->extra_const_buffer->getAddress()); errno_t err = memcpy_s(ecb, patch_buffers_->extra_const_buffer->getSize(), extra_consts.data(), size * sizeof(airaw::pre_processing::psf_pred::extrac_const)); if (err != EOK) { CAM_LOG_WARNING(__PRETTY_FUNCTION__ << " memcpy extraConst to buff failed"); throw securec_failed{EXCEPTION_POINT}; } } else { auto ecb = static_cast<float *>(patch_buffers_->extra_const_buffer->getAddress()); for (int i = 0; i < extra_consts.size(); i++) { ecb[i] = extra_consts[i].normal; } } } fx::ops::flush_cc(patch_buffers_->extra_const_buffer); CAM_LOG_INFO(__FUNCTION__ << " extra const success"); co_return; } CATCH_AND_NEST()```解释这个代码内容,并降低函数深度,不要改变原本调用的函数
04-02
``` exec::task<void> net_block_extra_const_process() try { DEBUG_TIME_TRACE_SCOPE(utils::TRACE_TIER::INNER_PROCESS, __FUNCTION__); DEBUG_CAM_TRACE_ASYNC_SCOPE(__FUNCTION__, utils::DEFAULT_TRACE_ID); // 参数有效性检查 validate_parameters(); // 准备常量数据 prepare_extra_constants(); fx::ops::flush_cc(patch_buffers_->extra_const_buffer); CAM_LOG_INFO(__FUNCTION__ << " extra const success"); co_return; } CATCH_AND_NEST() // 参数校验子函数 void validate_parameters() { auto batch_num = fx::capn_algo_settings(e_)->getNet().getGenerateCfg().getPatchNum(); if (!net_cfg_params_.hasModelName()) { throw invalid_params{EXCEPTION_POINT}; } if (!patch_buffers_->extra_const_buffer) { CAM_LOG_WARNING(__FUNCTION__ << " extra_const_buffer is null"); throw invalid_params{EXCEPTION_POINT}; } if (!rpr_.extra_net_params->is_not_extra_const) { if (batch_num <= 0 || rpr_.extra_net_params->extra_consts.empty()) { throw invalid_params{EXCEPTION_POINT}; } } } // 准备常量数据子函数 void prepare_extra_constants() { if (rpr_.extra_net_params->is_not_extra_const) return; auto& extra_consts = rpr_.extra_net_params->extra_consts; const bool is_qualcomm_fp16 = net_cfg_params_.getIsQualcommFp16(); if (is_qualcomm_fp16) { handle_fp32_conversion(extra_consts); } else { handle_fp16_conversion(extra_consts); } } // FP16类型处理 void handle_fp16_conversion(const auto& extra_consts) { auto* ecb = static_cast<__fp16*>(patch_buffers_->extra_const_buffer->getAddress()); const size_t copy_size = extra_consts.size() * sizeof(airaw::pre_processing::psf_pred::extrac_const); if (memcpy_s(ecb, patch_buffers_->extra_const_buffer->getSize(), extra_consts.data(), copy_size) != EOK) { CAM_LOG_WARNING(__PRETTY_FUNCTION__ << " memcpy extraConst to buff failed"); throw securec_failed{EXCEPTION_POINT}; } } // FP32类型处理 void handle_fp32_conversion(const auto& extra_consts) { auto* ecb = static_cast<float*>(patch_buffers_->extra_const_buffer->getAddress()); for (int i = 0; i < extra_consts.size(); ++i) { ecb[i] = extra_consts[i].normal; } }```每个函数的函数深度
04-02
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

半月斩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值