This is an automated email from the ASF dual-hosted git repository. yiguolei pushed a commit to branch master in repository https://gitbox.apache.org/repos/asf/doris.git
The following commit(s) were added to refs/heads/master by this push: new 29d4809c80 [BugFix](Array) fix DataTypeArray to_string use after free (#10640) 29d4809c80 is described below commit 29d4809c80550ab7c864b415da1d95fb28b4793a Author: lihangyu <15605149...@163.com> AuthorDate: Wed Jul 6 18:18:00 2022 +0800 [BugFix](Array) fix DataTypeArray to_string use after free (#10640) ColumnArray::convert_to_full_column_if_const override the base function and ColumnArray::create generate a temporary variable --- be/src/vec/data_types/data_type_array.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/be/src/vec/data_types/data_type_array.cpp b/be/src/vec/data_types/data_type_array.cpp index 40aa07011b..4c459ed4b8 100644 --- a/be/src/vec/data_types/data_type_array.cpp +++ b/be/src/vec/data_types/data_type_array.cpp @@ -96,8 +96,8 @@ void DataTypeArray::to_pb_column_meta(PColumnMeta* col_meta) const { } void DataTypeArray::to_string(const IColumn& column, size_t row_num, BufferWritable& ostr) const { - auto& data_column = - assert_cast<const ColumnArray&>(*column.convert_to_full_column_if_const().get()); + auto ptr = column.convert_to_full_column_if_const(); + auto& data_column = assert_cast<const ColumnArray&>(*ptr.get()); auto& offsets = data_column.get_offsets(); size_t offset = offsets[row_num - 1]; @@ -115,8 +115,8 @@ void DataTypeArray::to_string(const IColumn& column, size_t row_num, BufferWrita } std::string DataTypeArray::to_string(const IColumn& column, size_t row_num) const { - auto& data_column = - assert_cast<const ColumnArray&>(*column.convert_to_full_column_if_const().get()); + auto ptr = column.convert_to_full_column_if_const(); + auto& data_column = assert_cast<const ColumnArray&>(*ptr.get()); auto& offsets = data_column.get_offsets(); size_t offset = offsets[row_num - 1]; @@ -183,4 +183,4 @@ Status DataTypeArray::from_string(ReadBuffer& rb, IColumn* column) const { return Status::OK(); } -} // namespace doris::vectorized \ No newline at end of file +} // namespace doris::vectorized --------------------------------------------------------------------- To unsubscribe, e-mail: commits-unsubscr...@doris.apache.org For additional commands, e-mail: commits-h...@doris.apache.org