| |

VerySource

 Forgot password?
 Register
Search
View: 4865|Reply: 25

Discussion: Is template technology just a class library?

[Copy link]

1

Threads

3

Posts

4.00

Credits

Newbie

Rank: 1

Credits
4.00

 China

Post time: 2020-1-18 19:20:01
| Show all posts |Read mode
Boost, stl, loki, all use templates a lot, everyone learned templates, is it just to look at those libraries. Who can use it in enterprise applications, for example, constructing a paradigmatic inventory library, or in other words, paradigms have no use in the high-end field?
Reply

Use magic Report

0

Threads

24

Posts

7.00

Credits

Newbie

Rank: 1

Credits
7.00

 China

Post time: 2020-1-25 10:27:01
| Show all posts
Is template technology just a class library?
-------------------------------------------------- -----------------------------------
A few of my friends also discussed this issue in private, ...
Reply

Use magic Report

0

Threads

24

Posts

7.00

Credits

Newbie

Rank: 1

Credits
7.00

 China

Post time: 2020-1-25 11:18:01
| Show all posts
I think generics are just a solution to a need, if you have that need, you can use it.
Reply

Use magic Report

0

Threads

36

Posts

13.00

Credits

Newbie

Rank: 1

Credits
13.00

 China

Post time: 2020-1-25 11:54:01
| Show all posts
Is a representative of the academic school,
But it represents the future of language development
It takes a long time from academic to engineering application
It is suggested that the landlord can look at the relevant reports of the 0x standard to know some situations.
Reply

Use magic Report

0

Threads

78

Posts

29.00

Credits

Newbie

Rank: 1

Credits
29.00

 China

Post time: 2020-1-25 15:54:01
| Show all posts
You have to be happy
Isn't it okay to write one yourself?
No one is forbidden ~~~~~
Reply

Use magic Report

0

Threads

11

Posts

9.00

Credits

Newbie

Rank: 1

Credits
9.00

 Invalid IP Address

Post time: 2020-1-25 17:27:02
| Show all posts
. . . The basic purpose of template is source level re-use, and source level re-use is only a (partial) feature of library. The application emphasizes delivery the functionality to the user, as to what technology and means are not important.
Reply

Use magic Report

0

Threads

4

Posts

4.00

Credits

Newbie

Rank: 1

Credits
4.00

 China

Post time: 2020-1-26 13:45:01
| Show all posts
Cheeky to post the discussion of friends, I hope friends do not mind
A:
To start a discussion, I'll start with a brick. Today I saw the section on implementing Functor in the new thinking of C ++ design. I feel that GP is more suitable for class library design than system design.
First of all, talk about the advantages of GP. I personally think that the main advantages of GP are code reuse, execution efficiency, type safety, and ease of use. And this is exactly what the class library design needs. As a large system, code reuse is less important. The key is to reduce the complexity of the design, reduce the difficulty of maintenance, and scalability.
Personally, I think the GP is not doing well in this regard. As far as design is concerned, it is difficult to write good generic code. Too much consideration of using GP to make the code reusable will increase the complexity of the design. The maintainability of generic code is not as good as OO, especially those more sophisticated generic code, it takes a long time to understand.
Secondly, GP will not only increase the complexity of system design. As for designing class libraries, it is more difficult to use GP. Personally, one of the reasons for the difficulty in designing C ++ class libraries is not the multi-paradigm of C ++, but because of the class. Library design is overly enthusiastic about GP.
In terms of reusability, it is incomplete to say that GP has better reusability. The reusability of GP is reflected in the fact that various types can simply reuse components in some class libraries as long as they meet certain requirements. There is no advantage to those functional reuse. For example, I need an FTP class for data transmission. For the reuse of FTP class, GP has no advantage.
As far as execution efficiency is concerned, it is also the class library design that is more concerned. For system design, according to the two and eight theorems, the efficiency improvement brought by GP is not too important.
B:
As a large system, code reuse is less important
---
I don't agree with this. If you don't reuse, it will produce a lot of duplicate, similar code, which is a very serious problem, which has a great adverse impact on development efficiency, product quality, and difficulty of maintenance.

It is difficult to write high-quality GP code, but I think that any degree of reuse requires a degree. If you talk about writing GP code, you must be able to cross-platform, have high efficiency, and have good behaviors for various types. , Wait, I'm afraid few people can accomplish this. Not only is GP difficult, even OO is even harder.

There is no conflict between OO and GP. It depends on where they are applicable. GP is suitable for writing libraries. It is difficult to write libraries. In particular, efficiency and elegance of design are often contradictory. GP can achieve a better balance.
 
A:
Any reuse requires a degree. If you write GP code, you must be able to cross-platform, have high efficiency, and have good behaviors for various types, etc. I am afraid few people can accomplish this. Not only is GP difficult, even OO is even harder.
------------------------------------------
Agree, I just want to know the application level of GP in actual work. For me, it feels a little difficult to combine GP and OO programming. Represent different modes of thinking. I personally think that GP is an abstraction of the relationship between objects and behaviors, and OO is an abstraction of the relationship between objects and objects. It feels that OO is very important to encapsulate the data and behavior of the object, but GP is to separate the type and behavior. Although this is not contradictory, and I don't like pure OO, I feel that it is difficult to program the combination of the two (this may be my own reason, and my own programming experience is seriously inadequate :)) Of course, there are a lot of Encapsulation and inheritance are used, but I personally think that this is not a combination of OO and GP programming.
The topic is far away :), I want to ask whether GP can reduce the complexity of large-scale system design. Although there is no "silver bullet" in software engineering, I feel that OO does reduce the complexity of system design to a certain extent. Considering GP in system design will increase complexity.
The power of GP in the design of class libraries is obvious to all. This is not only reflected in the design of low-level applications. For GUI libraries such as WTL, the compiled program size is much smaller than the MFC program with the same function. It feels easier to use.
I personally feel that GP is more like a small framework, but it is a bit inappropriate. It provides the basic framework of tools and generation tools, and OO is more suitable for system development on this basis.
My personal humble opinion, once again drew a lot of attention :)
 
-------------------------------------------------- -------------------------------------------------- -------------------------------------- B:
I feel exactly the opposite of you :) I think OO will increase complexity and GP can reduce complexity.
Class inheritance will become more complicated in the future. The inheritance relationship is a very strong coupling. Good design avoids abuse of inheritance. GP decouples types, which is a higher level of abstraction than OO. This is of great benefit to reduce the complexity of the entire system (of course, the GP technology itself seems to be much more complicated than OO).
When you say that GP is like a small framework, I don't agree with it. I think GP is more like a very independent "component". It can be used by assembling it and has great flexibility. Not as rigid as the so-called framework.
Speaking of actual work, I am afraid that there are not many opportunities to use GP. Didn't you read the discussion on verysource, even STL was not allowed, because I was afraid that others in the group could not understand it. . . Although I disagree with this view, the reality is that there are only a few C ++ programmers who know GP.
The combination of OO and GP ideas you said is difficult. After all, it is still a matter of degree. When it should be separated, it should be separated. When it is encapsulated, the design of std :: string is not as big as Daniel said that it is too. Are you fat? Many member functions can be separated. But there are still many people who say that the functions it seals are too few and are not easy to use. It can be seen that it is really difficult to grasp this degree. Different users, different levels, different views.
 
B:
In addition, regarding the design of the string, I think that we should minimize the member functions of the string class, reuse the functions that can decouple the types, and then write a fat_string to combine the string class, plus all members that are convenient for users. Functions, the internal implementation can use those independent reuse functions. This can meet the needs of different users.
 
A:
Class inheritance levels will become more complicated in the future. The inheritance relationship is a very strong coupling. Good design avoids abuse of inheritance.
--------------------------------------
Agree, OO is most commonly used for encapsulation, not for derivation, and too many levels of inheritance can cause unmanageable complexity. However, proper control of the inheritance level, and the use of inheritance in a reasonable place can control the complexity. If inheritance is used, it is likely to require polymorphism. For example, when dealing with a collection of heterogeneous objects, individuals decide that OO should do better.
#include <iostream>
#include <vector>
#include <boost / shared_ptr.hpp>

using namespace std;
using namespace boost;

class IBASE
{
public:
    virtual void doSomething () const = 0;
virtual ~ IBASE () {};
};

class DeA: public IBASE
{
public:
void doSomething () const {cout << "DeA" << endl;}
};

class DeB: public IBASE
{
public:
void doSomething () const {cout << "DeB" << endl;}
};

int main ()
{
typedef vector <shared_ptr <IBASE>> IBASEVec;

IBASEVec vec;
vec.push_back (shared_ptr <IBASE> (new DeA));
vec.push_back (shared_ptr <IBASE> (new DeB));
     
for (IBASEVec :: iterator iter = vec.begin ();
iter! = vec.end ();
++ iter)
{
(* iter)-> doSomething ();
}

}
Reply

Use magic Report

3

Threads

10

Posts

10.00

Credits

Newbie

Rank: 1

Credits
10.00

 China

Post time: 2020-1-26 14:45:01
| Show all posts
Template metaprogramming
A hack
Not highly recommended
Typical space for time
Reply

Use magic Report

0

Threads

4

Posts

4.00

Credits

Newbie

Rank: 1

Credits
4.00

 Canada

Post time: 2020-1-26 15:09:01
| Show all posts
This is an example of dynamic polymorphism
 
#include <iostream>
#include <vector>

using namespace std;

class DeA
{
public:
void doSomething () const {cout << "DeA" << endl;}
};

class DeB
{
public:
void doSomething () const {cout << "DeB" << endl;}
};

template <typename T>
void DoSomething (vector <T> vec)
{
for (vector <T> :: iterator iter = vec.begin ();
iter! = vec.end ();
++ iter)
{
   iter-> doSomething ();
}
}

int main ()
{
typedef vector <DeA> DEAVEC;
typedef vector <DeB> DEBVEC;

DEAVEC va;
DEBVEC vb;

va.push_back (DeA ());
va.push_back (DeA ());
     
vb.push_back (DeB ());
vb.push_back (DeB ());

DoSomething (va);
DoSomething (vb);
}


This is an example of static polymorphism
Personally, it is more natural to use dynamic polymorphism to handle heterogeneous object collections.
First, conceptually, the responsibility of calling doSomething is IBASE (IBASE only knows what to do, and the above method breaks this encapsulation relationship). In order to process different objects, a vector must be created for these objects to save. Dealing with heterogeneous collections of objects is exactly what a build system often does.
 
Hehe wrote, and found it difficult to justify it :)

GP decouples types, a higher level of abstraction than OO
-------------------------------------------------- ------
I just wrote the code and gradually understood it. This makes sense. For example, there is a human and a dog, they all have the action of eating. If you introduce an animal base class to them in order to handle this action, it does feel that it increases the coupling. It is obviously worthwhile to add a base class just for the same behavior. It might be better to abstract these behaviors. (In the future, if you want to deal with a creature like a herbivore,
You can reuse the code directly without introducing a nondescript base class :))
It seems that his belief has begun to shake.

You said that GP is like a small framework, and I do n’t agree with it. I think GP is more like a very independent "component"
-------------------------------------------------- -------------------------------------------------- -------
For example, if you want to make a container that can use the STL algorithm, you must provide some traits when designing its iterator.
I feel this is a bit similar to the framework. But there are big and not so, so it feels a bit inappropriate to compare GP to a small framework.

Isn't std :: string designed to say it's too fat?
-------------------------------------------------- -------------------------------------------------- -----
As if Herb Sutter said, Scott Meyer also said that reusable functions should be separated from member functions when appropriate.
I also agree with this point, which is why I don't like pure OO :)
 
C:
Both object-oriented and generic programming pursue the beauty of [reuse], which is the soul of software engineering.
However, they [reuse] differently: object-oriented focuses on [multiplexing] at the binary level, and generics focuses on [multiplexing] at the source code level.

The so-called excellent program library exists for use by engineering; the so-called excellent project is known for its beautiful [reusable] program library. In my opinion, the difference between engineering and libraries is not as big as expected, but it is appropriate to use [fuzzy] to describe it.

Imagine that there are many projects, all of which elegantly use a component of a program library to complete a specific function, then [extract this function into a component] is reasonable. So I said that there is no strict boundary between engineering and libraries.
B:
In fact, static polymorphism can be like this:

#include <iostream>
#include <vector>
using namespace std;

#include <boost / variant.hpp>
#include <boost / foreach.hpp>
using namespace boost;

#define foreach BOOST_FOREACH

class DeA
{
public:
void xxx () const {cout << "DeA" << endl;}
};

class DeB
{
public:
void yyy () const {cout << "DeB" << endl;}
};

class dosomething_visitor: public static_visitor <>
{
public:
void operator () (DeA const&dea) const
{
dea.xxx ();
}

void operator () (DeB const&deb) const
{
deb.yyy ();
}
};

int _tmain (int argc, _TCHAR * argv [])
{
typedef variant <DeA, DeB> de_t;
typedef vector <de_t> devec_t;

devec_t vec;
vec.push_back (DeA ());
vec.push_back (DeB ());

foreach (de_t const&de, vec)
{
apply_visitor (dosomething_visitor (), de);
}

return 0;
}

So elegant, right? :)
Reply

Use magic Report

0

Threads

3

Posts

3.00

Credits

Newbie

Rank: 1

Credits
3.00

 China

Post time: 2020-1-27 22:27:02
| Show all posts
mark.
Reply

Use magic Report

You have to log in before you can reply Login | Register

Points Rules

Contact us|Archive|Mobile|CopyRight © 2008-2023|verysource.com ( 京ICP备17048824号-1 )

Quick Reply To Top Return to the list